A place to cache linked articles (think custom and personal wayback machine)
選択できるのは25トピックまでです。 トピックは、先頭が英数字で、英数字とダッシュ('-')を使用した35文字以内のものにしてください。

index.html 31KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703
  1. <!doctype html><!-- This is a valid HTML5 document. -->
  2. <!-- Screen readers, SEO, extensions and so on. -->
  3. <html lang=fr>
  4. <!-- Has to be within the first 1024 bytes, hence before the <title>
  5. See: https://www.w3.org/TR/2012/CR-html5-20121217/document-metadata.html#charset -->
  6. <meta charset=utf-8>
  7. <!-- Why no `X-UA-Compatible` meta: https://stackoverflow.com/a/6771584 -->
  8. <!-- The viewport meta is quite crowded and we are responsible for that.
  9. See: https://codepen.io/tigt/post/meta-viewport-for-2015 -->
  10. <meta name=viewport content="width=device-width,minimum-scale=1,initial-scale=1,shrink-to-fit=no">
  11. <!-- Required to make a valid HTML5 document. -->
  12. <title>You're using &lt;em&gt; wrong (archive) — David Larlet</title>
  13. <!-- Generated from https://realfavicongenerator.net/ such a mess. -->
  14. <link rel="apple-touch-icon" sizes="180x180" href="/static/david/icons/apple-touch-icon.png">
  15. <link rel="icon" type="image/png" sizes="32x32" href="/static/david/icons/favicon-32x32.png">
  16. <link rel="icon" type="image/png" sizes="16x16" href="/static/david/icons/favicon-16x16.png">
  17. <link rel="manifest" href="/manifest.json">
  18. <link rel="mask-icon" href="/static/david/icons/safari-pinned-tab.svg" color="#5bbad5">
  19. <link rel="shortcut icon" href="/static/david/icons/favicon.ico">
  20. <meta name="apple-mobile-web-app-title" content="David Larlet">
  21. <meta name="application-name" content="David Larlet">
  22. <meta name="msapplication-TileColor" content="#da532c">
  23. <meta name="msapplication-config" content="/static/david/icons/browserconfig.xml">
  24. <meta name="theme-color" content="#f0f0ea">
  25. <!-- That good ol' feed, subscribe :p. -->
  26. <link rel=alternate type="application/atom+xml" title=Feed href="/david/log/">
  27. <meta name="robots" content="noindex, nofollow">
  28. <meta content="origin-when-cross-origin" name="referrer">
  29. <!-- Canonical URL for SEO purposes -->
  30. <link rel="canonical" href="https://logrocket.com/blog/youre-using-em-wrong/">
  31. <style>
  32. /* http://meyerweb.com/eric/tools/css/reset/ */
  33. html, body, div, span,
  34. h1, h2, h3, h4, h5, h6, p, blockquote, pre,
  35. a, abbr, address, big, cite, code,
  36. del, dfn, em, img, ins,
  37. small, strike, strong, tt, var,
  38. dl, dt, dd, ol, ul, li,
  39. fieldset, form, label, legend,
  40. table, caption, tbody, tfoot, thead, tr, th, td,
  41. article, aside, canvas, details, embed,
  42. figure, figcaption, footer, header, hgroup,
  43. menu, nav, output, ruby, section, summary,
  44. time, mark, audio, video {
  45. margin: 0;
  46. padding: 0;
  47. border: 0;
  48. font-size: 100%;
  49. font: inherit;
  50. vertical-align: baseline;
  51. }
  52. /* HTML5 display-role reset for older browsers */
  53. article, aside, details, figcaption, figure,
  54. footer, header, hgroup, menu, nav, section { display: block; }
  55. body { line-height: 1; }
  56. blockquote, q { quotes: none; }
  57. blockquote:before, blockquote:after,
  58. q:before, q:after {
  59. content: '';
  60. content: none;
  61. }
  62. table {
  63. border-collapse: collapse;
  64. border-spacing: 0;
  65. }
  66. /* http://practicaltypography.com/equity.html */
  67. /* https://calendar.perfplanet.com/2016/no-font-face-bulletproof-syntax/ */
  68. /* https://www.filamentgroup.com/lab/js-web-fonts.html */
  69. @font-face {
  70. font-family: 'EquityTextB';
  71. src: url('/static/david/css/fonts/Equity-Text-B-Regular-webfont.woff2') format('woff2'),
  72. url('/static/david/css/fonts/Equity-Text-B-Regular-webfont.woff') format('woff');
  73. font-weight: 300;
  74. font-style: normal;
  75. font-display: swap;
  76. }
  77. @font-face {
  78. font-family: 'EquityTextB';
  79. src: url('/static/david/css/fonts/Equity-Text-B-Italic-webfont.woff2') format('woff2'),
  80. url('/static/david/css/fonts/Equity-Text-B-Italic-webfont.woff') format('woff');
  81. font-weight: 300;
  82. font-style: italic;
  83. font-display: swap;
  84. }
  85. @font-face {
  86. font-family: 'EquityTextB';
  87. src: url('/static/david/css/fonts/Equity-Text-B-Bold-webfont.woff2') format('woff2'),
  88. url('/static/david/css/fonts/Equity-Text-B-Bold-webfont.woff') format('woff');
  89. font-weight: 700;
  90. font-style: normal;
  91. font-display: swap;
  92. }
  93. @font-face {
  94. font-family: 'ConcourseT3';
  95. src: url('/static/david/css/fonts/concourse_t3_regular-webfont-20190806.woff2') format('woff2'),
  96. url('/static/david/css/fonts/concourse_t3_regular-webfont-20190806.woff') format('woff');
  97. font-weight: 300;
  98. font-style: normal;
  99. font-display: swap;
  100. }
  101. /* http://practice.typekit.com/lesson/caring-about-opentype-features/ */
  102. body {
  103. /* http://www.cssfontstack.com/ Palatino 99% Win 86% Mac */
  104. font-family: "EquityTextB", Palatino, serif;
  105. background-color: #f0f0ea;
  106. color: #07486c;
  107. font-kerning: normal;
  108. -moz-osx-font-smoothing: grayscale;
  109. -webkit-font-smoothing: subpixel-antialiased;
  110. text-rendering: optimizeLegibility;
  111. font-variant-ligatures: common-ligatures contextual;
  112. font-feature-settings: "kern", "liga", "clig", "calt";
  113. }
  114. pre, code, kbd, samp, var, tt {
  115. font-family: 'TriplicateT4c', monospace;
  116. }
  117. em {
  118. font-style: italic;
  119. color: #323a45;
  120. }
  121. strong {
  122. font-weight: bold;
  123. color: black;
  124. }
  125. nav {
  126. background-color: #323a45;
  127. color: #f0f0ea;
  128. display: flex;
  129. justify-content: space-around;
  130. padding: 1rem .5rem;
  131. }
  132. nav:last-child {
  133. border-bottom: 1vh solid #2d7474;
  134. }
  135. nav a {
  136. color: #f0f0ea;
  137. }
  138. nav abbr {
  139. border-bottom: 1px dotted white;
  140. }
  141. h1 {
  142. border-top: 1vh solid #2d7474;
  143. border-bottom: .2vh dotted #2d7474;
  144. background-color: #e3e1e1;
  145. color: #323a45;
  146. text-align: center;
  147. padding: 5rem 0 4rem 0;
  148. width: 100%;
  149. font-family: 'ConcourseT3';
  150. display: flex;
  151. flex-direction: column;
  152. }
  153. h1.single {
  154. padding-bottom: 10rem;
  155. }
  156. h1 span {
  157. position: absolute;
  158. top: 1vh;
  159. left: 20%;
  160. line-height: 0;
  161. }
  162. h1 span a {
  163. line-height: 1.7;
  164. padding: 1rem 1.2rem .6rem 1.2rem;
  165. border-radius: 0 0 6% 6%;
  166. background: #2d7474;
  167. font-size: 1.3rem;
  168. color: white;
  169. text-decoration: none;
  170. }
  171. h2 {
  172. margin: 4rem 0 1rem;
  173. border-top: .2vh solid #2d7474;
  174. padding-top: 1vh;
  175. }
  176. h3 {
  177. text-align: center;
  178. margin: 3rem 0 .75em;
  179. }
  180. hr {
  181. height: .4rem;
  182. width: .4rem;
  183. border-radius: .4rem;
  184. background: #07486c;
  185. margin: 2.5rem auto;
  186. }
  187. time {
  188. display: bloc;
  189. margin-left: 0 !important;
  190. }
  191. ul, ol {
  192. margin: 2rem;
  193. }
  194. ul {
  195. list-style-type: square;
  196. }
  197. a {
  198. text-decoration-skip-ink: auto;
  199. text-decoration-thickness: 0.05em;
  200. text-underline-offset: 0.09em;
  201. }
  202. article {
  203. max-width: 50rem;
  204. display: flex;
  205. flex-direction: column;
  206. margin: 2rem auto;
  207. }
  208. article.single {
  209. border-top: .2vh dotted #2d7474;
  210. margin: -6rem auto 1rem auto;
  211. background: #f0f0ea;
  212. padding: 2rem;
  213. }
  214. article p:last-child {
  215. margin-bottom: 1rem;
  216. }
  217. p {
  218. padding: 0 .5rem;
  219. margin-left: 3rem;
  220. }
  221. p + p,
  222. figure + p {
  223. margin-top: 2rem;
  224. }
  225. blockquote {
  226. background-color: #e3e1e1;
  227. border-left: .5vw solid #2d7474;
  228. display: flex;
  229. flex-direction: column;
  230. align-items: center;
  231. padding: 1rem;
  232. margin: 1.5rem;
  233. }
  234. blockquote cite {
  235. font-style: italic;
  236. }
  237. blockquote p {
  238. margin-left: 0;
  239. }
  240. figure {
  241. border-top: .2vh solid #2d7474;
  242. background-color: #e3e1e1;
  243. text-align: center;
  244. padding: 1.5rem 0;
  245. margin: 1rem 0 0;
  246. font-size: 1.5rem;
  247. width: 100%;
  248. }
  249. figure img {
  250. max-width: 250px;
  251. max-height: 250px;
  252. border: .5vw solid #323a45;
  253. padding: 1px;
  254. }
  255. figcaption {
  256. padding: 1rem;
  257. line-height: 1.4;
  258. }
  259. aside {
  260. display: flex;
  261. flex-direction: column;
  262. background-color: #e3e1e1;
  263. padding: 1rem 0;
  264. border-bottom: .2vh solid #07486c;
  265. }
  266. aside p {
  267. max-width: 50rem;
  268. margin: 0 auto;
  269. }
  270. /* https://fvsch.com/code/css-locks/ */
  271. p, li, pre, code, kbd, samp, var, tt, time, details, figcaption {
  272. font-size: 1rem;
  273. line-height: calc( 1.5em + 0.2 * 1rem );
  274. }
  275. h1 {
  276. font-size: 1.9rem;
  277. line-height: calc( 1.2em + 0.2 * 1rem );
  278. }
  279. h2 {
  280. font-size: 1.6rem;
  281. line-height: calc( 1.3em + 0.2 * 1rem );
  282. }
  283. h3 {
  284. font-size: 1.35rem;
  285. line-height: calc( 1.4em + 0.2 * 1rem );
  286. }
  287. @media (min-width: 20em) {
  288. /* The (100vw - 20rem) / (50 - 20) part
  289. resolves to 0-1rem, depending on the
  290. viewport width (between 20em and 50em). */
  291. p, li, pre, code, kbd, samp, var, tt, time, details, figcaption {
  292. font-size: calc( 1rem + .6 * (100vw - 20rem) / (50 - 20) );
  293. line-height: calc( 1.5em + 0.2 * (100vw - 50rem) / (20 - 50) );
  294. margin-left: 0;
  295. }
  296. h1 {
  297. font-size: calc( 1.9rem + 1.5 * (100vw - 20rem) / (50 - 20) );
  298. line-height: calc( 1.2em + 0.2 * (100vw - 50rem) / (20 - 50) );
  299. }
  300. h2 {
  301. font-size: calc( 1.5rem + 1.5 * (100vw - 20rem) / (50 - 20) );
  302. line-height: calc( 1.3em + 0.2 * (100vw - 50rem) / (20 - 50) );
  303. }
  304. h3 {
  305. font-size: calc( 1.35rem + 1.5 * (100vw - 20rem) / (50 - 20) );
  306. line-height: calc( 1.4em + 0.2 * (100vw - 50rem) / (20 - 50) );
  307. }
  308. }
  309. @media (min-width: 50em) {
  310. /* The right part of the addition *must* be a
  311. rem value. In this example we *could* change
  312. the whole declaration to font-size:2.5rem,
  313. but if our baseline value was not expressed
  314. in rem we would have to use calc. */
  315. p, li, pre, code, kbd, samp, var, tt, time, details, figcaption {
  316. font-size: calc( 1rem + .6 * 1rem );
  317. line-height: 1.5em;
  318. }
  319. p, li, pre, details {
  320. margin-left: 3rem;
  321. }
  322. h1 {
  323. font-size: calc( 1.9rem + 1.5 * 1rem );
  324. line-height: 1.2em;
  325. }
  326. h2 {
  327. font-size: calc( 1.5rem + 1.5 * 1rem );
  328. line-height: 1.3em;
  329. }
  330. h3 {
  331. font-size: calc( 1.35rem + 1.5 * 1rem );
  332. line-height: 1.4em;
  333. }
  334. figure img {
  335. max-width: 500px;
  336. max-height: 500px;
  337. }
  338. }
  339. figure.unsquared {
  340. margin-bottom: 1.5rem;
  341. }
  342. figure.unsquared img {
  343. height: inherit;
  344. }
  345. @media print {
  346. body { font-size: 100%; }
  347. a:after { content: " (" attr(href) ")"; }
  348. a, a:link, a:visited, a:after {
  349. text-decoration: underline;
  350. text-shadow: none !important;
  351. background-image: none !important;
  352. background: white;
  353. color: black;
  354. }
  355. abbr[title] { border-bottom: 0; }
  356. abbr[title]:after { content: " (" attr(title) ")"; }
  357. img { page-break-inside: avoid; }
  358. @page { margin: 2cm .5cm; }
  359. h1, h2, h3 { page-break-after: avoid; }
  360. p3 { orphans: 3; widows: 3; }
  361. img {
  362. max-width: 250px !important;
  363. max-height: 250px !important;
  364. }
  365. nav, aside { display: none; }
  366. }
  367. ul.with_columns {
  368. column-count: 1;
  369. }
  370. @media (min-width: 20em) {
  371. ul.with_columns {
  372. column-count: 2;
  373. }
  374. }
  375. @media (min-width: 50em) {
  376. ul.with_columns {
  377. column-count: 3;
  378. }
  379. }
  380. ul.with_two_columns {
  381. column-count: 1;
  382. }
  383. @media (min-width: 20em) {
  384. ul.with_two_columns {
  385. column-count: 1;
  386. }
  387. }
  388. @media (min-width: 50em) {
  389. ul.with_two_columns {
  390. column-count: 2;
  391. }
  392. }
  393. .gallery {
  394. display: flex;
  395. flex-wrap: wrap;
  396. justify-content: space-around;
  397. }
  398. .gallery figure img {
  399. margin-left: 1rem;
  400. margin-right: 1rem;
  401. }
  402. .gallery figure figcaption {
  403. font-family: 'ConcourseT3'
  404. }
  405. footer {
  406. font-family: 'ConcourseT3';
  407. display: flex;
  408. flex-direction: column;
  409. border-top: 3px solid white;
  410. padding: 4rem 0;
  411. background-color: #07486c;
  412. color: white;
  413. }
  414. footer > * {
  415. max-width: 50rem;
  416. margin: 0 auto;
  417. }
  418. footer a {
  419. color: #f1c40f;
  420. }
  421. footer .avatar {
  422. width: 200px;
  423. height: 200px;
  424. border-radius: 50%;
  425. float: left;
  426. -webkit-shape-outside: circle();
  427. shape-outside: circle();
  428. margin-right: 2rem;
  429. padding: 2px 5px 5px 2px;
  430. background: white;
  431. border-left: 1px solid #f1c40f;
  432. border-top: 1px solid #f1c40f;
  433. border-right: 5px solid #f1c40f;
  434. border-bottom: 5px solid #f1c40f;
  435. }
  436. </style>
  437. <h1>
  438. <span><a id="jumper" href="#jumpto" title="Un peu perdu ?">?</a></span>
  439. You're using &lt;em&gt; wrong (archive)
  440. <time>Pour la pérennité des contenus liés. Non-indexé, retrait sur simple email.</time>
  441. </h1>
  442. <section>
  443. <article>
  444. <h3><a href="https://logrocket.com/blog/youre-using-em-wrong/">Source originale du contenu</a></h3>
  445. <p>It’s been a bumpy road that somehow got us misusing one of the most important text-level semantic tags.</p>
  446. <p>In the dark ages of HTML, &lt;em&gt; was barely used at all, despite being part of the specs since really early on (<a href="http://www.ietf.org/rfc/rfc1866.txt" rel="noreferrer nofollow noopener noopener">HTML 2.0</a> standard, 1995). But at that point in time and for some years to come, (almost) no one was thinking of semantics or even separation of concerns. Italics were simply marked up with &lt;i&gt; tags, and we wouldn’t give it a second thought.</p>
  447. <p>Then somewhere along the way, someone shouted <em>“Semantics!”</em> and everybody started to hate the poor little &lt;i&gt; tag like a bad neighbor. A really, <em>really</em> bad neighbor.</p>
  448. <p>&lt;em&gt; was all the rage, with supposed benefits for accessibility and SEO, which got us all using it everywhere. By <a href="https://www.w3.org/TR/html401/struct/text.html#edef-EM">HTML 4</a>, everybody knew &lt;em&gt; was for emphasis and styled as italics, &lt;strong&gt; was for stronger emphasis and styled as bold text. If you ever dared to use &lt;i&gt;, you would be instantly tagged as a bad developer.</p>
  449. <p>There were even rumours that the <em>totally un-semantic</em> &lt;i&gt; and &lt;b&gt; would be deprecated any minute like &lt;u&gt; was, and our WYSIWYG editors didn’t even have a button for &lt;i&gt; or &lt;b&gt;, they would simply put an &lt;em&gt; whenever we clicked the italics icon and &lt;strong&gt; when clicking the bold.</p>
  450. <p>But….</p>
  451. <h2 id="the-em-tag-is-not-for-emphasis">The &lt;em&gt; tag is not for emphasis</h2>
  452. <p>Let me repeat that: <strong>&lt;em&gt; is <em>not</em> for emphasis</strong>. In <a href="https://www.w3.org/TR/html50/text-level-semantics.html#the-em-element">HTML5</a>, <strong>&lt;em&gt; is for <em>stress </em>emphasis</strong>.</p>
  453. <p>This might look like a subtle distinction, but that’s where all of this confusion comes from. The HTML 2, 3 and 4 specs were pretty vague on their definition of “emphasis”, making it look like a lesser version of &lt;strong&gt;. Something to mark text of higher importance, but not <em>so</em> important.</p>
  454. <p>But when HTML5 rolled out, they made sure to draw a clearer line on what they intended &lt;em&gt; to be, while redefining the &lt;i&gt; from a text-italicising tag into a semantic tag that pretty much wraps most other use cases for italics.</p>
  455. <p>But <strong>what is stress emphasis?</strong> Stress emphasis is the phonetic resource of changing pitch and/or dragging the word to denote a special meaning to it. It marks a word in a way that changes the meaning of the whole sentence. It’s used for a correction, clarification, sarcasm, the key part of a counter-argument, etc.</p>
  456. <p>Native English speakers do this without even thinking about it, but more often than not, those of us for whom English is a second language had to sit through really boring lessons about it. </p>
  457. <p>A quick look at the <a href="https://www.w3.org/TR/html50/text-level-semantics.html#the-em-element">examples from the spec itself</a> should make it clearer: they take the phrase “Cats are cute animals” and change the &lt;em&gt; tag from word to word, thus changing the meaning from implying that the discussion was about which animals are cute, to imply that the truth of the whole sentence was in question, implying that someone else said they were ugly, to the ridiculous notion that someone confused cats for plants. Or gods. Probably gods.</p>
  458. <h2 id="some-use-cases">Some use cases</h2>
  459. <p>We can use stress emphasis to communicate the higher importance of a word:</p>
  460. <pre><code>&lt;p&gt;"I'm not &lt;em&gt;that&lt;/em&gt; into text semantics"&lt;/p&gt;</code></pre>
  461. <p>The emphasis on “that” makes it clear that, while interested in it, it will not stop the speaker from using incorrect tags every now and then.</p>
  462. <p>But we can use it to indicate sarcasm as well:</p>
  463. <pre><code>&lt;p&gt;Sure, another TV is &lt;em&gt;exactly&lt;/em&gt; what our family needs&lt;/p&gt;</code></pre>
  464. <p>To correct or clarify information, quoting <a href="https://www.quackit.com/html/tags/html_em_tag.cfm">Quackit excellent guide on text-level semantics:</a></p>
  465. <pre><code>&lt;p&gt;"Did you say that you are a &lt;em&gt;chameleon&lt;/em&gt;?"&lt;/p&gt;
  466. &lt;p&gt;"No, I am a &lt;em&gt;comedian&lt;/em&gt;"&lt;/p&gt;</code></pre>
  467. <p>We might also use it to hint at some implications:</p>
  468. <pre><code>&lt;p&gt;What &lt;em&gt;we&lt;/em&gt; need to do is finish this project asap&lt;/p&gt;</code></pre>
  469. <p>The emphasis implies that there’s <em>someone else</em> who needs to do <em>something else</em>.</p>
  470. <p>It’s also used to mark the point of confrontation:</p>
  471. <pre><code>&lt;p&gt;&lt;em&gt;Dogs&lt;/em&gt; are cute animals&lt;/p&gt;</code></pre>
  472. <p>I’m implying a confrontation with somebody else who claimed <em>other</em> animals are cute (in this case, whoever wrote the HTML5 spec example) and marking the point of discrepancy.</p>
  473. <p>&lt;em&gt; tags would normally be used on single words, maybe two, but we can sometimes use it on the whole sentence, to mark that the speaker is <em>really</em> fighting to get their point across, or denote an urgency. An exclamation can be the right use for &lt;em&gt; in a phrase:</p>
  474. <pre><code>&lt;p&gt;&lt;em&gt;We need to get out of here!&lt;/em&gt;&lt;/p&gt;</code></pre>
  475. <p>There are a gazillion WYSIWYG editors that get this wrong. From actual software intended to ease the creation of simple websites by drag-and-drop to blogging platforms; If your editor has the typical “italics — bold — underline” buttons, then most likely there’s nothing semantic about it.</p>
  476. <p>Most (possibly all) of the ones that claim to be “semantic” are just throwing &lt;em&gt; for any italicised text and &lt;strong&gt; for bold text, without giving a thought about <em>why</em> the text is formatted that way (which is exactly what “semantics” try to solve). <strong>If there are no independent buttons for &lt;i&gt; and &lt;em&gt;</strong>, or a super-intelligent algorithm capable of interpreting <em>why</em> you are italicising text and applying the correct tag for the use case, <strong>it’s <em>not</em> semantic.</strong></p>
  477. <p>Even our modern tools fall short when it comes to this. <strong>Markdown</strong> implementations use exactly the same approach of &lt;em&gt; for italicised text, &lt;strong&gt; for bold text.</p>
  478. <p>Some of the reference <a href="https://github.com/adam-p/markdown-here/wiki/Markdown-Cheatsheet#emphasis">guides </a>on it even go as far as saying</p>
  479. <blockquote>Emphasis, <strong>aka </strong>italics, with asterisks or underscores.</blockquote>
  480. <p>Which, at that point, really makes me think it might be the developers and not the tools.</p>
  481. <p>I get it, Markdown is intended for quick writing, it even says so in the <a href="https://daringfireball.net/projects/markdown/syntax#html" rel="noreferrer nofollow noopener noopener">documentation</a></p>
  482. <blockquote>Markdown is not a replacement for HTML, or even close to it. Its syntax is very small, corresponding only to a very small subset of HTML tags. The idea is <strong>not </strong>to create a syntax that makes it easier to insert HTML tags. (…) HTML is a <strong>publishing </strong>format; Markdown is a <strong>writing </strong>format. Thus, Markdown’s formatting syntax only addresses issues that can be conveyed in plain text.</blockquote>
  483. <p>We could (in some implementations) manually use the &lt;i&gt; tag inside markdown formatted text, but even then, I feel like they should have addressed both in the language.</p>
  484. <h2 id="when-not-to-use-em">When NOT to use &lt;em&gt;</h2>
  485. <p>There are many cases where italics are meant to represent <em>something other than</em> emphasis.</p>
  486. <p>In which case, the correct tag is actually <strong>&lt;i&gt;.</strong> Some may think &lt;i&gt; is a non-semantic tag, but it’s actually pretty much a catch-all tag for use cases where we want italicised text <em>without</em> stress emphasis.</p>
  487. <p>To quote from the spec</p>
  488. <blockquote>The i element represents a span of text in an <strong>alternate voice or mood</strong>, or otherwise offset from the normal prose in a manner indicating a different quality of text</blockquote>
  489. <p>For instance, we should use &lt;i&gt; when marking an idiomatic phrase from another language, with their corresponding <strong>lang</strong> attribute so screen readers get the right pronunciation:</p>
  490. <pre><code>&lt;p&gt;I would like us all to use better text-level semantics, but &lt;i lang="fr"&gt;c'est la vie&lt;/i&gt;&lt;/p&gt;
  491. &lt;p&gt;Major of Springfield, &lt;i lang="la"&gt;Corruptus in Extremis&lt;/i&gt;&lt;/p&gt;</code></pre>
  492. <p>It is also used for taxonomic nomenclature:</p>
  493. <pre><code>&lt;p&gt;&lt;i lang="la"&gt;Carnivorous Vulgaris&lt;/i&gt; keeps chasing his prey, &lt;i lang="la"&gt;Accelerati Incrediblus&lt;/i&gt; &lt;/p&gt;</code></pre>
  494. <p>To mark a technical term:</p>
  495. <pre><code>&lt;p&gt;Concepts like &lt;i&gt;closure&lt;/i&gt; can be confusing to JavaScript beginners&lt;/p&gt;</code></pre>
  496. <p>fictional character voices:</p>
  497. <pre><code>&lt;p&gt;&lt;i&gt;- That's what I do: I drink and I know things&lt;/i&gt;&lt;/p&gt;</code></pre>
  498. <p>thoughts:</p>
  499. <pre><code>&lt;p&gt;&lt;i&gt;I am better than this&lt;/i&gt;, she thought as she walked away&lt;/p&gt;</code></pre>
  500. <p>and some other use cases, depending on the language (such as ship names).</p>
  501. <p>Another italic-causing tag that we might find a good use for is the <strong>&lt;cite&gt;</strong> element.</p>
  502. <p>It is used to mark the title of a work (painting, book, etc):</p>
  503. <pre><code>&lt;p&gt;&lt;cite&gt;The persistence of memory&lt;/cite&gt; by Salvador Dalí. Painted in 1931&lt;/p&gt;</code></pre>
  504. <p>or the author:</p>
  505. <pre><code>&lt;p&gt; According to &lt;cite title="You're using &lt;em&gt; wrong. Published by LogRocket (October, 2018)"&gt;Facundo Corradini&lt;/cite&gt;, we should reconsider the tags we're using to italicise text.</code></pre>
  506. <p>In many platforms &lt;blockquote&gt; causes the text to be italicised (as well as indented), but I don’t think anyone is confusing that one with &lt;em&gt;, and editors always have the proper button for it. It can cause some nesting issues though, so that’s something to keep in mind.</p>
  507. <h2 id="why-it-matters">Why it matters</h2>
  508. <p>Accessibility, of course. Every time we use the wrong tag to italicise a word, most of our users won’t even notice. As long as we are doing so according to our language conventions, the word will be read with the intended emphasis.</p>
  509. <p>But <strong>we are making things so much more complicated for screen readers</strong>, especially when nesting. If we were doing our job right, speech synthesizers would be able to easily make the right pitch corrections. But we’re so far gone in this that all of them (as far as I know) have it disabled by default, and <strong>that’s a big part of what makes them feel so unnatural</strong>.</p>
  510. <p>It can be enabled in some, but even then, they opted to just get anything that’s italicised and apply the inflection.. which is just as bad. They are correcting our errors.</p>
  511. <p>But maybe, if we all start doing it the right way, we can get them to work properly in the future and feel much more human. <strong>We can communicate better</strong>.</p>
  512. <p>I have to admit, this whole article kind of started with my strong disagreement with this <a href="https://twitter.com/css/status/1037774960943620097" rel="noreferrer nofollow noopener noopener">CSS-Tricks tweet on “nested emphasis”</a>.</p>
  513. <figure class="kg-card kg-embed-card"><blockquote class="twitter-tweet"><p lang="en" dir="ltr">Nested emphasis? Undo it.<br/><br/>```<br/>em em {<br/> font-style: normal;<br/>}<br/>``` <a href="https://t.co/YIaBPoKvod">pic.twitter.com/YIaBPoKvod</a></p>— CSS-Tricks (@css) <a href="https://twitter.com/css/status/1037774960943620097?ref_src=twsrc%5Etfw">September 6, 2018</a></blockquote>
  514. </figure>
  515. <p><br/>Let’s break that down: </p>
  516. <pre><code>&lt;em&gt;Now &lt;em&gt;that's&lt;/em&gt; a change, she thought&lt;/em&gt;
  517. em em { font-style: normal;}</code></pre>
  518. <p><em>Now</em> that’s <em>a change, she thought</em></p>
  519. <p>The given phrase is a fictional character’s thought, who is putting emphasis on “that’s”, implying the change they’re talking about is really noticeable, probably compared to another, previous small change.</p>
  520. <p>For starters, “Now that’s a change” is a thought, so it should be marked down with an &lt;i&gt; tag, not &lt;em&gt;. But as we previously discussed, pretty much all of our tools are forcing us to do these kinds of things, so I can live with that.</p>
  521. <p>The part that really bugged me was the core idea of resetting the italics. To me, it looks like the worst possible solution. It doesn’t just fail to convey the intended <em>stress</em> on that word, it actually makes it appear outside the scope of the fictional character’s thought.</p>
  522. <p>Look how much better it conveys the stress if we opt for adding bold weight instead:</p>
  523. <pre><code>&lt;i&gt;Now &lt;em&gt;that's&lt;/em&gt; a change&lt;/i&gt;, she thought
  524. i em { font-weight: bold;}</code></pre>
  525. <p><em>Now </em><strong><em>that’s</em></strong><em> a change</em>, she thought</p>
  526. <p>Some might argue that an underline would get the job done just as well, which might be true for print, but it’s clearly a no-go for the web, as it would make it look like a link:</p>
  527. <pre><code>&lt;i&gt;Now &lt;em&gt;that's&lt;/em&gt; a change&lt;/i&gt;, she thought
  528. i em {text-decoration: underline;}</code></pre>
  529. <p>Or maybe use caps, after all, it’s just one word. Personally, I believe this one goes over-the-top and might be better suited for nesting bold-causing tags, as it’s commonly interpreted as shouting:</p>
  530. <pre><code>&lt;i&gt;Now &lt;em&gt;that's&lt;/em&gt; a change&lt;/i&gt;, she thought
  531. i em {text-transform: uppercase;}</code></pre>
  532. <p><em>Now THAT’S a change</em>, she thought</p>
  533. <p>There are some other combinations of tags that would cause italicised text inside an italicised scope, but most of them are &lt;em&gt; inside some other tag, so I would argue that just setting the inner tag to bold does the trick almost every time.</p>
  534. <h2 id="takeaways">Takeaways</h2>
  535. <ul><li>Whenever you’re throwing italics at a word/phrase, think about why are you doing so and choose the right tag for the task if possible</li><li>When in doubt, read it aloud. Or get someone else to read it aloud and see if it matches your expected inflections</li><li>If you’re using italics on more than one or two words, &lt;em&gt; is probably not the right tag</li><li>Marking a whole phrase with &lt;em&gt; means urgency, so it would normally only be used in exclamations</li><li>When nesting italics-producing tags, go for a bold weight. And for the love of HTML, do not undo them!</li></ul>
  536. <p>We need to start considering why we are italicising text and using the right tag for it. We can make our tools better. We can make the web better.</p>
  537. </article>
  538. </section>
  539. <nav id="jumpto">
  540. <p>
  541. <a href="/david/blog/">Accueil du blog</a> |
  542. <a href="https://logrocket.com/blog/youre-using-em-wrong/">Source originale</a> |
  543. <a href="/david/stream/2019/">Accueil du flux</a>
  544. </p>
  545. </nav>
  546. <footer>
  547. <div>
  548. <img src="/static/david/david-larlet-avatar.jpg" loading="lazy" class="avatar" width="200" height="200">
  549. <p>
  550. Bonjour/Hi!
  551. Je suis <a href="/david/" title="Profil public">David&nbsp;Larlet</a>, je vis actuellement à Montréal et j’alimente cet espace depuis 15 ans. <br>
  552. Si tu as apprécié cette lecture, n’hésite pas à poursuivre ton exploration. Par exemple via les <a href="/david/blog/" title="Expériences bienveillantes">réflexions bimestrielles</a>, la <a href="/david/stream/2019/" title="Pensées (dés)articulées">veille hebdomadaire</a> ou en t’abonnant au <a href="/david/log/" title="S’abonner aux publications via RSS">flux RSS</a> (<a href="/david/blog/2019/flux-rss/" title="Tiens c’est quoi un flux RSS ?">so 2005</a>).
  553. </p>
  554. <p>
  555. Je m’intéresse à la place que je peux avoir dans ce monde. En tant qu’humain, en tant que membre d’une famille et en tant qu’associé d’une coopérative. De temps en temps, je fais aussi des <a href="https://github.com/davidbgk" title="Principalement sur Github mais aussi ailleurs">trucs techniques</a>. Et encore plus rarement, <a href="/david/talks/" title="En ce moment je laisse plutôt la place aux autres">j’en parle</a>.
  556. </p>
  557. <p>
  558. Voici quelques articles choisis :
  559. <a href="/david/blog/2019/faire-equipe/" title="Accéder à l’article complet">Faire équipe</a>,
  560. <a href="/david/blog/2018/bivouac-automnal/" title="Accéder à l’article complet">Bivouac automnal</a>,
  561. <a href="/david/blog/2018/commodite-effondrement/" title="Accéder à l’article complet">Commodité et effondrement</a>,
  562. <a href="/david/blog/2017/donnees-communs/" title="Accéder à l’article complet">Des données aux communs</a>,
  563. <a href="/david/blog/2016/accompagner-enfant/" title="Accéder à l’article complet">Accompagner un enfant</a>,
  564. <a href="/david/blog/2016/senior-developer/" title="Accéder à l’article complet">Senior developer</a>,
  565. <a href="/david/blog/2016/illusion-sociale/" title="Accéder à l’article complet">L’illusion sociale</a>,
  566. <a href="/david/blog/2016/instantane-scopyleft/" title="Accéder à l’article complet">Instantané Scopyleft</a>,
  567. <a href="/david/blog/2016/enseigner-web/" title="Accéder à l’article complet">Enseigner le Web</a>,
  568. <a href="/david/blog/2016/simplicite-defaut/" title="Accéder à l’article complet">Simplicité par défaut</a>,
  569. <a href="/david/blog/2016/minimalisme-esthetique/" title="Accéder à l’article complet">Minimalisme et esthétique</a>,
  570. <a href="/david/blog/2014/un-web-omni-present/" title="Accéder à l’article complet">Un web omni-présent</a>,
  571. <a href="/david/blog/2014/manifeste-developpeur/" title="Accéder à l’article complet">Manifeste de développeur</a>,
  572. <a href="/david/blog/2013/confort-convivialite/" title="Accéder à l’article complet">Confort et convivialité</a>,
  573. <a href="/david/blog/2013/testament-numerique/" title="Accéder à l’article complet">Testament numérique</a>,
  574. et <a href="/david/blog/" title="Accéder aux archives">bien d’autres…</a>
  575. </p>
  576. <p>
  577. On peut <a href="mailto:david%40larlet.fr" title="Envoyer un courriel">échanger par courriel</a>. Si éventuellement tu souhaites que l’on travaille ensemble, tu devrais commencer par consulter le <a href="http://larlet.com">profil dédié à mon activité professionnelle</a> et/ou contacter directement <a href="http://scopyleft.fr/">scopyleft</a>, la <abbr title="Société coopérative et participative">SCOP</abbr> dont je fais partie depuis six ans. Je recommande au préalable de lire <a href="/david/blog/2018/cout-site/" title="Attention ce qui va suivre peut vous choquer">combien coûte un site</a> et pourquoi je suis plutôt favorable à une <a href="/david/pro/devis/" title="Discutons-en !">non-demande de devis</a>.
  578. </p>
  579. <p>
  580. Je ne traque pas ta navigation mais mon
  581. <abbr title="Alwaysdata, 62 rue Tiquetonne 75002 Paris, +33.184162340">hébergeur</abbr>
  582. conserve des logs d’accès.
  583. </p>
  584. </div>
  585. </footer>
  586. <script type="text/javascript">
  587. ;(_ => {
  588. const jumper = document.getElementById('jumper')
  589. jumper.addEventListener('click', e => {
  590. e.preventDefault()
  591. const anchor = e.target.getAttribute('href')
  592. const targetEl = document.getElementById(anchor.substring(1))
  593. targetEl.scrollIntoView({behavior: 'smooth'})
  594. })
  595. })()
  596. </script>