Repository with sources and generator of https://larlet.fr/david/ https://larlet.fr/david/
Ви не можете вибрати більше 25 тем Теми мають розпочинатися з літери або цифри, можуть містити дефіси (-) і не повинні перевищувати 35 символів.

5 роки тому
5 роки тому
5 роки тому
5 роки тому
5 роки тому
5 роки тому
5 роки тому
5 роки тому
5 роки тому
5 роки тому
5 роки тому
5 роки тому
5 роки тому
5 роки тому
5 роки тому
5 роки тому
5 роки тому
5 роки тому
5 роки тому
5 роки тому
5 роки тому
5 роки тому
5 роки тому
5 роки тому
5 роки тому
5 роки тому
5 роки тому
5 роки тому
5 роки тому
5 роки тому
5 роки тому
5 роки тому
5 роки тому
5 роки тому
5 роки тому
5 роки тому
5 роки тому
5 роки тому
5 роки тому
5 роки тому
5 роки тому
5 роки тому
5 роки тому
5 роки тому
5 роки тому
5 роки тому
5 роки тому
5 роки тому
5 роки тому
5 роки тому
5 роки тому
5 роки тому
5 роки тому
5 роки тому
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803
  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>Apprentissage et auto-dépréciation — 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. <!-- Canonical URL for SEO purposes -->
  28. <link rel="canonical" href="https://larlet.fr/david/blog/2016/apprentissage-autodepreciation/">
  29. <!-- SEO/Semantic metadata -->
  30. <meta name="description" content="Toute ma démarche a été de les pousser du comment scolaire au pourquoi professionnel." />
  31. <meta name="twitter:description" property="og:description" itemprop="description" content="Toute ma démarche a été de les pousser du comment scolaire au pourquoi professionnel." />
  32. <meta name="twitter:title" property="og:title" itemprop="name" content="Apprentissage et auto-dépréciation" />
  33. <meta name="twitter:card" content="summary" />
  34. <meta name="twitter:creator" content="@davidbgk" />
  35. <meta name="twitter:url" property="og:url" content="https://larlet.fr/david/blog/2016/apprentissage-autodepreciation/" />
  36. <meta property="og:type" content="article" />
  37. <meta property="og:site_name" content="David Larlet (@davidbgk)" />
  38. <meta name="twitter:image" property="og:image" itemprop="image" content="https://larlet.fr/static/david/blog/2016/apprentissage-autodepreciation.jpg" />
  39. <style>
  40. /* http://meyerweb.com/eric/tools/css/reset/ */
  41. html, body, div, span,
  42. h1, h2, h3, h4, h5, h6, p, blockquote, pre,
  43. a, abbr, address, big, cite, code,
  44. del, dfn, em, img, ins,
  45. small, strike, strong, tt, var,
  46. dl, dt, dd, ol, ul, li,
  47. fieldset, form, label, legend,
  48. table, caption, tbody, tfoot, thead, tr, th, td,
  49. article, aside, canvas, details, embed,
  50. figure, figcaption, footer, header, hgroup,
  51. menu, nav, output, ruby, section, summary,
  52. time, mark, audio, video {
  53. margin: 0;
  54. padding: 0;
  55. border: 0;
  56. font-size: 100%;
  57. font: inherit;
  58. vertical-align: baseline;
  59. }
  60. /* HTML5 display-role reset for older browsers */
  61. article, aside, details, figcaption, figure,
  62. footer, header, hgroup, menu, nav, section { display: block; }
  63. body { line-height: 1; }
  64. blockquote, q { quotes: none; }
  65. blockquote:before, blockquote:after,
  66. q:before, q:after {
  67. content: '';
  68. content: none;
  69. }
  70. table {
  71. border-collapse: collapse;
  72. border-spacing: 0;
  73. }
  74. /* http://practicaltypography.com/equity.html */
  75. /* https://calendar.perfplanet.com/2016/no-font-face-bulletproof-syntax/ */
  76. /* https://www.filamentgroup.com/lab/js-web-fonts.html */
  77. @font-face {
  78. font-family: 'EquityTextB';
  79. src: url('/static/david/css/fonts/Equity-Text-B-Regular-webfont.woff2') format('woff2'),
  80. url('/static/david/css/fonts/Equity-Text-B-Regular-webfont.woff') format('woff');
  81. font-weight: 300;
  82. font-style: normal;
  83. font-display: swap;
  84. }
  85. @font-face {
  86. font-family: 'EquityTextB';
  87. src: url('/static/david/css/fonts/Equity-Text-B-Italic-webfont.woff2') format('woff2'),
  88. url('/static/david/css/fonts/Equity-Text-B-Italic-webfont.woff') format('woff');
  89. font-weight: 300;
  90. font-style: italic;
  91. font-display: swap;
  92. }
  93. @font-face {
  94. font-family: 'EquityTextB';
  95. src: url('/static/david/css/fonts/Equity-Text-B-Bold-webfont.woff2') format('woff2'),
  96. url('/static/david/css/fonts/Equity-Text-B-Bold-webfont.woff') format('woff');
  97. font-weight: 700;
  98. font-style: normal;
  99. font-display: swap;
  100. }
  101. @font-face {
  102. font-family: 'ConcourseT3';
  103. src: url('/static/david/css/fonts/concourse_t3_regular-webfont-20190806.woff2') format('woff2'),
  104. url('/static/david/css/fonts/concourse_t3_regular-webfont-20190806.woff') format('woff');
  105. font-weight: 300;
  106. font-style: normal;
  107. font-display: swap;
  108. }
  109. /* http://practice.typekit.com/lesson/caring-about-opentype-features/ */
  110. body {
  111. /* http://www.cssfontstack.com/ Palatino 99% Win 86% Mac */
  112. font-family: "EquityTextB", Palatino, serif;
  113. background-color: #f0f0ea;
  114. color: #07486c;
  115. font-kerning: normal;
  116. -moz-osx-font-smoothing: grayscale;
  117. -webkit-font-smoothing: subpixel-antialiased;
  118. text-rendering: optimizeLegibility;
  119. font-variant-ligatures: common-ligatures contextual;
  120. font-feature-settings: "kern", "liga", "clig", "calt";
  121. }
  122. pre, code, kbd, samp, var, tt {
  123. font-family: 'TriplicateT4c', monospace;
  124. }
  125. em {
  126. font-style: italic;
  127. color: #323a45;
  128. }
  129. strong {
  130. font-weight: bold;
  131. color: black;
  132. }
  133. nav {
  134. background-color: #323a45;
  135. color: #f0f0ea;
  136. display: flex;
  137. justify-content: space-around;
  138. padding: 1rem .5rem;
  139. }
  140. nav:last-child {
  141. border-bottom: 1vh solid #2d7474;
  142. }
  143. nav a {
  144. color: #f0f0ea;
  145. }
  146. nav abbr {
  147. border-bottom: 1px dotted white;
  148. }
  149. h1 {
  150. border-top: 1vh solid #2d7474;
  151. border-bottom: .2vh dotted #2d7474;
  152. background-color: #e3e1e1;
  153. color: #323a45;
  154. text-align: center;
  155. padding: 5rem 0 4rem 0;
  156. width: 100%;
  157. font-family: 'ConcourseT3';
  158. display: flex;
  159. flex-direction: column;
  160. }
  161. h1.single {
  162. padding-bottom: 10rem;
  163. }
  164. h1 span {
  165. position: absolute;
  166. top: 1vh;
  167. left: 20%;
  168. line-height: 0;
  169. }
  170. h1 span a {
  171. line-height: 1.7;
  172. padding: 1rem 1.2rem .6rem 1.2rem;
  173. border-radius: 0 0 6% 6%;
  174. background: #2d7474;
  175. font-size: 1.3rem;
  176. color: white;
  177. text-decoration: none;
  178. }
  179. h2 {
  180. margin: 4rem 0 1rem;
  181. border-top: .2vh solid #2d7474;
  182. padding-top: 1vh;
  183. }
  184. h3 {
  185. text-align: center;
  186. margin: 3rem 0 .75em;
  187. }
  188. hr {
  189. height: .4rem;
  190. width: .4rem;
  191. border-radius: .4rem;
  192. background: #07486c;
  193. margin: 2.5rem auto;
  194. }
  195. time {
  196. display: bloc;
  197. margin-left: 0 !important;
  198. }
  199. ul, ol {
  200. margin: 2rem;
  201. }
  202. ul {
  203. list-style-type: square;
  204. }
  205. a {
  206. text-decoration-skip-ink: auto;
  207. text-decoration-thickness: 0.05em;
  208. text-underline-offset: 0.09em;
  209. }
  210. article {
  211. max-width: 50rem;
  212. display: flex;
  213. flex-direction: column;
  214. margin: 2rem auto;
  215. }
  216. article.single {
  217. border-top: .2vh dotted #2d7474;
  218. margin: -6rem auto 1rem auto;
  219. background: #f0f0ea;
  220. padding: 2rem;
  221. }
  222. article p:last-child {
  223. margin-bottom: 1rem;
  224. }
  225. p {
  226. padding: 0 .5rem;
  227. margin-left: 3rem;
  228. }
  229. p + p,
  230. figure + p {
  231. margin-top: 2rem;
  232. }
  233. blockquote {
  234. background-color: #e3e1e1;
  235. border-left: .5vw solid #2d7474;
  236. display: flex;
  237. flex-direction: column;
  238. align-items: center;
  239. padding: 1rem;
  240. margin: 1.5rem;
  241. }
  242. blockquote cite {
  243. font-style: italic;
  244. }
  245. blockquote p {
  246. margin-left: 0;
  247. }
  248. figure {
  249. border-top: .2vh solid #2d7474;
  250. background-color: #e3e1e1;
  251. text-align: center;
  252. padding: 1.5rem 0;
  253. margin: 1rem 0 0;
  254. font-size: 1.5rem;
  255. width: 100%;
  256. }
  257. figure img {
  258. max-width: 250px;
  259. max-height: 250px;
  260. border: .5vw solid #323a45;
  261. padding: 1px;
  262. }
  263. figcaption {
  264. padding: 1rem;
  265. line-height: 1.4;
  266. }
  267. aside {
  268. display: flex;
  269. flex-direction: column;
  270. background-color: #e3e1e1;
  271. padding: 1rem 0;
  272. border-bottom: .2vh solid #07486c;
  273. }
  274. aside p {
  275. max-width: 50rem;
  276. margin: 0 auto;
  277. }
  278. /* https://fvsch.com/code/css-locks/ */
  279. p, li, pre, code, kbd, samp, var, tt, time, details, figcaption {
  280. font-size: 1rem;
  281. line-height: calc( 1.5em + 0.2 * 1rem );
  282. }
  283. h1 {
  284. font-size: 1.9rem;
  285. line-height: calc( 1.2em + 0.2 * 1rem );
  286. }
  287. h2 {
  288. font-size: 1.6rem;
  289. line-height: calc( 1.3em + 0.2 * 1rem );
  290. }
  291. h3 {
  292. font-size: 1.35rem;
  293. line-height: calc( 1.4em + 0.2 * 1rem );
  294. }
  295. @media (min-width: 20em) {
  296. /* The (100vw - 20rem) / (50 - 20) part
  297. resolves to 0-1rem, depending on the
  298. viewport width (between 20em and 50em). */
  299. p, li, pre, code, kbd, samp, var, tt, time, details, figcaption {
  300. font-size: calc( 1rem + .6 * (100vw - 20rem) / (50 - 20) );
  301. line-height: calc( 1.5em + 0.2 * (100vw - 50rem) / (20 - 50) );
  302. margin-left: 0;
  303. }
  304. h1 {
  305. font-size: calc( 1.9rem + 1.5 * (100vw - 20rem) / (50 - 20) );
  306. line-height: calc( 1.2em + 0.2 * (100vw - 50rem) / (20 - 50) );
  307. }
  308. h2 {
  309. font-size: calc( 1.5rem + 1.5 * (100vw - 20rem) / (50 - 20) );
  310. line-height: calc( 1.3em + 0.2 * (100vw - 50rem) / (20 - 50) );
  311. }
  312. h3 {
  313. font-size: calc( 1.35rem + 1.5 * (100vw - 20rem) / (50 - 20) );
  314. line-height: calc( 1.4em + 0.2 * (100vw - 50rem) / (20 - 50) );
  315. }
  316. }
  317. @media (min-width: 50em) {
  318. /* The right part of the addition *must* be a
  319. rem value. In this example we *could* change
  320. the whole declaration to font-size:2.5rem,
  321. but if our baseline value was not expressed
  322. in rem we would have to use calc. */
  323. p, li, pre, code, kbd, samp, var, tt, time, details, figcaption {
  324. font-size: calc( 1rem + .6 * 1rem );
  325. line-height: 1.5em;
  326. }
  327. p, li, pre, details {
  328. margin-left: 3rem;
  329. }
  330. h1 {
  331. font-size: calc( 1.9rem + 1.5 * 1rem );
  332. line-height: 1.2em;
  333. }
  334. h2 {
  335. font-size: calc( 1.5rem + 1.5 * 1rem );
  336. line-height: 1.3em;
  337. }
  338. h3 {
  339. font-size: calc( 1.35rem + 1.5 * 1rem );
  340. line-height: 1.4em;
  341. }
  342. figure img {
  343. max-width: 500px;
  344. max-height: 500px;
  345. }
  346. }
  347. figure.unsquared {
  348. margin-bottom: 1.5rem;
  349. }
  350. figure.unsquared img {
  351. height: inherit;
  352. }
  353. @media print {
  354. body { font-size: 100%; }
  355. a:after { content: " (" attr(href) ")"; }
  356. a, a:link, a:visited, a:after {
  357. text-decoration: underline;
  358. text-shadow: none !important;
  359. background-image: none !important;
  360. background: white;
  361. color: black;
  362. }
  363. abbr[title] { border-bottom: 0; }
  364. abbr[title]:after { content: " (" attr(title) ")"; }
  365. img { page-break-inside: avoid; }
  366. @page { margin: 2cm .5cm; }
  367. h1, h2, h3 { page-break-after: avoid; }
  368. p3 { orphans: 3; widows: 3; }
  369. img {
  370. max-width: 250px !important;
  371. max-height: 250px !important;
  372. }
  373. nav, aside { display: none; }
  374. }
  375. ul.with_columns {
  376. column-count: 1;
  377. }
  378. @media (min-width: 20em) {
  379. ul.with_columns {
  380. column-count: 2;
  381. }
  382. }
  383. @media (min-width: 50em) {
  384. ul.with_columns {
  385. column-count: 3;
  386. }
  387. }
  388. ul.with_two_columns {
  389. column-count: 1;
  390. }
  391. @media (min-width: 20em) {
  392. ul.with_two_columns {
  393. column-count: 1;
  394. }
  395. }
  396. @media (min-width: 50em) {
  397. ul.with_two_columns {
  398. column-count: 2;
  399. }
  400. }
  401. .gallery {
  402. display: flex;
  403. flex-wrap: wrap;
  404. justify-content: space-around;
  405. }
  406. .gallery figure img {
  407. margin-left: 1rem;
  408. margin-right: 1rem;
  409. }
  410. .gallery figure figcaption {
  411. font-family: 'ConcourseT3'
  412. }
  413. footer {
  414. font-family: 'ConcourseT3';
  415. display: flex;
  416. flex-direction: column;
  417. border-top: 3px solid white;
  418. padding: 4rem 0;
  419. background-color: #07486c;
  420. color: white;
  421. }
  422. footer > * {
  423. max-width: 50rem;
  424. margin: 0 auto;
  425. }
  426. footer a {
  427. color: #f1c40f;
  428. }
  429. footer .avatar {
  430. width: 200px;
  431. height: 200px;
  432. border-radius: 50%;
  433. float: left;
  434. -webkit-shape-outside: circle();
  435. shape-outside: circle();
  436. margin-right: 2rem;
  437. padding: 2px 5px 5px 2px;
  438. background: white;
  439. border-left: 1px solid #f1c40f;
  440. border-top: 1px solid #f1c40f;
  441. border-right: 5px solid #f1c40f;
  442. border-bottom: 5px solid #f1c40f;
  443. }
  444. </style>
  445. <h1 class="single">
  446. <span><a id="jumper" href="#jumpto" title="Un peu perdu ?">?</a></span>
  447. Apprentissage et auto-dépréciation
  448. <time>Publié le 4 janvier 2016</time>
  449. </h1>
  450. <article class="single">
  451. <blockquote>
  452. <p>This unfortunately became a trend. I don’t really go to local tech meetups anymore because I don’t feel like I fit in both due to age demographic and the age related comments I get. Usually whenever my age was bought up it was met with shock and awe.</p>
  453. <p>I hated it. I don’t need to be told facts about myself. It didn’t make me feel special or unique, it just made me feel very different and abnormal. Once I had someone harass me for an entire meetup about my age and I ended up going home feeling like shit and crying myself to sleep.</p>
  454. <p>My age was particularly of concern whenever I’d go to the US for work or conferences. The tech industry has a strong drinking culture and not being able to go into bars is very socially isolating. Whenever I go to the US I feel like a child and even get asked at customs why I’m travelling alone.</p>
  455. <p><cite><em><a href="https://medium.com/@sebmck/2015-in-review-51ac7035e272">~2015 in review - Medium</a></em> (<a href="/david/cache/8366ca8b48a7d28c6ed98a090d567052/">cache</a>)</cite></p>
  456. </blockquote>
  457. <p>Le dernier <a href="/david/pro/enseignement/">cours</a> a été l’occasion de faire une restitution d’un travail sur le long terme. Le résultat fut assez terrible principalement car les étudiants ne savaient pas mettre en valeur leurs connaissances. J’essaye toujours de mettre en contexte les évaluations, que ce soit via une <a href="/david/blog/2015/cours-iut-candidature-spontanee/">candidature spontanée</a> ou une <a href="/david/blog/2015/critique-site/">critique de site</a>. Cette fois-ci, il s’agissait de présenter leur travail à une personne rencontrée pendant un événement qui voulait voir de quoi était capable l’étudiant rapidement dans le but de l’embaucher. <strong>Toute ma démarche a été de les pousser du comment scolaire au pourquoi professionnel.</strong> Décrire ce qu’ils ont fait est intuitif pour eux mais prendre du recul et décrire ce qu’ils ont vraiment acquis et comment est-ce qu’il pourraient le mettre en application — voire pourquoi est-ce que c’est une bonne pratique — est beaucoup plus compliqué. Or c’est ce qui me semble pertinent dans un tel contexte.</p>
  458. <p>J’ai du mal à identifier pourquoi est-ce qu’ils arrivent avec un tel manque de confiance en eux à cette étape de leur vie mais c’est vraiment dommageable pour qu’ils réussissent à trouver un emploi s’ils n’arrivent pas à valoriser un minimum ce qu’ils ont appris. Peut-être poussent-ils l’auto-critique et l’humilité trop loin ?</p>
  459. <blockquote>
  460. <p>The reason it’s so difficult to test and improve is that it requires you to acknowledge that your original plan wasn’t perfect. And to have the humility and care to go ahead and fix it.</p>
  461. <p><cite><em><a href="http://sethgodin.typepad.com/seths_blog/2016/01/software-is-testing.html">Software is testing</a></em> (<a href="/david/cache/c0ecb4bba8efbe26c57fa8d0caef4743/">cache</a>)</cite></p>
  462. </blockquote>
  463. <p>Peut-être sont-ils <a href="https://medium.com/@ericclemmons/javascript-fatigue-48d4011b6fc4">fatigués d’avance</a> (<a href="/david/cache/f41d0be1b419e16d37b415958dab7339/">cache</a>) par l’ampleur de la tâche qui les attend ? Ou peut-être que leur formation est trop généraliste ? Je vais essayer de leur faire (re)prendre confiance en eux en <a href="/david/blog/2015/javascript-abstraction/">introduisant JavaScript</a> avec le moins d’abstraction possible.</p>
  464. <p>Karl <a href="http://www.la-grange.net/2016/01/06/sens#idfe0f6c72b2">a réagi depuis</a> :</p>
  465. <blockquote>
  466. <p>La confiance est un autre élément culturel socialement teinté. Cela rejoint la prose de l’article précédent découvert par cet article de David. Il est parfois pour certains individus appropriés de ne pas avoir confiance en soi. Nous pouvons appeler cela de l’humilité, de l’empathie pour les autres ou de la volonté de respect. L’équilibre est difficile. Cela peut également être totalement inconscient et être dû à de nombreuses expériences personnelles. La société des médias, de l’école ainsi que le monde professionnel poussent à la compétition, à la place du premier, aux meilleurs résultats, aux performances. Il est alors peut-être nécessaire de déplacer le terrain de la mesure par rapport aux autres sur celui de la réalisation personnelle.</p>
  467. </blockquote>
  468. </article>
  469. <figure class="image" property="schema:image">
  470. <img src="/static/david/blog/2016/apprentissage-autodepreciation.jpg" alt="" />
  471. </figure>
  472. <nav id="jumpto">
  473. <p>
  474. <a rel=prev href="/david/blog/2016/experience-ecriture/">← Expérience d’écriture</a> | <a href="/david/blog/" title="Retour à la liste des expériences">↑</a> | <a rel=next href="/david/blog/2016/javascript-zero/">JavaScript de zéro →</a>
  475. </p>
  476. </nav>
  477. <footer>
  478. <div>
  479. <img src="/static/david/david-larlet-avatar.jpg" loading="lazy" class="avatar" width="200" height="200">
  480. <p>
  481. Bonjour/Hi!
  482. 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>
  483. 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>).
  484. </p>
  485. <p>
  486. 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>.
  487. </p>
  488. <p>
  489. Les dernières publications hebdomadaires sont :
  490. </p>
  491. <ul class="with_columns">
  492. <li>
  493. <a href="/david/stream/2019/12/31/">Merci</a>
  494. </li>
  495. <li>
  496. <a href="/david/stream/2019/12/27/">Intemporels</a>
  497. </li>
  498. <li>
  499. <a href="/david/stream/2019/12/24/">Outils</a>
  500. </li>
  501. <li>
  502. <a href="/david/stream/2019/12/17/">Origines</a>
  503. </li>
  504. <li>
  505. <a href="/david/stream/2019/12/10/">Publier</a>
  506. </li>
  507. <li>
  508. <a href="/david/stream/2019/12/03/">En forêt</a>
  509. </li>
  510. <li>
  511. <a href="/david/stream/2019/11/26/">Ecocentric</a>
  512. </li>
  513. <li>
  514. <a href="/david/stream/2019/11/19/">Se livrer</a>
  515. </li>
  516. <li>
  517. <a href="/david/stream/2019/11/12/">Dépendances</a>
  518. </li>
  519. <li>
  520. <a href="/david/stream/2019/11/05/">Positif</a>
  521. </li>
  522. <li>
  523. <a href="/david/stream/2019/10/29/">Dettes</a>
  524. </li>
  525. <li>
  526. <a href="/david/stream/2019/10/22/">Privilèges</a>
  527. </li>
  528. <li>
  529. <a href="/david/stream/2019/10/15/">Discrétion</a>
  530. </li>
  531. <li>
  532. <a href="/david/stream/2019/10/08/">Désespérance</a>
  533. </li>
  534. <li>
  535. <a href="/david/stream/2019/10/01/">Présent</a>
  536. </li>
  537. <li>
  538. <a href="/david/stream/2019/09/24/">Manifester</a>
  539. </li>
  540. <li>
  541. <a href="/david/stream/2019/09/17/">Arpenter</a>
  542. </li>
  543. <li>
  544. <a href="/david/stream/2019/09/10/">Nostalgie</a>
  545. </li>
  546. <li>
  547. <a href="/david/stream/2019/09/03/">Déconstruire</a>
  548. </li>
  549. <li>
  550. <a href="/david/stream/2019/08/27/">Documenter</a>
  551. </li>
  552. <li>
  553. <a href="/david/stream/2019/08/20/">Frustration</a>
  554. </li>
  555. <li>
  556. <a href="/david/stream/2019/08/13/">Holisme</a>
  557. </li>
  558. <li>
  559. <a href="/david/stream/2019/08/06/">1%</a>
  560. </li>
  561. <li>
  562. <a href="/david/stream/2019/07/30/">Exemplarité</a>
  563. </li>
  564. <li>
  565. <a href="/david/stream/2019/07/23/">Timelines</a>
  566. </li>
  567. <li>
  568. <a href="/david/stream/2019/07/16/">Écoute</a>
  569. </li>
  570. <li>
  571. <a href="/david/stream/2019/07/02/">Anxiété</a>
  572. </li>
  573. <li>
  574. <a href="/david/stream/2019/06/21/">À lier</a>
  575. </li>
  576. <li>
  577. <a href="/david/stream/2019/06/14/">Pauvreté</a>
  578. </li>
  579. <li>
  580. <a href="/david/stream/2019/06/07/">Amateur</a>
  581. </li>
  582. <li>
  583. <a href="/david/stream/2019/05/31/">Pollution</a>
  584. </li>
  585. <li>
  586. <a href="/david/stream/2019/05/24/">Apaisement</a>
  587. </li>
  588. <li>
  589. <a href="/david/stream/2019/05/10/">Folie</a>
  590. </li>
  591. <li>
  592. <a href="/david/stream/2019/05/03/">Sympathie</a>
  593. </li>
  594. <li>
  595. <a href="/david/stream/2019/04/12/">Péremption</a>
  596. </li>
  597. <li>
  598. <a href="/david/stream/2019/04/05/">Définitions</a>
  599. </li>
  600. <li>
  601. <a href="/david/stream/2019/03/29/">Acceptation</a>
  602. </li>
  603. <li>
  604. <a href="/david/stream/2019/03/22/">Dissonance</a>
  605. </li>
  606. <li>
  607. <a href="/david/stream/2019/03/15/">Reconnaissance</a>
  608. </li>
  609. <li>
  610. <a href="/david/stream/2019/03/08/">Lecture</a>
  611. </li>
  612. <li>
  613. <a href="/david/stream/2019/03/01/">Journaux</a>
  614. </li>
  615. <li>
  616. <a href="/david/stream/2019/02/22/">Écriture</a>
  617. </li>
  618. <li>
  619. <a href="/david/stream/2019/02/15/">Kyriarchie</a>
  620. </li>
  621. <li>
  622. <a href="/david/stream/2019/02/08/">Mots-serrures</a>
  623. </li>
  624. <li>
  625. <a href="/david/stream/2019/02/01/">Sans voie</a>
  626. </li>
  627. <li>
  628. <a href="/david/stream/2019/01/25/">Auto-diagnostic</a>
  629. </li>
  630. <li>
  631. <a href="/david/stream/2019/01/18/">Agilité</a>
  632. </li>
  633. <li>
  634. <a href="/david/stream/2019/01/11/">Métaphores</a>
  635. </li>
  636. <li>
  637. <a href="/david/stream/2019/01/04/">Balbutiements</a>
  638. </li>
  639. </ul>
  640. <p>
  641. Voici quelques articles choisis :
  642. <a href="/david/blog/2019/faire-equipe/" title="Accéder à l’article complet">Faire équipe</a>,
  643. <a href="/david/blog/2018/bivouac-automnal/" title="Accéder à l’article complet">Bivouac automnal</a>,
  644. <a href="/david/blog/2018/commodite-effondrement/" title="Accéder à l’article complet">Commodité et effondrement</a>,
  645. <a href="/david/blog/2017/donnees-communs/" title="Accéder à l’article complet">Des données aux communs</a>,
  646. <a href="/david/blog/2016/accompagner-enfant/" title="Accéder à l’article complet">Accompagner un enfant</a>,
  647. <a href="/david/blog/2016/senior-developer/" title="Accéder à l’article complet">Senior developer</a>,
  648. <a href="/david/blog/2016/illusion-sociale/" title="Accéder à l’article complet">L’illusion sociale</a>,
  649. <a href="/david/blog/2016/instantane-scopyleft/" title="Accéder à l’article complet">Instantané Scopyleft</a>,
  650. <a href="/david/blog/2016/enseigner-web/" title="Accéder à l’article complet">Enseigner le Web</a>,
  651. <a href="/david/blog/2016/simplicite-defaut/" title="Accéder à l’article complet">Simplicité par défaut</a>,
  652. <a href="/david/blog/2016/minimalisme-esthetique/" title="Accéder à l’article complet">Minimalisme et esthétique</a>,
  653. <a href="/david/blog/2014/un-web-omni-present/" title="Accéder à l’article complet">Un web omni-présent</a>,
  654. <a href="/david/blog/2014/manifeste-developpeur/" title="Accéder à l’article complet">Manifeste de développeur</a>,
  655. <a href="/david/blog/2013/confort-convivialite/" title="Accéder à l’article complet">Confort et convivialité</a>,
  656. <a href="/david/blog/2013/testament-numerique/" title="Accéder à l’article complet">Testament numérique</a>,
  657. et <a href="/david/blog/" title="Accéder aux archives">bien d’autres…</a>
  658. </p>
  659. <p>
  660. 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>.
  661. </p>
  662. <p>
  663. Je ne traque pas ta navigation mais mon
  664. <abbr title="Alwaysdata, 62 rue Tiquetonne 75002 Paris, +33.184162340">hébergeur</abbr>
  665. conserve des logs d’accès.
  666. </p>
  667. </div>
  668. </footer>
  669. <script type="text/javascript">
  670. ;(_ => {
  671. const jumper = document.getElementById('jumper')
  672. jumper.addEventListener('click', e => {
  673. e.preventDefault()
  674. const anchor = e.target.getAttribute('href')
  675. const targetEl = document.getElementById(anchor.substring(1))
  676. targetEl.scrollIntoView({behavior: 'smooth'})
  677. })
  678. })()
  679. </script>
  680. <script>
  681. /* Service workers */
  682. if (navigator.serviceWorker) {
  683. window.addEventListener('load', function () {
  684. var selector = 'a[href^="/david/cache/"], a[rel=prev], a[rel=next]'
  685. function sendLinks (selector) {
  686. var links = [].slice.call(document.querySelectorAll(selector)).map(function (link) {
  687. return link.getAttribute('href')
  688. })
  689. links.push(location.pathname) // Put the current page in cache too.
  690. navigator.serviceWorker.controller.postMessage({ links: links })
  691. }
  692. navigator.serviceWorker.getRegistration()
  693. .then(function (registration) {
  694. if (!registration || !navigator.serviceWorker.controller) {
  695. return navigator.serviceWorker.register('/serviceworker.js')
  696. .then(navigator.serviceWorker.ready)
  697. .then(function () {
  698. console.log('[ServiceWorker] Ready to go!')
  699. })
  700. .catch(console.error.bind(console))
  701. } else {
  702. console.log('[ServiceWorker] Send links via registration')
  703. sendLinks(selector)
  704. }
  705. })
  706. navigator.serviceWorker.addEventListener('controllerchange', function () {
  707. console.log('[ServiceWorker] Send links via controller change')
  708. sendLinks(selector)
  709. })
  710. navigator.serviceWorker.addEventListener('message', function (event) {
  711. var link = document.querySelector('a[href="' + event.data.link + '"]')
  712. if (event.data.status && link) {
  713. link.style.backgroundColor = '#2d7474'
  714. link.style.color = '#f0f0ea'
  715. link.setAttribute('title', 'En cache pour consultation sans connexion')
  716. }
  717. })
  718. })
  719. } else {
  720. console.warn('[ServiceWorker] No cache for old browsers.')
  721. }
  722. </script>