diff --git a/.DS_Store b/.DS_Store index 2f5f5a4..7d9ecf7 100644 Binary files a/.DS_Store and b/.DS_Store differ diff --git a/README.md b/README.md index dbed5a4..86f8a3d 100644 --- a/README.md +++ b/README.md @@ -1,3 +1 @@ -2021-07-18 21:24:30 -* 2021-07-18 21:27:02 -* 2021-07-18 21:30:33 \ No newline at end of file +旧的维基系统。Dokuwiki稳定运行以后,这个网站基本可以下架。 \ No newline at end of file diff --git a/_config.yml b/_config.yml index 8cf8353..3550d34 100644 --- a/_config.yml +++ b/_config.yml @@ -29,7 +29,7 @@ admin: # Directory source_dir: source -public_dir: docs # 改为 docs 就可以自动发布 +public_dir: public # 改为 docs 就可以自动发布 tag_dir: tags archive_dir: archives category_dir: categories diff --git a/db.json b/db.json index deee9f4..24c4a7d 100644 --- a/db.json +++ b/db.json @@ -1 +1 @@ -{"meta":{"version":1,"warehouse":"2.2.0"},"models":{"Asset":[{"_id":"themes/Wikitten/source/css/style.styl","path":"css/style.styl","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/js/insight.js","path":"js/insight.js","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/images/mobile2.png","path":"images/mobile2.png","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/js/main.js","path":"js/main.js","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/images/mobile1.png","path":"images/mobile1.png","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/css/images/favicon.ico","path":"css/images/favicon.ico","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/css/images/logo.png","path":"css/images/logo.png","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/css/images/thumb-default-small.png","path":"css/images/thumb-default-small.png","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/fonts/glyphicons-halflings-regular.woff2","path":"libs/fonts/glyphicons-halflings-regular.woff2","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/fonts/glyphicons-halflings-regular.woff","path":"libs/fonts/glyphicons-halflings-regular.woff","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/fonts/glyphicons-halflings-regular.ttf","path":"libs/fonts/glyphicons-halflings-regular.ttf","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/justified-gallery/justifiedGallery.min.css","path":"libs/justified-gallery/justifiedGallery.min.css","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/justified-gallery/jquery.justifiedGallery.min.js","path":"libs/justified-gallery/jquery.justifiedGallery.min.js","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/source-code-pro/styles.css","path":"libs/source-code-pro/styles.css","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/open-sans/styles.css","path":"libs/open-sans/styles.css","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/images/SitePreview.png","path":"images/SitePreview.png","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/uploads/road-to-asset-freedom-mindmap.html","path":"uploads/road-to-asset-freedom-mindmap.html","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/fonts/glyphicons-halflings-regular.eot","path":"libs/fonts/glyphicons-halflings-regular.eot","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/fonts/glyphicons-halflings-regular.svg","path":"libs/fonts/glyphicons-halflings-regular.svg","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/font-awesome/css/font-awesome.css","path":"libs/font-awesome/css/font-awesome.css","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/lightgallery/css/lg-fb-comment-box.css","path":"libs/lightgallery/css/lg-fb-comment-box.css","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/font-awesome/css/font-awesome.min.css","path":"libs/font-awesome/css/font-awesome.min.css","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/lightgallery/css/lg-fb-comment-box.css.map","path":"libs/lightgallery/css/lg-fb-comment-box.css.map","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/lightgallery/css/lg-fb-comment-box.min.css","path":"libs/lightgallery/css/lg-fb-comment-box.min.css","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/lightgallery/css/lg-transitions.css","path":"libs/lightgallery/css/lg-transitions.css","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/lightgallery/css/lg-transitions.css.map","path":"libs/lightgallery/css/lg-transitions.css.map","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/lightgallery/css/lg-transitions.min.css","path":"libs/lightgallery/css/lg-transitions.min.css","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/lightgallery/css/lightgallery.css","path":"libs/lightgallery/css/lightgallery.css","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/lightgallery/css/lightgallery.css.map","path":"libs/lightgallery/css/lightgallery.css.map","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/lightgallery/css/lightgallery.min.css","path":"libs/lightgallery/css/lightgallery.min.css","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/lightgallery/fonts/lg.eot","path":"libs/lightgallery/fonts/lg.eot","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/lightgallery/fonts/lg.svg","path":"libs/lightgallery/fonts/lg.svg","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/lightgallery/fonts/lg.woff","path":"libs/lightgallery/fonts/lg.woff","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/lightgallery/js/lg-autoplay.js","path":"libs/lightgallery/js/lg-autoplay.js","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/lightgallery/fonts/lg.ttf","path":"libs/lightgallery/fonts/lg.ttf","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/lightgallery/js/lg-autoplay.min.js","path":"libs/lightgallery/js/lg-autoplay.min.js","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/lightgallery/js/lg-fullscreen.js","path":"libs/lightgallery/js/lg-fullscreen.js","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/lightgallery/js/lg-fullscreen.min.js","path":"libs/lightgallery/js/lg-fullscreen.min.js","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/lightgallery/js/lg-hash.js","path":"libs/lightgallery/js/lg-hash.js","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/lightgallery/js/lg-hash.min.js","path":"libs/lightgallery/js/lg-hash.min.js","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/lightgallery/js/lg-pager.js","path":"libs/lightgallery/js/lg-pager.js","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/lightgallery/js/lg-pager.min.js","path":"libs/lightgallery/js/lg-pager.min.js","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/lightgallery/js/lg-share.js","path":"libs/lightgallery/js/lg-share.js","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/lightgallery/js/lg-share.min.js","path":"libs/lightgallery/js/lg-share.min.js","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/lightgallery/js/lg-thumbnail.js","path":"libs/lightgallery/js/lg-thumbnail.js","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/lightgallery/js/lg-thumbnail.min.js","path":"libs/lightgallery/js/lg-thumbnail.min.js","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/lightgallery/js/lg-video.js","path":"libs/lightgallery/js/lg-video.js","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/lightgallery/js/lg-video.min.js","path":"libs/lightgallery/js/lg-video.min.js","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/lightgallery/js/lg-zoom.js","path":"libs/lightgallery/js/lg-zoom.js","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/lightgallery/js/lg-zoom.min.js","path":"libs/lightgallery/js/lg-zoom.min.js","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/lightgallery/js/lightgallery.js","path":"libs/lightgallery/js/lightgallery.js","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/lightgallery/js/lightgallery.min.js","path":"libs/lightgallery/js/lightgallery.min.js","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/lightgallery/img/loading.gif","path":"libs/lightgallery/img/loading.gif","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/lightgallery/img/video-play.png","path":"libs/lightgallery/img/video-play.png","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/lightgallery/img/vimeo-play.png","path":"libs/lightgallery/img/vimeo-play.png","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/lightgallery/img/youtube-play.png","path":"libs/lightgallery/img/youtube-play.png","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/59ZRklaO5bWGqF5A9baEERJtnKITppOI_IvcXXDNrsc.woff2","path":"libs/open-sans/fonts/59ZRklaO5bWGqF5A9baEERJtnKITppOI_IvcXXDNrsc.woff2","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/K88pR3goAWT7BTt32Z01mxJtnKITppOI_IvcXXDNrsc.woff2","path":"libs/open-sans/fonts/K88pR3goAWT7BTt32Z01mxJtnKITppOI_IvcXXDNrsc.woff2","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/LWCjsQkB6EMdfHrEVqA1KRJtnKITppOI_IvcXXDNrsc.woff2","path":"libs/open-sans/fonts/LWCjsQkB6EMdfHrEVqA1KRJtnKITppOI_IvcXXDNrsc.woff2","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/MTP_ySUJH_bn48VBG8sNShWV49_lSm1NYrwo-zkhivY.woff2","path":"libs/open-sans/fonts/MTP_ySUJH_bn48VBG8sNShWV49_lSm1NYrwo-zkhivY.woff2","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/MTP_ySUJH_bn48VBG8sNSj0LW-43aMEzIO6XUTLjad8.woff2","path":"libs/open-sans/fonts/MTP_ySUJH_bn48VBG8sNSj0LW-43aMEzIO6XUTLjad8.woff2","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/MTP_ySUJH_bn48VBG8sNSpX5f-9o1vgP2EXwfjgl7AY.woff2","path":"libs/open-sans/fonts/MTP_ySUJH_bn48VBG8sNSpX5f-9o1vgP2EXwfjgl7AY.woff2","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/MTP_ySUJH_bn48VBG8sNSq-j2U0lmluP9RWlSytm3ho.woff2","path":"libs/open-sans/fonts/MTP_ySUJH_bn48VBG8sNSq-j2U0lmluP9RWlSytm3ho.woff2","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/MTP_ySUJH_bn48VBG8sNSqaRobkAwv3vxw3jMhVENGA.woff2","path":"libs/open-sans/fonts/MTP_ySUJH_bn48VBG8sNSqaRobkAwv3vxw3jMhVENGA.woff2","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/MTP_ySUJH_bn48VBG8sNSugdm0LZdjqr5-oayXSOefg.woff2","path":"libs/open-sans/fonts/MTP_ySUJH_bn48VBG8sNSugdm0LZdjqr5-oayXSOefg.woff2","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/MTP_ySUJH_bn48VBG8sNSv8zf_FOSsgRmwsS7Aa9k2w.woff2","path":"libs/open-sans/fonts/MTP_ySUJH_bn48VBG8sNSv8zf_FOSsgRmwsS7Aa9k2w.woff2","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/RjgO7rYTmqiVp7vzi-Q5URJtnKITppOI_IvcXXDNrsc.woff2","path":"libs/open-sans/fonts/RjgO7rYTmqiVp7vzi-Q5URJtnKITppOI_IvcXXDNrsc.woff2","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/cJZKeOuBrn4kERxqtaUH3VtXRa8TVwTICgirnJhmVJw.woff2","path":"libs/open-sans/fonts/cJZKeOuBrn4kERxqtaUH3VtXRa8TVwTICgirnJhmVJw.woff2","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/u-WUoqrET9fUeobQW7jkRRJtnKITppOI_IvcXXDNrsc.woff2","path":"libs/open-sans/fonts/u-WUoqrET9fUeobQW7jkRRJtnKITppOI_IvcXXDNrsc.woff2","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/xjAJXh38I15wypJXxuGMBiYE0-AqJ3nfInTTiDXDjU4.woff2","path":"libs/open-sans/fonts/xjAJXh38I15wypJXxuGMBiYE0-AqJ3nfInTTiDXDjU4.woff2","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/xjAJXh38I15wypJXxuGMBjTOQ_MqJVwkKsUn0wKzc2I.woff2","path":"libs/open-sans/fonts/xjAJXh38I15wypJXxuGMBjTOQ_MqJVwkKsUn0wKzc2I.woff2","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/xjAJXh38I15wypJXxuGMBjUj_cnvWIuuBMVgbX098Mw.woff2","path":"libs/open-sans/fonts/xjAJXh38I15wypJXxuGMBjUj_cnvWIuuBMVgbX098Mw.woff2","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/xjAJXh38I15wypJXxuGMBkbcKLIaa1LC45dFaAfauRA.woff2","path":"libs/open-sans/fonts/xjAJXh38I15wypJXxuGMBkbcKLIaa1LC45dFaAfauRA.woff2","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/xjAJXh38I15wypJXxuGMBmo_sUJ8uO4YLWRInS22T3Y.woff2","path":"libs/open-sans/fonts/xjAJXh38I15wypJXxuGMBmo_sUJ8uO4YLWRInS22T3Y.woff2","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/xjAJXh38I15wypJXxuGMBo4P5ICox8Kq3LLUNMylGO4.woff2","path":"libs/open-sans/fonts/xjAJXh38I15wypJXxuGMBo4P5ICox8Kq3LLUNMylGO4.woff2","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/xjAJXh38I15wypJXxuGMBr6up8jxqWt8HVA3mDhkV_0.woff2","path":"libs/open-sans/fonts/xjAJXh38I15wypJXxuGMBr6up8jxqWt8HVA3mDhkV_0.woff2","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/xozscpT2726on7jbcb_pAhJtnKITppOI_IvcXXDNrsc.woff2","path":"libs/open-sans/fonts/xozscpT2726on7jbcb_pAhJtnKITppOI_IvcXXDNrsc.woff2","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/source-code-pro/fonts/mrl8jkM18OlOQN8JLgasD9V_2ngZ8dMf8fLgjYEouxg.woff2","path":"libs/source-code-pro/fonts/mrl8jkM18OlOQN8JLgasD9V_2ngZ8dMf8fLgjYEouxg.woff2","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/source-code-pro/fonts/mrl8jkM18OlOQN8JLgasDy2Q8seG17bfDXYR_jUsrzg.woff2","path":"libs/source-code-pro/fonts/mrl8jkM18OlOQN8JLgasDy2Q8seG17bfDXYR_jUsrzg.woff2","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/font-awesome/fonts/fontawesome-webfont.woff","path":"libs/font-awesome/fonts/fontawesome-webfont.woff","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/font-awesome/fonts/fontawesome-webfont.woff2","path":"libs/font-awesome/fonts/fontawesome-webfont.woff2","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/font-awesome/fonts/FontAwesome.otf","path":"libs/font-awesome/fonts/FontAwesome.otf","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/font-awesome/fonts/fontawesome-webfont.eot","path":"libs/font-awesome/fonts/fontawesome-webfont.eot","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/font-awesome/fonts/fontawesome-webfont.ttf","path":"libs/font-awesome/fonts/fontawesome-webfont.ttf","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/jquery/2.1.3/jquery.min.js","path":"libs/jquery/2.1.3/jquery.min.js","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/jquery/plugins/cookie/1.4.1/jquery.cookie.js","path":"libs/jquery/plugins/cookie/1.4.1/jquery.cookie.js","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/font-awesome/fonts/fontawesome-webfont.svg","path":"libs/font-awesome/fonts/fontawesome-webfont.svg","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/uploads/tianya.png","path":"uploads/tianya.png","modified":0,"renderable":1}],"Cache":[{"_id":"S_Store","hash":"a9cabec0ae931e7048f423a95c704c714780b5e1","modified":1588882647870},{"_id":"themes/Wikitten/LICENSE","hash":"feadcd728a8e828cfc507b4586d7a7ab94b66fe8","modified":1563743114000},{"_id":"themes/Wikitten/.DS_Store","hash":"df2fbeb1400acda0909a32c1cf6bf492f1121e07","modified":1565719634000},{"_id":"themes/Wikitten/README.md","hash":"8c9fc9b9ebdf37c9289a4e1d72ac8aedbe23316c","modified":1563743114000},{"_id":"themes/Wikitten/README_zh-CN.md","hash":"8a4e600ff1f75007df8facf15a9c127aafec5e18","modified":1563743114000},{"_id":"themes/Wikitten/_config.yml","hash":"c9bfc67c810f7a79227daad8af59f57b6ef020b3","modified":1588912541465},{"_id":"themes/Wikitten/package.json","hash":"2b308f996333d1d9def3e536dbf302afcdd8e1f0","modified":1563743114000},{"_id":"arkeditor/file_manager_status.config","hash":"c750fd1fe3f1407005c5d2b5d7b7f9bca54970c3","modified":1564688931000},{"_id":"arkeditor/file_manager_width.config","hash":"2c427b959b7a35c68831d16645d2afde8cb67ddd","modified":1564594162000},{"_id":"rafts/.DS_Store","hash":"df2fbeb1400acda0909a32c1cf6bf492f1121e07","modified":1565728063000},{"_id":"rafts/典故-md.md","hash":"2b33e03ac046894df112a9d45da13a690f621ed2","modified":1563856606000},{"_id":"osts/.DS_Store","hash":"6f8ff578f75eaeb17eeb676dc7e41d9fe37fa6af","modified":1588882832887},{"_id":"out/.DS_Store","hash":"df2fbeb1400acda0909a32c1cf6bf492f1121e07","modified":1565728063000},{"_id":"out/index.md","hash":"282d4c506b467c746d1154f25338d16be6abbb62","modified":1563816667000},{"_id":"tegories/.DS_Store","hash":"df2fbeb1400acda0909a32c1cf6bf492f1121e07","modified":1565728063000},{"_id":"tegories/index.md","hash":"53bbe27e36d98a4a55fdce6a7fd9cac3e6671439","modified":1563766746000},{"_id":"gs/.DS_Store","hash":"df2fbeb1400acda0909a32c1cf6bf492f1121e07","modified":1565728063000},{"_id":"gs/index.md","hash":"163f9d816dac6cc50a48347bf7f93f29fa503736","modified":1563766671000},{"_id":"themes/Wikitten/_scaffolds/embed.md","hash":"0830c3a5b134fbd21a6ddeda141a4de8345cabb1","modified":1563743114000},{"_id":"themes/Wikitten/_scaffolds/post.md","hash":"af892af6f7dafdd617c5aa17ee91e9e445d20fa4","modified":1563743114000},{"_id":"themes/Wikitten/languages/en.yml","hash":"ade241498b85503a8953a1deca963222f47067a7","modified":1563743114000},{"_id":"themes/Wikitten/languages/es.yml","hash":"d7432219be5bee4cb569331378ade61b749688e0","modified":1563743114000},{"_id":"themes/Wikitten/languages/fr.yml","hash":"cb3e597cbec7e8f458858c457bafd1f3a225083d","modified":1563743114000},{"_id":"themes/Wikitten/languages/id.yml","hash":"70ec9ab2ac04cf882e81377ca5ad15bf8adceca8","modified":1563743114000},{"_id":"themes/Wikitten/languages/ja.yml","hash":"ff972961e5f468a695d80d21b62c3e9032cdf561","modified":1563743114000},{"_id":"themes/Wikitten/languages/ko.yml","hash":"7c4ad4577dc0577ad2ca1c0410507f5e5fadf530","modified":1563743114000},{"_id":"themes/Wikitten/languages/pt-BR.yml","hash":"3c5d5293575593705b9a2dfa9d97b017eb4bc8c3","modified":1563743114000},{"_id":"themes/Wikitten/_source/.DS_Store","hash":"df2fbeb1400acda0909a32c1cf6bf492f1121e07","modified":1588912619614},{"_id":"themes/Wikitten/languages/ru.yml","hash":"d1aab2b0c939d0c6020f881d664b660a01ee7327","modified":1563743114000},{"_id":"themes/Wikitten/languages/tr.yml","hash":"8b7eb6aec264db50dbabea89f680acca256f4cd1","modified":1563743114000},{"_id":"themes/Wikitten/languages/zh-Hans.yml","hash":"3dc8ec524805afd090438be717908750da439204","modified":1563743114000},{"_id":"themes/Wikitten/languages/zh-TW.yml","hash":"d8d96a0a17c20af11919ce036e87379a6b163db9","modified":1563743114000},{"_id":"themes/Wikitten/layout/archive.ejs","hash":"34180dcc26b8fcc59f8644ce506aadf7db5f07e5","modified":1563743114000},{"_id":"themes/Wikitten/layout/categories.ejs","hash":"aa95629b770cff8cca9d663aeb6b17928f070de5","modified":1563743114000},{"_id":"themes/Wikitten/layout/category.ejs","hash":"1d407f9176db84e83062c52ad4755aaea9e74401","modified":1563743114000},{"_id":"themes/Wikitten/layout/embed.ejs","hash":"9e4e14d7adf20225e26d3943bdae8d08cf2d0d8b","modified":1563743114000},{"_id":"themes/Wikitten/layout/page.ejs","hash":"50170783bac99946ae8af483920568de9b2d9801","modified":1563743114000},{"_id":"themes/Wikitten/layout/index.ejs","hash":"abda4978fe246ec7f2a240e591d5caaea6de327c","modified":1588913059866},{"_id":"themes/Wikitten/layout/layout.ejs","hash":"b81b084839a6944c99cceedf743422aea4d856fa","modified":1589039520929},{"_id":"themes/Wikitten/layout/post.ejs","hash":"50170783bac99946ae8af483920568de9b2d9801","modified":1563743114000},{"_id":"themes/Wikitten/layout/tag.ejs","hash":"f6c220d4e5c231028bc71ddc11aec97d7b5a9943","modified":1563743114000},{"_id":"themes/Wikitten/layout/tags.ejs","hash":"b0fcea68d7c11e5899bf0375d80997685111653f","modified":1563743114000},{"_id":"themes/Wikitten/scripts/fold.js","hash":"2c8cfa7dac0b2665db9c148882f18a11d7d78957","modified":1563907083000},{"_id":"themes/Wikitten/scripts/.DS_Store","hash":"df2fbeb1400acda0909a32c1cf6bf492f1121e07","modified":1563908768000},{"_id":"themes/Wikitten/scripts/meta.js","hash":"1993754a2f3dffa283fa0538eb8f056385b69ad4","modified":1563743114000},{"_id":"themes/Wikitten/scripts/tags.js","hash":"259bc8f40e9f8eb457c1bdc99744b34d1e8602e8","modified":1563907013000},{"_id":"themes/Wikitten/scripts/thumbnail.js","hash":"e667a611f9baac270281b765832020d50bf8fb7f","modified":1563743114000},{"_id":"themes/Wikitten/source/.DS_Store","hash":"df2fbeb1400acda0909a32c1cf6bf492f1121e07","modified":1581539379000},{"_id":"osts/.markeditor/file_manager_status.config","hash":"26ccad3385b35b5dd4b33232ba36d0da4f190c00","modified":1588848849111},{"_id":"osts/IT/.DS_Store","hash":"f31c5797d3b40ff7f36965331428bf17084dc289","modified":1565813210000},{"_id":"osts/.markeditor/file_manager_width.config","hash":"2c427b959b7a35c68831d16645d2afde8cb67ddd","modified":1588848807781},{"_id":"osts/常用文件/.DS_Store","hash":"df2fbeb1400acda0909a32c1cf6bf492f1121e07","modified":1565728063000},{"_id":"osts/常用文件/Hexo日常管理.md","hash":"48184f3ce76a6679a525e3349ec30ae4608ac5ec","modified":1564718092000},{"_id":"osts/摘录/.DS_Store","hash":"df2fbeb1400acda0909a32c1cf6bf492f1121e07","modified":1565728063000},{"_id":"osts/摘录/《驴得水》影评.md","hash":"dcd7ea1a8643fe06ff14022c5d5577ccf810a33c","modified":1565905736000},{"_id":"osts/摘录/典故.md","hash":"bd9982cfe6eea388c4f99b79d479939974cf0d1e","modified":1564545095000},{"_id":"osts/摘录/爱乐之城——影评.md","hash":"dd74130851f4565e9a4ae2d8b1218e4b74fb9672","modified":1565764310000},{"_id":"osts/文档/RZF-Organisation.md","hash":"37c4c97661f0ac8203e1b0c4f7f1df70dfe2c4a1","modified":1566463161000},{"_id":"osts/读书笔记/.DS_Store","hash":"df2fbeb1400acda0909a32c1cf6bf492f1121e07","modified":1565728063000},{"_id":"osts/读书笔记/《少有人走的路》笔记.md","hash":"5a6ce1a62ddca691e7aa49658a6a1ea8cd8215e3","modified":1564632258000},{"_id":"osts/读书笔记/斯多葛主义手册.md","hash":"a56ce651794cbedea74361202e9f1868a0b10f61","modified":1565764288000},{"_id":"osts/读书笔记/财富自由之路-李笑来.md","hash":"0f1bb3b57fb1b23e38984f0343c31431c0592ab8","modified":1565764569000},{"_id":"osts/随笔/.DS_Store","hash":"df2fbeb1400acda0909a32c1cf6bf492f1121e07","modified":1565728063000},{"_id":"osts/随笔/hello-world.md","hash":"5c562e2b6c5184f490c0ea1b6d820fe50579406b","modified":1564545095000},{"_id":"themes/Wikitten/_source/about/index.md","hash":"3b3e8701e1e68d422641c456dc808bb4a665720c","modified":1563745735000},{"_id":"themes/Wikitten/_source/categories/index.md","hash":"994c1641a9b4b9ef0c604c197dffb6b0ce0513a0","modified":1563745700000},{"_id":"themes/Wikitten/_source/tags/index.md","hash":"b5cea9db4620416c871ea1b14b7eddf23b330779","modified":1563745653000},{"_id":"themes/Wikitten/layout/comment/counter.ejs","hash":"e109d3256b004b027d029bd5bd67feeb72dc5388","modified":1563743114000},{"_id":"themes/Wikitten/layout/comment/disqus.ejs","hash":"1b32a90f400dc580f4b8298de75b94429ca6de68","modified":1563743114000},{"_id":"themes/Wikitten/layout/comment/duoshuo.ejs","hash":"ce46d7410a99b57704da32e9d09071cef6c9fa93","modified":1563743114000},{"_id":"themes/Wikitten/layout/comment/index.ejs","hash":"f0f00cce7a5c37f00dbc4acf49529bdd6a6bdc5d","modified":1563743114000},{"_id":"themes/Wikitten/layout/comment/scripts.ejs","hash":"8a9a20f72ba0923afa776396fb67d8c5d446a666","modified":1563743114000},{"_id":"themes/Wikitten/layout/comment/youyan.ejs","hash":"6fe807992832939caf6c3e7651d052df9520d88e","modified":1563743114000},{"_id":"themes/Wikitten/layout/common/article.ejs","hash":"595a086a42a156dd44d30ee7f9e7189ca370bcf1","modified":1563743114000},{"_id":"themes/Wikitten/layout/common/footer.ejs","hash":"2e5c72b780ac21462976108aec769a215d2f1f45","modified":1563812254000},{"_id":"themes/Wikitten/layout/common/head.ejs","hash":"5f2df8713f0ef723b3bfc79ae580fe8707ea2036","modified":1563743114000},{"_id":"themes/Wikitten/layout/common/header.ejs","hash":"738c6a923b2a6de6a81c4892c8a47e03d8b34f88","modified":1563743114000},{"_id":"themes/Wikitten/layout/common/iframe.ejs","hash":"c3a8e71e1660d58b6ed106a045c6829e77e65881","modified":1563743114000},{"_id":"themes/Wikitten/layout/common/profile.ejs","hash":"0d5a9622d490652599e3ba3e4077a7d6bb2eb38e","modified":1563743114000},{"_id":"themes/Wikitten/layout/common/scripts.ejs","hash":"c0a1a9e53f89440c42c325d5bd8c7234652c8937","modified":1563743114000},{"_id":"themes/Wikitten/layout/common/sidebar.ejs","hash":"6e80fa52d23c9c39bfa357a1e00c26fc8b851b82","modified":1563743114000},{"_id":"themes/Wikitten/layout/common/thumbnail.ejs","hash":"1b70f8a98cd8650b159bda858dbee38dbdb7f0c5","modified":1563743114000},{"_id":"themes/Wikitten/layout/common/timeline.ejs","hash":"6420e34e0332c9b6670011519f341340db989343","modified":1563743114000},{"_id":"themes/Wikitten/layout/plugin/google-analytics.ejs","hash":"349f08b6521a16e79046b1f94f04317ac74f556e","modified":1563743114000},{"_id":"themes/Wikitten/layout/plugin/scripts.ejs","hash":"6e410c120dabac0dccbd8b0c312f261c9566cacb","modified":1563743114000},{"_id":"themes/Wikitten/layout/plugin/baidu-analytics.ejs","hash":"6a7bee18e666e627e62541a5e30906f87ba1bfe8","modified":1563743114000},{"_id":"themes/Wikitten/layout/plugin/mathjax.ejs","hash":"aa644e12c338cd595ae53c37c89b974fa4364966","modified":1588882392716},{"_id":"themes/Wikitten/layout/search/baidu.ejs","hash":"3e603a702d20c53fd3bcbeb570a16a86d54781ce","modified":1563743114000},{"_id":"themes/Wikitten/layout/search/index-mobile.ejs","hash":"50a727ac1dfe3073eb6fa6699ba01e66f4ac41c0","modified":1563743114000},{"_id":"themes/Wikitten/layout/search/index.ejs","hash":"24935e32e61d4706454b174ea3bed0726ae7fb34","modified":1563743114000},{"_id":"themes/Wikitten/layout/search/insight.ejs","hash":"130fe3d33ac71da0b50f7fee6a87979f30938a1b","modified":1563743114000},{"_id":"themes/Wikitten/layout/search/swiftype.ejs","hash":"379e66d2c13526e72e4120c443f95fccf4edef71","modified":1563743114000},{"_id":"themes/Wikitten/layout/share/addtoany.ejs","hash":"ac180c4c84b73a04d61b17e7dc18c257e20bf59f","modified":1563743114000},{"_id":"themes/Wikitten/layout/share/bdshare.ejs","hash":"a1e772c5a6f174d585b0c1e574058f75dc8e2898","modified":1563743114000},{"_id":"themes/Wikitten/layout/share/default.ejs","hash":"ebfb919dc525b3ed61a6a5ee05ee71410eedc541","modified":1563743114000},{"_id":"themes/Wikitten/layout/share/index.ejs","hash":"2a2c0095b95b11e5692bd8ad6a2337aa644189a2","modified":1563743114000},{"_id":"themes/Wikitten/layout/share/jiathis.ejs","hash":"21ebaa51e828cba2cefbeeaccb01514643565755","modified":1563743114000},{"_id":"themes/Wikitten/layout/widget/archive.ejs","hash":"91a4675876990c12bd252f00e13894e0e7e5e50a","modified":1563743114000},{"_id":"themes/Wikitten/layout/widget/category.ejs","hash":"d09317d5e328a9c6ff8fded93604ebe04764cc4c","modified":1563743114000},{"_id":"themes/Wikitten/layout/widget/links.ejs","hash":"0f58cafed5156488f550df6d560814f835a46854","modified":1563743114000},{"_id":"themes/Wikitten/layout/widget/recent_posts.ejs","hash":"dc83051ae67cfae0db0a6d9790c923ff2883ee25","modified":1563743114000},{"_id":"themes/Wikitten/layout/widget/tag.ejs","hash":"5d70b1bf3b1fc977135e458f9a50cb65cff91f17","modified":1563743114000},{"_id":"themes/Wikitten/layout/widget/tagcloud.ejs","hash":"73638a7c91c6d6433e766b35199508719bf27d19","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_extend.styl","hash":"9a5c72663c0da1b32ecb6a75773a5ccfb8c467ca","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_variables.styl","hash":"2eba1250b39115da9f32e8a70d271e04186419c0","modified":1563743114000},{"_id":"themes/Wikitten/source/css/style.styl","hash":"d37d6c7754805c60564c0d9a50b7b058e7f830c9","modified":1563743114000},{"_id":"themes/Wikitten/source/js/insight.js","hash":"c9dfd20ae82a446facad01439b7bb75332e3705b","modified":1563743114000},{"_id":"themes/Wikitten/source/images/mobile2.png","hash":"ba9a7a5464369c4272f6345ef879b5d1c2449de1","modified":1563743114000},{"_id":"themes/Wikitten/source/js/main.js","hash":"d1ab55b8f28037dab5512c40d33553fac966dc39","modified":1563908857000},{"_id":"themes/Wikitten/source/uploads/.DS_Store","hash":"df2fbeb1400acda0909a32c1cf6bf492f1121e07","modified":1563652057000},{"_id":"themes/Wikitten/source/images/mobile1.png","hash":"db83e3ffbf60ff88443cd3b9d1c23666005e88f0","modified":1563743114000},{"_id":"osts/IT/Code/Javascript技术摘要.md","hash":"e949fc3ccd48cfba5e3064c7b39ed5f523553d86","modified":1568660025000},{"_id":"osts/IT/Mac/.DS_Store","hash":"df2fbeb1400acda0909a32c1cf6bf492f1121e07","modified":1588882793782},{"_id":"osts/IT/Mac/Mac使用标签.md","hash":"c28b4fa4701f08fcfe5942ec8f151d7cfd2f8dad","modified":1564545094000},{"_id":"osts/IT/Tools/Gitbook攻略.md","hash":"c78d9b403444239f353b6a4a6ce0f97e6ad0fcd7","modified":1565862378000},{"_id":"osts/IT/Mac/Mac备忘录.md","hash":"5d7fb8ad7a1a59b6dd65df8a6eae0d8cb7b18fd5","modified":1588836517649},{"_id":"osts/IT/Tools/Ubuntu重设root用户密码.md","hash":"b7323a3ac81d57b3c489d97c7da56a991883089f","modified":1565764467000},{"_id":"osts/IT/Tools/使用Github维护知识库.md","hash":"27bf57527ac1d9061b1733540ac9f0b383a8a35f","modified":1565862053000},{"_id":"osts/IT/Tools/坚果云有关.md","hash":"1a966cbc37318b34551bf17be4bccfc16761fa7f","modified":1565820630000},{"_id":"osts/IT/Tools/编辑器工具使用技巧汇总.md","hash":"8103dd1e47e61523c797cf86e82bb26517f54b12","modified":1567357907000},{"_id":"osts/IT/Tools/配置服务器端MySQL.md","hash":"d44b85906db5816259dc4b2128dcac8a0766b447","modified":1565788245000},{"_id":"osts/IT/Web/Next主题添加内容折叠.md","hash":"0c381c884e0c77af522fdbf958536f2c217ceb1b","modified":1564545094000},{"_id":"osts/IT/Web/同步Hexo文章与Mac上原笔记的分类和标签.md","hash":"3af3acc8ed642c8c74ad89b87ee0e98bf0db9865","modified":1564837106000},{"_id":"osts/IT/Web/如何系统化管理Hexo博客.md","hash":"06aeeeb674ebf91cc550732fd7c5f5f30413e791","modified":1565905917000},{"_id":"osts/IT/Tools/有用的shell命令.md","hash":"1e3bffca5cac009d0f91cbd6bb96206076e50cae","modified":1565788356000},{"_id":"osts/IT/skill/用Typescript编写JS函数库.md","hash":"b189a07241dcd4bc6388fb40f92d1ec9b9835669","modified":1566646240000},{"_id":"osts/IT/Web/搭建Hexo博客的流水账.md","hash":"2bc4bf601a7c03ca17acf56806bd8aaf1b2e6f5c","modified":1565865865000},{"_id":"osts/IT/skill/还在用七牛.md","hash":"ee7b98bee940ef09c06ffcdc967b41af8d0752b1","modified":1565852093000},{"_id":"osts/摘录/片段/佛偈集合.md","hash":"fcc94a0d1fbabbd9ff5cc9a607bc07dec6b9fb8b","modified":1565905574000},{"_id":"osts/摘录/片段/名人语录.md","hash":"3c9d34d4393d3276a3ab8ad82ccabc6b3155f39f","modified":1564545095000},{"_id":"osts/摘录/娱乐/搞笑段子.md","hash":"a13e48400bba8b3427b7ac080073ec19fa20bc93","modified":1564545095000},{"_id":"osts/摘录/片段/简短书摘.md","hash":"a2586fd508f831d1631fbc0925c39288ffd23692","modified":1564545095000},{"_id":"osts/IT/skill/MathJax用于易学领域.md","hash":"a199fc359afe19f5ec89c2069defd27990b742f9","modified":1588930688489},{"_id":"osts/摘录/片段/零散句子.md","hash":"c6100208f88c30d1910c03d472cc96e53320c996","modified":1564942528000},{"_id":"osts/摘录/片段/缠中说禅.md","hash":"57bc98bc30aff6804eebbe9b5300af1f673973a3","modified":1564545095000},{"_id":"themes/Wikitten/layout/common/post/banner.ejs","hash":"47ced3f03525698c79c6b1c07b48383fb6c496b2","modified":1563743114000},{"_id":"themes/Wikitten/layout/common/post/category.ejs","hash":"75c9dda2e7ec041943855ca163a6b1c4c8b4f260","modified":1563743114000},{"_id":"themes/Wikitten/layout/common/post/date.ejs","hash":"45cb0bcad461036cdd1fe2e3fbb5f2f19940025c","modified":1563743114000},{"_id":"themes/Wikitten/layout/common/post/gallery.ejs","hash":"659f019761116313169148ec61773e7b84abb739","modified":1563743114000},{"_id":"themes/Wikitten/layout/common/post/nav.ejs","hash":"d7cd611e642327f33dff3963ef869c2b46824a11","modified":1563743114000},{"_id":"themes/Wikitten/layout/common/post/tag.ejs","hash":"2e966216256321aa0c76fe1b9be689601c76ef31","modified":1563743114000},{"_id":"themes/Wikitten/layout/common/post/title.ejs","hash":"669ddb46fefa100856588351a7a2d30ad996b755","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/agate.styl","hash":"601eb70448a16b918df132f6fc41e891ae053653","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/androidstudio.styl","hash":"65d09f1b0e81c6a182f549fd3de51e59823c97ae","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/arduino-light.styl","hash":"15e8572585cd708221c513dea4bdd89d8fe56c10","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/arta.styl","hash":"1a5accc115f41d1b669ed708ac6a29abac876599","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/ascetic.styl","hash":"32cff3bef6fac3760fe78f203096477052a90552","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/atelier-cave-dark.styl","hash":"bc647b2c1d971d7cc947aa1ed66e9fd115261921","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/atelier-cave-light.styl","hash":"a5be0744a7ecf4a08f600ade4cfd555afc67bc15","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/atelier-dune-dark.styl","hash":"df50a85a4b14c7ca6e825d665594b91229d0e460","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/atelier-dune-light.styl","hash":"931435fbc6f974e8ce9e32722680035d248a9dc1","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/atelier-estuary-dark.styl","hash":"d84382bc8298f96730757391d3e761b7e640f406","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/atelier-estuary-light.styl","hash":"344276ca9b27e51d4c907f76afe5d13cf8e60bdf","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/atelier-forest-dark.styl","hash":"57c154c6045a038dc7df0a25927853e10bf48c4a","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/atelier-forest-light.styl","hash":"95228d9f2102fad425536aac44b80b2cba1f5950","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/atelier-heath-dark.styl","hash":"b0cf13b2233e7bc38342032d2d7296591a4c2bcf","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/atelier-lakeside-dark.styl","hash":"bb0a8c4ad0dd8e3e7de7122ddf268fc42aa94acb","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/atelier-lakeside-light.styl","hash":"2c54cb9bdb259ae3b5b29f63ac2469ed34b08578","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/atelier-heath-light.styl","hash":"8c8c2e445abef85273be966d59770e9ced6aac21","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/atelier-plateau-dark.styl","hash":"09c64f1a7052aec9070c36c0431df25216afaea1","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/atelier-plateau-light.styl","hash":"d1a05fdd1ededc9063d181ab25bad55a164aeb4a","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/atelier-savanna-dark.styl","hash":"a16c919a1ccf2f845488078fb341381bec46b1f3","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/atelier-savanna-light.styl","hash":"f8244c93711c7cb59dd79d2df966806b30d171ea","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/atelier-seaside-dark.styl","hash":"ce233a101daea7124cbfcd34add43ccfe2e1e1c7","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/atelier-seaside-light.styl","hash":"0597342da6e2d0c5bdcc7d42dabb07322b1a4177","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/atelier-sulphurpool-dark.styl","hash":"414b0cfc142f70afe359c16450b651e28bf7325a","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/atelier-sulphurpool-light.styl","hash":"efa52713efc468abeeb2b9299704371583b857de","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/brown-paper.styl","hash":"c2326ba20a5020a66ca7895258d18833327d4334","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/brown-papersq.png","hash":"3a1332ede3a75a3d24f60b6ed69035b72da5e182","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/color-brewer.styl","hash":"2a439d6214430e2f45dd4939b4dfe1fe1a20aa0f","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/dark.styl","hash":"71ce56d311cc2f3a605f6e2c495ccd7236878404","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/codepen-embed.styl","hash":"f4dcc84d8e39f9831a5efe80e51923fc3054feb0","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/docco.styl","hash":"b1c176378bb275f2e8caa759f36294e42d614bf1","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/far.styl","hash":"d9928010ffe71e80b97a5afcba1a4975efdd7372","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/darkula.styl","hash":"ad0d5728d21645039c9f199e7a56814170ed3bab","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/foundation.styl","hash":"bf8ddc94b4ad995b8b8805b5a4cf95004553fdac","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/github-gist.styl","hash":"48211a03d33e7f7ada0b261162bea06676155a71","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/github.styl","hash":"3336aeba324c6d34a6fd41fef9b47bc598f7064c","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/googlecode.styl","hash":"bda816beee7b439814b514e6869dc678822be1bc","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/grayscale.styl","hash":"bf37d8b8d1e602126c51526f0cc28807440228ed","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/highlightjs.styl","hash":"0e198b7a59191c7a39b641a4ddd22c948edb9358","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/hopscotch.styl","hash":"b374c6550b89b4751aedc8fbc3cf98d95bd70ead","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/hybrid.styl","hash":"ea8d7ddc258b073308746385f5cb85aabb8bfb83","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/idea.styl","hash":"a02967cb51c16a34e0ee895d33ded2b823d35b21","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/index.styl","hash":"002d5596f6379cc87dbd43d9145bc764aa666be1","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/ir-black.styl","hash":"693078bbd72a2091ed30f506cc55949600b717af","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/kimbie.dark.styl","hash":"45dbb168f22d739d0109745d2decd66b5f94e786","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/kimbie.light.styl","hash":"61f8baed25be05288c8604d5070afbcd9f183f49","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/magula.styl","hash":"16d323f989b1420a0f72ef989242ece9bf17a456","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/mono-blue.styl","hash":"4c89a6ae29de67c0700585af82a60607e85df928","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/monokai-sublime.styl","hash":"25aa2fc1dbe38593e7c7ebe525438a39574d9935","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/monokai.styl","hash":"5a4fe9f957fd7a368c21b62a818403db4270452f","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/obsidian.styl","hash":"55572bbcfee1de6c31ac54681bb00336f5ae826d","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/paraiso-dark.styl","hash":"f1537bd868579fa018ecdbfd2eb922dcf3ba2cac","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/paraiso-light.styl","hash":"d224d1df0eb3395d9eea1344cee945c228af2911","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/pojoaque.jpg","hash":"c5fe6533b88b21f8d90d3d03954c6b29baa67791","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/pojoaque.styl","hash":"77dae9dc41945359d17fe84dbd317f1b40b2ee33","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/railscasts.styl","hash":"acd620f8bb7ff0e3fe5f9a22b4433ceef93a05e6","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/rainbow.styl","hash":"ce73b858fc0aba0e57ef9fb136c083082746bc1d","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/school-book.png","hash":"711ec983c874e093bb89eb77afcbdf6741fa61ee","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/school-book.styl","hash":"d43560fe519a931ce6da7d57416d7aa148441b83","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/solarized-dark.styl","hash":"702b9299a48c90124e3ac1d45f1591042f2beccc","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/solarized-light.styl","hash":"aa0dd3fd25c464183b59c5575c9bee8756b397f2","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/sunburst.styl","hash":"a0b5b5129547a23865d400cfa562ea0ac1ee3958","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/tomorrow-night-blue.styl","hash":"8b3087d4422be6eb800935a22eb11e035341c4ba","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/tomorrow-night-bright.styl","hash":"0ac6af6ecb446b5b60d6226748e4a6532db34f57","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/tomorrow-night-eighties.styl","hash":"fa57b3bb7857a160fc856dbe319b31e30cc5d771","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/tomorrow-night.styl","hash":"19b3080d4b066b40d50d7e7f297472482b5801fd","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/tomorrow.styl","hash":"15779cf6846725c7c35fc56cac39047d7e0aec1c","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/vs.styl","hash":"959a746f4b37aacb5d1d6ff1d57e0c045289d75d","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/xcode.styl","hash":"5e8532ae8366dcf6a4ef5e4813dc3d42ab3d0a50","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/zenburn.styl","hash":"fc5ec840435dad80964d04519d3f882ddc03746a","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_partial/archive.styl","hash":"146b5a86d6f602232d86e246ea20620ec923cccc","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_partial/article.styl","hash":"55392727ed6a4cc57dca7ed88ae8364d441e65e3","modified":1564810565000},{"_id":"themes/Wikitten/source/css/_partial/comment.styl","hash":"784646796184d4f27918c22395288a2fafbf9554","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_partial/footer.styl","hash":"484776654e4c1691dc844e6e93786a08855c1c99","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_partial/header.styl","hash":"154fcfe17c4a9833903b3a91efb1ddf315e7fcba","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_partial/insight.styl","hash":"d3195723c373a68a05b76d430f8aeb2d2dd1957f","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_partial/profile.styl","hash":"2ecc48d48ad8769556036f19f2769c84c428cbc6","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_partial/sidebar.styl","hash":"4a11aace0de3aeafdd88caef7cd238543ce1cd95","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_util/grid.styl","hash":"93fb6f1e2f40cd7d88ad0d56dd73d3f9a7bc853e","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_partial/timeline.styl","hash":"4ea679287d49f91634dd32ad812746cccc1e6281","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_util/mixin.styl","hash":"c8e1ddfc0fe9108bab592c7a73b73ce9344991fd","modified":1563743114000},{"_id":"themes/Wikitten/source/css/images/favicon.ico","hash":"b37ac89616b9e4c01a35991af59fe6b63e41a48e","modified":1563743114000},{"_id":"themes/Wikitten/source/css/images/logo.png","hash":"8c61e1ec0b7c7200045d7795bac097fce475ef16","modified":1563743114000},{"_id":"themes/Wikitten/source/css/images/thumb-default-small.png","hash":"e8403b97ed9251f9f5207765b0ce796c5000b4ba","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/fonts/glyphicons-halflings-regular.woff2","hash":"ca35b697d99cae4d1b60f2d60fcd37771987eb07","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/fonts/glyphicons-halflings-regular.woff","hash":"278e49a86e634da6f2a02f3b47dd9d2a8f26210f","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/fonts/glyphicons-halflings-regular.ttf","hash":"44bc1850f570972267b169ae18f1cb06b611ffa2","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/justified-gallery/justifiedGallery.min.css","hash":"13fbcba5e97aa88b748d94d3efc4718475279907","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/justified-gallery/jquery.justifiedGallery.min.js","hash":"b2683e7a872bc109b1756a65188a37cef7d0bd5c","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/source-code-pro/styles.css","hash":"93c308012738728f906cd4c5cfdb34189e0c712b","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/open-sans/styles.css","hash":"5ca6e111046232bde112d33201a60532aee7d3c4","modified":1563743114000},{"_id":"themes/Wikitten/source/images/SitePreview.png","hash":"c37c32696828492d6a8a4dfb0f84af98f5fb1306","modified":1563743114000},{"_id":"themes/Wikitten/source/uploads/road-to-asset-freedom-mindmap.html","hash":"eed342d1dd1cac1d8635292caeac2ed90f64cc70","modified":1563735219000},{"_id":"themes/Wikitten/source/libs/fonts/glyphicons-halflings-regular.eot","hash":"86b6f62b7853e67d3e635f6512a5a5efc58ea3c3","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/fonts/glyphicons-halflings-regular.svg","hash":"de51a8494180a6db074af2dee2383f0a363c5b08","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/font-awesome/css/font-awesome.css","hash":"b5020c3860669185ba3f316fa7332cdf5c06f393","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/lightgallery/css/lg-fb-comment-box.css","hash":"844ce27b8488968bccb3e50bb49184ba2aae0625","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/font-awesome/css/font-awesome.min.css","hash":"7cd5a3384333f95c3d37d9488ad82cd6c4b03761","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/lightgallery/css/lg-fb-comment-box.css.map","hash":"51e9df39edf0faa3f38c1bab0c1fa6c922b9edcb","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/lightgallery/css/lg-fb-comment-box.min.css","hash":"05830fadb8454f39dcc98c8686eb4d5c24b71fc0","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/lightgallery/css/lg-transitions.css","hash":"7871c28498d74451d6aa438c8d3a1817810a1e19","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/lightgallery/css/lg-transitions.css.map","hash":"50c3348638b4d82fa08a449c690e8d2bb593005d","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/lightgallery/css/lg-transitions.min.css","hash":"5c22e2073a4c96d6212c72135391b599e8d1359f","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/lightgallery/css/lightgallery.css","hash":"bef55316a32e512d5a8940e5d0bfe8bf7a9c5c61","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/lightgallery/css/lightgallery.css.map","hash":"3175b4107078674d25798979f7666f4daf31e624","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/lightgallery/css/lightgallery.min.css","hash":"c9a2e19c932b56f4a2ce30c98910d10b74edb38a","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/lightgallery/fonts/lg.eot","hash":"54caf05a81e33d7bf04f2e420736ce6f1de5f936","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/lightgallery/fonts/lg.svg","hash":"9a732790adc004b22022cc60fd5f77ec4c8e3e5a","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/lightgallery/fonts/lg.woff","hash":"3048de344dd5cad4624e0127e58eaae4b576f574","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/lightgallery/js/lg-autoplay.js","hash":"426bb78b93acfc39d533ea2bab1cec8dc289cf24","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/lightgallery/fonts/lg.ttf","hash":"f6421c0c397311ae09f9257aa58bcd5e9720f493","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/lightgallery/js/lg-autoplay.min.js","hash":"d845741bcaf961579622880eb2a445257efad1ac","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/lightgallery/js/lg-fullscreen.js","hash":"65c47ac65362854ba44b00a010bb01e3630209d8","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/lightgallery/js/lg-fullscreen.min.js","hash":"b6b9e4022700b7faf2a5a175ba44a3bd938fdd20","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/lightgallery/js/lg-hash.js","hash":"15d16516c5642d3de1566ff8fc9160136ccaa405","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/lightgallery/js/lg-hash.min.js","hash":"43f1e1e720ab0e241c19b83aa26bd6848eab8edc","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/lightgallery/js/lg-pager.js","hash":"8092c692b244bb26343eb03b91bd97deb9dafc9c","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/lightgallery/js/lg-pager.min.js","hash":"25caa6ff65b1c6dee09941e795ae2633bdbab211","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/lightgallery/js/lg-share.js","hash":"b7fb5f6474911060a351b0a6fe9dbb9ac3fb22aa","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/lightgallery/js/lg-share.min.js","hash":"39c615f07c5d3aaa65a2c3068a30fdd6dd5c372d","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/lightgallery/js/lg-thumbnail.js","hash":"3a6476b6df1d2bef4a21861a78776282a7a11ef1","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/lightgallery/js/lg-thumbnail.min.js","hash":"18dd7d2909d1bfd6852f031d03e774b4428c512b","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/lightgallery/js/lg-video.js","hash":"4f99b598f6bb18de9eca8c45c5b4373a03962367","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/lightgallery/js/lg-video.min.js","hash":"032c001ab045a69856f9c3ed4a2a3bf12a8e310f","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/lightgallery/js/lg-zoom.js","hash":"a758e2c8fcf710f9ff761da0eea0ab9321f3484d","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/lightgallery/js/lg-zoom.min.js","hash":"15b49f9728439819ece15e4295cce254c87a4f45","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/lightgallery/js/lightgallery.js","hash":"3cd19b33ba99efd5ba1d167da91720566d274b2c","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/lightgallery/js/lightgallery.min.js","hash":"956ef9b706755318da69ad0b5d7786339d831251","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/lightgallery/img/loading.gif","hash":"607810444094b8619fa4efa6273bc2a7e38dd4b4","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/lightgallery/img/video-play.png","hash":"3ea484cdc04d2e4547f80cbf80001dcf248c94ef","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/lightgallery/img/vimeo-play.png","hash":"6190254f2804904a4a1fa1eb390dfd334e416992","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/lightgallery/img/youtube-play.png","hash":"fea6df9d9d43151f9c9d15f000adb30eb3e26fc4","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/59ZRklaO5bWGqF5A9baEERJtnKITppOI_IvcXXDNrsc.woff2","hash":"c4248ea800bd5608344ce163f5658b57e7ef9410","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/K88pR3goAWT7BTt32Z01mxJtnKITppOI_IvcXXDNrsc.woff2","hash":"e0350190d720a8fec0557ab47b318ec4e4486448","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/LWCjsQkB6EMdfHrEVqA1KRJtnKITppOI_IvcXXDNrsc.woff2","hash":"2c5b039b57f62625e88226a938679ec937431ad1","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/MTP_ySUJH_bn48VBG8sNShWV49_lSm1NYrwo-zkhivY.woff2","hash":"22413bb8bfb78608c1e25aa1ed5c1f38557df79f","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/MTP_ySUJH_bn48VBG8sNSj0LW-43aMEzIO6XUTLjad8.woff2","hash":"63eb74ef040aade256f2274a7f31a914edddb0ea","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/MTP_ySUJH_bn48VBG8sNSpX5f-9o1vgP2EXwfjgl7AY.woff2","hash":"328a22fe3eec71ad9e5ece4d67dd62e79dab6b7f","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/MTP_ySUJH_bn48VBG8sNSq-j2U0lmluP9RWlSytm3ho.woff2","hash":"4dc6d7174ea6d89f4c45e43e1bfc3e03d8ffebaf","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/MTP_ySUJH_bn48VBG8sNSqaRobkAwv3vxw3jMhVENGA.woff2","hash":"415eee05976ab8b2471602a5ddb78a6c58fc21aa","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/MTP_ySUJH_bn48VBG8sNSugdm0LZdjqr5-oayXSOefg.woff2","hash":"a0b0c389cf46d63c850e61fed572485ff0b68183","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/MTP_ySUJH_bn48VBG8sNSv8zf_FOSsgRmwsS7Aa9k2w.woff2","hash":"c5f29fed6632efe0aa83318369f0d8c4061b775b","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/RjgO7rYTmqiVp7vzi-Q5URJtnKITppOI_IvcXXDNrsc.woff2","hash":"be201d32a9aa5d186723ebb3c538be691aa8c53a","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/cJZKeOuBrn4kERxqtaUH3VtXRa8TVwTICgirnJhmVJw.woff2","hash":"afc44700053c9a28f9ab26f6aec4862ac1d0795d","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/u-WUoqrET9fUeobQW7jkRRJtnKITppOI_IvcXXDNrsc.woff2","hash":"113978181dcac77baecef6115a9121d8f6e4fc3a","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/xjAJXh38I15wypJXxuGMBiYE0-AqJ3nfInTTiDXDjU4.woff2","hash":"5067c81462c15422853c94d21a1726865a61634f","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/xjAJXh38I15wypJXxuGMBjTOQ_MqJVwkKsUn0wKzc2I.woff2","hash":"b366f2fda2e524eb5ef50058eefff249a3b96e6c","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/xjAJXh38I15wypJXxuGMBjUj_cnvWIuuBMVgbX098Mw.woff2","hash":"d22904914469be735490e3c8cb093c7862896dd5","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/xjAJXh38I15wypJXxuGMBkbcKLIaa1LC45dFaAfauRA.woff2","hash":"ae80fb3cd16339aa7b5da280ab53975523dcaac2","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/xjAJXh38I15wypJXxuGMBmo_sUJ8uO4YLWRInS22T3Y.woff2","hash":"b85efde42fa3a03c32b1d31c6cd74c622fc7916c","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/xjAJXh38I15wypJXxuGMBo4P5ICox8Kq3LLUNMylGO4.woff2","hash":"e75607ba1417181397c700775b84303d5a2957b9","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/xjAJXh38I15wypJXxuGMBr6up8jxqWt8HVA3mDhkV_0.woff2","hash":"d0b40a7848703556c6631f24e961a98ca5829255","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/xozscpT2726on7jbcb_pAhJtnKITppOI_IvcXXDNrsc.woff2","hash":"be365eca44760ce3fc9b377c43d4634958479c69","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/source-code-pro/fonts/mrl8jkM18OlOQN8JLgasD9V_2ngZ8dMf8fLgjYEouxg.woff2","hash":"942addaec4d3a60af33947a84a3d85f926015947","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/source-code-pro/fonts/mrl8jkM18OlOQN8JLgasDy2Q8seG17bfDXYR_jUsrzg.woff2","hash":"b0e0bb5ef78db8b15d430d0b9be9d4329289a310","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/font-awesome/fonts/fontawesome-webfont.woff","hash":"6d7e6a5fc802b13694d8820fc0138037c0977d2e","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/font-awesome/fonts/fontawesome-webfont.woff2","hash":"97e438cc545714309882fbceadbf344fcaddcec5","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/font-awesome/fonts/FontAwesome.otf","hash":"1b22f17fdc38070de50e6d1ab3a32da71aa2d819","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/font-awesome/fonts/fontawesome-webfont.eot","hash":"965ce8f688fedbeed504efd498bc9c1622d12362","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/font-awesome/fonts/fontawesome-webfont.ttf","hash":"61d8d967807ef12598d81582fa95b9f600c3ee01","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/jquery/2.1.3/jquery.min.js","hash":"41b4bfbaa96be6d1440db6e78004ade1c134e276","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/jquery/plugins/cookie/1.4.1/jquery.cookie.js","hash":"31e1bcc4cf805a2c2fee21f48ded1e598f64a2a8","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/font-awesome/fonts/fontawesome-webfont.svg","hash":"c0522272bbaef2acb3d341912754d6ea2d0ecfc0","modified":1563743114000},{"_id":"themes/Wikitten/source/uploads/tianya.png","hash":"2d392e6eb508d31f7328d0c21492f3970f0ee213","modified":1563651881000},{"_id":"source/.DS_Store","hash":"a9cabec0ae931e7048f423a95c704c714780b5e1","modified":1588882647870},{"_id":"source/.markeditor/file_manager_status.config","hash":"c750fd1fe3f1407005c5d2b5d7b7f9bca54970c3","modified":1564688931000},{"_id":"source/.markeditor/file_manager_width.config","hash":"2c427b959b7a35c68831d16645d2afde8cb67ddd","modified":1564594162000},{"_id":"source/_drafts/.DS_Store","hash":"df2fbeb1400acda0909a32c1cf6bf492f1121e07","modified":1565728063000},{"_id":"source/_drafts/典故-md.md","hash":"2b33e03ac046894df112a9d45da13a690f621ed2","modified":1563856606000},{"_id":"source/_posts/.DS_Store","hash":"6f8ff578f75eaeb17eeb676dc7e41d9fe37fa6af","modified":1588882832887},{"_id":"source/about/index.md","hash":"282d4c506b467c746d1154f25338d16be6abbb62","modified":1563816667000},{"_id":"source/categories/.DS_Store","hash":"df2fbeb1400acda0909a32c1cf6bf492f1121e07","modified":1565728063000},{"_id":"source/about/.DS_Store","hash":"df2fbeb1400acda0909a32c1cf6bf492f1121e07","modified":1565728063000},{"_id":"source/categories/index.md","hash":"53bbe27e36d98a4a55fdce6a7fd9cac3e6671439","modified":1563766746000},{"_id":"source/tags/.DS_Store","hash":"df2fbeb1400acda0909a32c1cf6bf492f1121e07","modified":1565728063000},{"_id":"source/tags/index.md","hash":"163f9d816dac6cc50a48347bf7f93f29fa503736","modified":1563766671000},{"_id":"source/_posts/.markeditor/file_manager_status.config","hash":"26ccad3385b35b5dd4b33232ba36d0da4f190c00","modified":1588848849111},{"_id":"source/_posts/.markeditor/file_manager_width.config","hash":"2c427b959b7a35c68831d16645d2afde8cb67ddd","modified":1588848807781},{"_id":"source/_posts/IT/.DS_Store","hash":"f31c5797d3b40ff7f36965331428bf17084dc289","modified":1565813210000},{"_id":"source/_posts/常用文件/Hexo日常管理.md","hash":"48184f3ce76a6679a525e3349ec30ae4608ac5ec","modified":1564718092000},{"_id":"source/_posts/常用文件/.DS_Store","hash":"df2fbeb1400acda0909a32c1cf6bf492f1121e07","modified":1565728063000},{"_id":"source/_posts/摘录/.DS_Store","hash":"df2fbeb1400acda0909a32c1cf6bf492f1121e07","modified":1565728063000},{"_id":"source/_posts/摘录/《驴得水》影评.md","hash":"dcd7ea1a8643fe06ff14022c5d5577ccf810a33c","modified":1565905736000},{"_id":"source/_posts/摘录/典故.md","hash":"bd9982cfe6eea388c4f99b79d479939974cf0d1e","modified":1564545095000},{"_id":"source/_posts/摘录/爱乐之城——影评.md","hash":"dd74130851f4565e9a4ae2d8b1218e4b74fb9672","modified":1565764310000},{"_id":"source/_posts/文档/RZF-Organisation.md","hash":"37c4c97661f0ac8203e1b0c4f7f1df70dfe2c4a1","modified":1566463161000},{"_id":"source/_posts/读书笔记/.DS_Store","hash":"df2fbeb1400acda0909a32c1cf6bf492f1121e07","modified":1565728063000},{"_id":"source/_posts/读书笔记/《少有人走的路》笔记.md","hash":"5a6ce1a62ddca691e7aa49658a6a1ea8cd8215e3","modified":1564632258000},{"_id":"source/_posts/读书笔记/斯多葛主义手册.md","hash":"a56ce651794cbedea74361202e9f1868a0b10f61","modified":1565764288000},{"_id":"source/_posts/读书笔记/财富自由之路-李笑来.md","hash":"0f1bb3b57fb1b23e38984f0343c31431c0592ab8","modified":1565764569000},{"_id":"source/_posts/随笔/.DS_Store","hash":"df2fbeb1400acda0909a32c1cf6bf492f1121e07","modified":1565728063000},{"_id":"source/_posts/随笔/hello-world.md","hash":"5c562e2b6c5184f490c0ea1b6d820fe50579406b","modified":1564545095000},{"_id":"source/_posts/IT/Code/Javascript技术摘要.md","hash":"e949fc3ccd48cfba5e3064c7b39ed5f523553d86","modified":1589169243957},{"_id":"source/_posts/IT/Mac/.DS_Store","hash":"df2fbeb1400acda0909a32c1cf6bf492f1121e07","modified":1588882793782},{"_id":"source/_posts/IT/Mac/Mac使用标签.md","hash":"c28b4fa4701f08fcfe5942ec8f151d7cfd2f8dad","modified":1564545094000},{"_id":"source/_posts/IT/Tools/Ubuntu重设root用户密码.md","hash":"b7323a3ac81d57b3c489d97c7da56a991883089f","modified":1565764467000},{"_id":"source/_posts/IT/Tools/坚果云有关.md","hash":"1a966cbc37318b34551bf17be4bccfc16761fa7f","modified":1565820630000},{"_id":"source/_posts/IT/Tools/Gitbook攻略.md","hash":"c78d9b403444239f353b6a4a6ce0f97e6ad0fcd7","modified":1565862378000},{"_id":"source/_posts/IT/Mac/Mac备忘录.md","hash":"5d7fb8ad7a1a59b6dd65df8a6eae0d8cb7b18fd5","modified":1588836517649},{"_id":"source/_posts/IT/Tools/使用Github维护知识库.md","hash":"27bf57527ac1d9061b1733540ac9f0b383a8a35f","modified":1565862053000},{"_id":"source/_posts/IT/Tools/有用的shell命令.md","hash":"1e3bffca5cac009d0f91cbd6bb96206076e50cae","modified":1565788356000},{"_id":"source/_posts/IT/Tools/编辑器工具使用技巧汇总.md","hash":"8103dd1e47e61523c797cf86e82bb26517f54b12","modified":1567357907000},{"_id":"source/_posts/IT/Tools/配置服务器端MySQL.md","hash":"d44b85906db5816259dc4b2128dcac8a0766b447","modified":1565788245000},{"_id":"source/_posts/IT/Web/Next主题添加内容折叠.md","hash":"0c381c884e0c77af522fdbf958536f2c217ceb1b","modified":1564545094000},{"_id":"source/_posts/IT/Web/同步Hexo文章与Mac上原笔记的分类和标签.md","hash":"3af3acc8ed642c8c74ad89b87ee0e98bf0db9865","modified":1564837106000},{"_id":"source/_posts/IT/Web/如何系统化管理Hexo博客.md","hash":"06aeeeb674ebf91cc550732fd7c5f5f30413e791","modified":1565905917000},{"_id":"source/_posts/IT/Web/搭建Hexo博客的流水账.md","hash":"2bc4bf601a7c03ca17acf56806bd8aaf1b2e6f5c","modified":1565865865000},{"_id":"source/_posts/IT/skill/用Typescript编写JS函数库.md","hash":"b189a07241dcd4bc6388fb40f92d1ec9b9835669","modified":1566646240000},{"_id":"source/_posts/IT/skill/还在用七牛.md","hash":"ee7b98bee940ef09c06ffcdc967b41af8d0752b1","modified":1565852093000},{"_id":"source/_posts/IT/skill/MathJax用于易学领域.md","hash":"a199fc359afe19f5ec89c2069defd27990b742f9","modified":1588930688489},{"_id":"source/_posts/摘录/娱乐/搞笑段子.md","hash":"a13e48400bba8b3427b7ac080073ec19fa20bc93","modified":1564545095000},{"_id":"source/_posts/摘录/片段/佛偈集合.md","hash":"fcc94a0d1fbabbd9ff5cc9a607bc07dec6b9fb8b","modified":1565905574000},{"_id":"source/_posts/摘录/片段/名人语录.md","hash":"3c9d34d4393d3276a3ab8ad82ccabc6b3155f39f","modified":1564545095000},{"_id":"source/_posts/摘录/片段/简短书摘.md","hash":"a2586fd508f831d1631fbc0925c39288ffd23692","modified":1564545095000},{"_id":"source/_posts/摘录/片段/缠中说禅.md","hash":"57bc98bc30aff6804eebbe9b5300af1f673973a3","modified":1564545095000},{"_id":"source/_posts/摘录/片段/零散句子.md","hash":"c6100208f88c30d1910c03d472cc96e53320c996","modified":1564942528000}],"Category":[{"name":"常用文件","_id":"cka1y594t00064huuvvjmyzwy"},{"name":"摘录","_id":"cka1y5953000b4huuyyfu5z4d"},{"name":"文档","_id":"cka1y5959000j4huug5k1h4j7"},{"name":"随笔","_id":"cka1y595b000o4huul85o0vh5"},{"name":"读书笔记","_id":"cka1y596g000v4huufrvfyl7e"},{"name":"IT","_id":"cka1y597u00184huu67j8phqt"},{"name":"Mac","parent":"cka1y597u00184huu67j8phqt","_id":"cka1y5987001q4huu2h0pcxc7"},{"name":"Code","parent":"cka1y597u00184huu67j8phqt","_id":"cka1y598b001w4huu0hxl1aoy"},{"name":"Tools","parent":"cka1y597u00184huu67j8phqt","_id":"cka1y598e00234huu3y8d3uke"},{"name":"Web","parent":"cka1y597u00184huu67j8phqt","_id":"cka1y598z003b4huuyf8flxmz"},{"name":"skill","parent":"cka1y597u00184huu67j8phqt","_id":"cka1y5997003q4huuzp1l2yal"},{"name":"片段","parent":"cka1y5953000b4huuyyfu5z4d","_id":"cka1y599a003w4huuplb2sm25"},{"name":"娱乐","parent":"cka1y5953000b4huuyyfu5z4d","_id":"cka1y599b00404huu2nbcrdvc"}],"Data":[],"Page":[{"title":"关于本站","date":"2019-07-20T20:03:56.000Z","layout":"page","_content":"自从过上了极简生活,家务变得很少。对于一个巨蟹座的中年大叔,整理笔记成了我主要的挥洒精力的地方。我是笔记App的重度用户,用了两年的印象笔记,然后又五年的为知笔记,乃至尝试了新生人类惊为天人的熊掌记、Notion、等等。仍然感觉各种不爽。自从有了Hexo,终于可以定下心来,专心做笔记了。\n\n\n\n作为不是处女座的强迫症患者,我把自己的这个笔记库部署到了两个不同的站点。内容基本一样,组织方式十分不同。\n\n[完整个人维基](https://maiernte.github.io/wiki)\n\n[心情版的博客](https://maiernte.github.io)","source":"about/index.md","raw":"---\ntitle: 关于本站\ndate: 2019-07-20 22:03:56\nlayout: \"page\"\n---\n自从过上了极简生活,家务变得很少。对于一个巨蟹座的中年大叔,整理笔记成了我主要的挥洒精力的地方。我是笔记App的重度用户,用了两年的印象笔记,然后又五年的为知笔记,乃至尝试了新生人类惊为天人的熊掌记、Notion、等等。仍然感觉各种不爽。自从有了Hexo,终于可以定下心来,专心做笔记了。\n\n\n\n作为不是处女座的强迫症患者,我把自己的这个笔记库部署到了两个不同的站点。内容基本一样,组织方式十分不同。\n\n[完整个人维基](https://maiernte.github.io/wiki)\n\n[心情版的博客](https://maiernte.github.io)","updated":"2019-07-22T17:31:07.000Z","path":"about/index.html","_id":"cka1y592h00014huu243mez1a","comments":1,"content":"

自从过上了极简生活,家务变得很少。对于一个巨蟹座的中年大叔,整理笔记成了我主要的挥洒精力的地方。我是笔记App的重度用户,用了两年的印象笔记,然后又五年的为知笔记,乃至尝试了新生人类惊为天人的熊掌记、Notion、等等。仍然感觉各种不爽。自从有了Hexo,终于可以定下心来,专心做笔记了。

\n

作为不是处女座的强迫症患者,我把自己的这个笔记库部署到了两个不同的站点。内容基本一样,组织方式十分不同。

\n

完整个人维基

\n

心情版的博客

\n","site":{"data":{}},"excerpt":"","more":"

自从过上了极简生活,家务变得很少。对于一个巨蟹座的中年大叔,整理笔记成了我主要的挥洒精力的地方。我是笔记App的重度用户,用了两年的印象笔记,然后又五年的为知笔记,乃至尝试了新生人类惊为天人的熊掌记、Notion、等等。仍然感觉各种不爽。自从有了Hexo,终于可以定下心来,专心做笔记了。

\n

作为不是处女座的强迫症患者,我把自己的这个笔记库部署到了两个不同的站点。内容基本一样,组织方式十分不同。

\n

完整个人维基

\n

心情版的博客

\n"},{"title":"分类","date":"2019-07-20T19:59:23.000Z","type":"categories","layout":"categories","comments":0,"_content":"","source":"categories/index.md","raw":"---\ntitle: 分类\ndate: 2019-07-20 21:59:23\ntype: \"categories\"\nlayout: \"categories\"\ncomments: false\n---\n","updated":"2019-07-22T03:39:06.000Z","path":"categories/index.html","_id":"cka1y592j00024huuarbix88c","content":"","site":{"data":{}},"excerpt":"","more":""},{"title":"标签","date":"2019-07-20T19:49:33.000Z","type":"tags","layout":"tags","comments":0,"_content":"","source":"tags/index.md","raw":"---\ntitle: 标签\ndate: 2019-07-20 21:49:33\ntype: \"tags\"\nlayout: \"tags\"\ncomments: false\n---\n","updated":"2019-07-22T03:37:51.000Z","path":"tags/index.html","_id":"cka1y593q00034huu0cpu2qd8","content":"","site":{"data":{}},"excerpt":"","more":""}],"Post":[{"title":"典故.md","date":"2019-07-23T04:36:46.000Z","_content":"###### 豫让刺赵简子\n\n晋毕阳之孙豫让,始事范、中行氏而不说,去而就知伯,知伯宠之。及三晋分知氏,赵襄子最恐知伯,而将其头以为饮器。豫让遁逃山中曰:“磋乎!士为知己者死,女为悦己者容。吾其报知氏之仇矣。”\n\n乃变姓名,为刑人,入宫涂厕,欲以刺襄子。 襄子如厕,心动,执问涂者,则豫让也。 刃其曰:“欲为知伯报仇!”左右欲杀之。 赵襄子曰:“彼义士也,吾谨避之耳。且知伯已死,无后,而其臣至为报仇,此天下之贤人也。”卒释之。 豫让又漆身为厉,灭须去眉,自刑以变其容,为乞人而往乞,其妻不识,曰:“状貌不似吾夫,其音何类吾夫之甚也。”又吞炭为哑,变其音。 其友谓之曰:“子之道甚难而无功,谓子有志,则然矣,谓子知,则否。以子之才,而善事襄子,襄子必近幸子;子之得近而行所欲,此甚易而功必成。”豫让乃笑而应之曰:“是为先知报后知,为故君贼新君,大乱君臣之义者无此矣。凡吾所谓为此者,以明君臣之义,非从易也。且夫委质而事人,而求弑之,是怀二心以事君也。吾所为难,亦将以愧天下后世人臣怀二心者。”\n\n居顷之,襄子当出,豫让伏所当过桥下。 襄子至桥而马惊。 襄子曰:“此必豫让也。”使人问之,果豫让。 于是赵襄子面数豫让曰:“子不尝事范中行氏乎?知伯灭范中行氏,而子不为报仇,反委质事知伯。知伯已死,子独何为报仇之深也?”豫让曰:“臣事范中行氏,范中行氏以众人遇臣,臣故众人报之;知伯以国士遇臣,臣故国士报之。”襄子乃喟然叹泣曰:“嗟乎,豫子!豫子之为知伯,名既成矣,寡人舍子,亦以足矣。子自为计,寡人不舍子。”使兵环之。 豫让曰:“臣闻明主不掩人之义,忠臣不爱死以成名。君前已宽舍臣,天下莫不称君之贤。今日之事,臣故伏诛,然愿请君之衣而击之,虽死不恨。非所望也,敢布腹心。”于是襄子义之,乃使使者持衣与豫让。 豫让拔剑三跃,呼天击之曰:“而可以报知伯矣。”遂伏剑而死。 死之日,赵国之士闻之,皆为涕泣。\n\n—— 《战国策》","source":"_drafts/典故-md.md","raw":"title: 典故.md\ndate: 2019-07-23 06:36:46\ntags:\n---\n###### 豫让刺赵简子\n\n晋毕阳之孙豫让,始事范、中行氏而不说,去而就知伯,知伯宠之。及三晋分知氏,赵襄子最恐知伯,而将其头以为饮器。豫让遁逃山中曰:“磋乎!士为知己者死,女为悦己者容。吾其报知氏之仇矣。”\n\n乃变姓名,为刑人,入宫涂厕,欲以刺襄子。 襄子如厕,心动,执问涂者,则豫让也。 刃其曰:“欲为知伯报仇!”左右欲杀之。 赵襄子曰:“彼义士也,吾谨避之耳。且知伯已死,无后,而其臣至为报仇,此天下之贤人也。”卒释之。 豫让又漆身为厉,灭须去眉,自刑以变其容,为乞人而往乞,其妻不识,曰:“状貌不似吾夫,其音何类吾夫之甚也。”又吞炭为哑,变其音。 其友谓之曰:“子之道甚难而无功,谓子有志,则然矣,谓子知,则否。以子之才,而善事襄子,襄子必近幸子;子之得近而行所欲,此甚易而功必成。”豫让乃笑而应之曰:“是为先知报后知,为故君贼新君,大乱君臣之义者无此矣。凡吾所谓为此者,以明君臣之义,非从易也。且夫委质而事人,而求弑之,是怀二心以事君也。吾所为难,亦将以愧天下后世人臣怀二心者。”\n\n居顷之,襄子当出,豫让伏所当过桥下。 襄子至桥而马惊。 襄子曰:“此必豫让也。”使人问之,果豫让。 于是赵襄子面数豫让曰:“子不尝事范中行氏乎?知伯灭范中行氏,而子不为报仇,反委质事知伯。知伯已死,子独何为报仇之深也?”豫让曰:“臣事范中行氏,范中行氏以众人遇臣,臣故众人报之;知伯以国士遇臣,臣故国士报之。”襄子乃喟然叹泣曰:“嗟乎,豫子!豫子之为知伯,名既成矣,寡人舍子,亦以足矣。子自为计,寡人不舍子。”使兵环之。 豫让曰:“臣闻明主不掩人之义,忠臣不爱死以成名。君前已宽舍臣,天下莫不称君之贤。今日之事,臣故伏诛,然愿请君之衣而击之,虽死不恨。非所望也,敢布腹心。”于是襄子义之,乃使使者持衣与豫让。 豫让拔剑三跃,呼天击之曰:“而可以报知伯矣。”遂伏剑而死。 死之日,赵国之士闻之,皆为涕泣。\n\n—— 《战国策》","slug":"典故-md","published":0,"updated":"2019-07-23T04:36:46.000Z","_id":"cka1y592b00004huurtszb8lj","comments":1,"layout":"post","photos":[],"link":"","content":"
豫让刺赵简子
\n

晋毕阳之孙豫让,始事范、中行氏而不说,去而就知伯,知伯宠之。及三晋分知氏,赵襄子最恐知伯,而将其头以为饮器。豫让遁逃山中曰:“磋乎!士为知己者死,女为悦己者容。吾其报知氏之仇矣。”

\n

乃变姓名,为刑人,入宫涂厕,欲以刺襄子。 襄子如厕,心动,执问涂者,则豫让也。 刃其曰:“欲为知伯报仇!”左右欲杀之。 赵襄子曰:“彼义士也,吾谨避之耳。且知伯已死,无后,而其臣至为报仇,此天下之贤人也。”卒释之。 豫让又漆身为厉,灭须去眉,自刑以变其容,为乞人而往乞,其妻不识,曰:“状貌不似吾夫,其音何类吾夫之甚也。”又吞炭为哑,变其音。 其友谓之曰:“子之道甚难而无功,谓子有志,则然矣,谓子知,则否。以子之才,而善事襄子,襄子必近幸子;子之得近而行所欲,此甚易而功必成。”豫让乃笑而应之曰:“是为先知报后知,为故君贼新君,大乱君臣之义者无此矣。凡吾所谓为此者,以明君臣之义,非从易也。且夫委质而事人,而求弑之,是怀二心以事君也。吾所为难,亦将以愧天下后世人臣怀二心者。”

\n

居顷之,襄子当出,豫让伏所当过桥下。 襄子至桥而马惊。 襄子曰:“此必豫让也。”使人问之,果豫让。 于是赵襄子面数豫让曰:“子不尝事范中行氏乎?知伯灭范中行氏,而子不为报仇,反委质事知伯。知伯已死,子独何为报仇之深也?”豫让曰:“臣事范中行氏,范中行氏以众人遇臣,臣故众人报之;知伯以国士遇臣,臣故国士报之。”襄子乃喟然叹泣曰:“嗟乎,豫子!豫子之为知伯,名既成矣,寡人舍子,亦以足矣。子自为计,寡人不舍子。”使兵环之。 豫让曰:“臣闻明主不掩人之义,忠臣不爱死以成名。君前已宽舍臣,天下莫不称君之贤。今日之事,臣故伏诛,然愿请君之衣而击之,虽死不恨。非所望也,敢布腹心。”于是襄子义之,乃使使者持衣与豫让。 豫让拔剑三跃,呼天击之曰:“而可以报知伯矣。”遂伏剑而死。 死之日,赵国之士闻之,皆为涕泣。

\n

—— 《战国策》

\n","site":{"data":{}},"excerpt":"","more":"
豫让刺赵简子
\n

晋毕阳之孙豫让,始事范、中行氏而不说,去而就知伯,知伯宠之。及三晋分知氏,赵襄子最恐知伯,而将其头以为饮器。豫让遁逃山中曰:“磋乎!士为知己者死,女为悦己者容。吾其报知氏之仇矣。”

\n

乃变姓名,为刑人,入宫涂厕,欲以刺襄子。 襄子如厕,心动,执问涂者,则豫让也。 刃其曰:“欲为知伯报仇!”左右欲杀之。 赵襄子曰:“彼义士也,吾谨避之耳。且知伯已死,无后,而其臣至为报仇,此天下之贤人也。”卒释之。 豫让又漆身为厉,灭须去眉,自刑以变其容,为乞人而往乞,其妻不识,曰:“状貌不似吾夫,其音何类吾夫之甚也。”又吞炭为哑,变其音。 其友谓之曰:“子之道甚难而无功,谓子有志,则然矣,谓子知,则否。以子之才,而善事襄子,襄子必近幸子;子之得近而行所欲,此甚易而功必成。”豫让乃笑而应之曰:“是为先知报后知,为故君贼新君,大乱君臣之义者无此矣。凡吾所谓为此者,以明君臣之义,非从易也。且夫委质而事人,而求弑之,是怀二心以事君也。吾所为难,亦将以愧天下后世人臣怀二心者。”

\n

居顷之,襄子当出,豫让伏所当过桥下。 襄子至桥而马惊。 襄子曰:“此必豫让也。”使人问之,果豫让。 于是赵襄子面数豫让曰:“子不尝事范中行氏乎?知伯灭范中行氏,而子不为报仇,反委质事知伯。知伯已死,子独何为报仇之深也?”豫让曰:“臣事范中行氏,范中行氏以众人遇臣,臣故众人报之;知伯以国士遇臣,臣故国士报之。”襄子乃喟然叹泣曰:“嗟乎,豫子!豫子之为知伯,名既成矣,寡人舍子,亦以足矣。子自为计,寡人不舍子。”使兵环之。 豫让曰:“臣闻明主不掩人之义,忠臣不爱死以成名。君前已宽舍臣,天下莫不称君之贤。今日之事,臣故伏诛,然愿请君之衣而击之,虽死不恨。非所望也,敢布腹心。”于是襄子义之,乃使使者持衣与豫让。 豫让拔剑三跃,呼天击之曰:“而可以报知伯矣。”遂伏剑而死。 死之日,赵国之士闻之,皆为涕泣。

\n

—— 《战国策》

\n"},{"title":"Hexo日常管理","date":"2019-07-30T15:27:28.000Z","urlname":"hexo-blog-alltag-verwalten","toc":true,"notshow":true,"_content":"\n# 复制MD文件\n\n\n#### 查找最新文件\n\n```sh\nls -t /Users/mai/Projects/hexo/source/_posts/*.md | head -1 | xargs ls -l | awk '{print $6 \"-\" $7 \"-\" $8 }'\n\n# 最旧的文件就应该是\nls -t /Users/mai/Projects/hexo/source/_posts/*.md | tail -1 | xargs ls -l | awk '{print $6 \"-\" $7 \"-\" $8 }'\n```\n\n\n\n# 其它\n\nHexo 代码折叠\n\n```\n{% fold 点击显/隐内容 %}\n需要隐藏的内容。。。\n{% endfold %}\n```\n\n\n\n# 参考文件\n\n[有用的shell命令](helpfull-shell-command.html)\n\n# 会导致编译奔溃的错误\n\n大括号和井号连在一起\n\n```sh\n{#、 #}、{#} 这三种情况都会导致系统奔溃\n{} 和 # 之间如果有别的字符就不会。如 { # }\n或者放在代码段内也不会。行内代码不能避免这种情形。\n```\n\n","source":"_posts/常用文件/Hexo日常管理.md","raw":"---\ntitle: Hexo日常管理\ndate: 2019-07-30 17:27:28\nurlname: hexo-blog-alltag-verwalten\ntoc: true\ntags: [Hexo]\ncategories: [常用文件]\nnotshow: true\n\n---\n\n# 复制MD文件\n\n\n#### 查找最新文件\n\n```sh\nls -t /Users/mai/Projects/hexo/source/_posts/*.md | head -1 | xargs ls -l | awk '{print $6 \"-\" $7 \"-\" $8 }'\n\n# 最旧的文件就应该是\nls -t /Users/mai/Projects/hexo/source/_posts/*.md | tail -1 | xargs ls -l | awk '{print $6 \"-\" $7 \"-\" $8 }'\n```\n\n\n\n# 其它\n\nHexo 代码折叠\n\n```\n{% fold 点击显/隐内容 %}\n需要隐藏的内容。。。\n{% endfold %}\n```\n\n\n\n# 参考文件\n\n[有用的shell命令](helpfull-shell-command.html)\n\n# 会导致编译奔溃的错误\n\n大括号和井号连在一起\n\n```sh\n{#、 #}、{#} 这三种情况都会导致系统奔溃\n{} 和 # 之间如果有别的字符就不会。如 { # }\n或者放在代码段内也不会。行内代码不能避免这种情形。\n```\n\n","slug":"常用文件/Hexo日常管理","published":1,"updated":"2019-08-02T03:54:52.000Z","_id":"cka1y594p00044huusb0xswfi","comments":1,"layout":"post","photos":[],"link":"","content":"

复制MD文件

\n\n

查找最新文件

\n
1
2
3
4
ls -t /Users/mai/Projects/hexo/source/_posts/*.md | head -1 | xargs ls -l | awk '{print  $6 \"-\" $7 \"-\" $8 }'

# 最旧的文件就应该是
ls -t /Users/mai/Projects/hexo/source/_posts/*.md | tail -1 | xargs ls -l | awk '{print $6 \"-\" $7 \"-\" $8 }'
\n

其它

\n

Hexo 代码折叠

\n
1
2
3
{% fold 点击显/隐内容 %}
需要隐藏的内容。。。
{% endfold %}
\n

参考文件

\n

有用的shell命令

\n

会导致编译奔溃的错误

\n

大括号和井号连在一起

\n
1
2
3
{#、 #}、{#} 这三种情况都会导致系统奔溃
{} 和 # 之间如果有别的字符就不会。如 { # }
或者放在代码段内也不会。行内代码不能避免这种情形。
\n","site":{"data":{}},"excerpt":"","more":"

复制MD文件

\n\n

查找最新文件

\n\n

其它

\n

Hexo 代码折叠

\n\n

参考文件

\n

有用的shell命令

\n

会导致编译奔溃的错误

\n

大括号和井号连在一起

\n\n"},{"title":"《驴得水》——影评","date":"2019-07-28T13:17:19.000Z","urlname":"lvdeshui-film","_content":"\n![](https://github.com/maiernte/img/raw/master/collection/%E9%A9%B4%E5%BE%97%E6%B0%B4%E5%89%A7%E7%85%A7.jpg)\n\n\n\n> 追求自由的人,疯了,死了。\n不愿低头的人,成了听话的牲口。\n宽容大度的人,成了唯利是图的小人。\n淳朴憨厚的人,成了狡诈的恶棍。\n正面积极的人,用谎言掩盖真相。\n\n你觉得这是电影吗?其实,这是现实。我们先来看一下电影故事讲的是什么:\n\n一群怀揣伟大梦想的人,却敌不过山区缺水的现实,养了一头驴拉水。上头却不给养驴费,于是就把驴谎报成老师。上头来检查,不能因为一头驴毁了梦想啊。于是为了捍卫梦想的道路,却失去了梦想的意义。《驴得水》的海报上说,“讲个笑话,你可别哭啊”。 就像另一句笑话讲的那样, “小的时候我想拯救世界,长大后却发现世界都拯救不了我”。\n\n好笑,但却想哭。\n\n谁TM还没点梦想啊。但有时梦想很脆弱,甚至敌不过一碗炸酱面。你想让自己闪闪发光,但总得先养活自己,饿着肚子的人怎么去谈梦想?这也是很多刚毕业不久的人,所要面对的最为矛盾的情况。“我有很多想法,有很多想做的事。但我现在没钱、没人脉、没背景,甚至还没长相。想要出去闯一片天地, 但还要为一日三餐和落脚地打拼。梦想是高潮,现实却是性冷淡。还能怎么办呢?先养活自己再说吧”。于是,你找了一份莫名其妙的工作,你一日三餐是不愁了,你做着日复一日重复的工作,但是你不敢停,你越来越迷茫,越来越看不清生活的方向。\n\n你害怕那种怀揣梦想,但却又碌碌无为的日子,但你却不知道从哪里开始改变。于是你只能在焦虑中慢慢对现实妥协,然后你变成了自己曾经最讨厌的那种人。冷漠、没有激情、不思进取、浑浑噩噩,就像影片中的人物一样。曾经那些他们坚信的东西在面对现实时,都变得不堪一击。铁男说,“我没有办法啊,你知道子弹从脸上呼啸而过的感觉吗”?像不像我们经常说的,“我没办法啊,现实就是这样”。\n\n是啊,现实就是这样!作为芸芸众生,普通屁民,谁TM还没被现实强奸过啊。但想要活得更好,重要的不是治愈,而是带着病痛活下去。而且我们要清醒的认识到一个事实,有时我们之所以像傻逼一样努力,不是为了改变世界,而是为了不让世界改变我们。或许,这才是我们对这个世界最大的善意。\n","source":"_posts/摘录/《驴得水》影评.md","raw":"---\ntitle: 《驴得水》——影评\ndate: 2019-07-28 15:17:19\nurlname: lvdeshui-film\ntags: [影视]\ncategories: 摘录\n\n---\n\n![](https://github.com/maiernte/img/raw/master/collection/%E9%A9%B4%E5%BE%97%E6%B0%B4%E5%89%A7%E7%85%A7.jpg)\n\n\n\n> 追求自由的人,疯了,死了。\n不愿低头的人,成了听话的牲口。\n宽容大度的人,成了唯利是图的小人。\n淳朴憨厚的人,成了狡诈的恶棍。\n正面积极的人,用谎言掩盖真相。\n\n你觉得这是电影吗?其实,这是现实。我们先来看一下电影故事讲的是什么:\n\n一群怀揣伟大梦想的人,却敌不过山区缺水的现实,养了一头驴拉水。上头却不给养驴费,于是就把驴谎报成老师。上头来检查,不能因为一头驴毁了梦想啊。于是为了捍卫梦想的道路,却失去了梦想的意义。《驴得水》的海报上说,“讲个笑话,你可别哭啊”。 就像另一句笑话讲的那样, “小的时候我想拯救世界,长大后却发现世界都拯救不了我”。\n\n好笑,但却想哭。\n\n谁TM还没点梦想啊。但有时梦想很脆弱,甚至敌不过一碗炸酱面。你想让自己闪闪发光,但总得先养活自己,饿着肚子的人怎么去谈梦想?这也是很多刚毕业不久的人,所要面对的最为矛盾的情况。“我有很多想法,有很多想做的事。但我现在没钱、没人脉、没背景,甚至还没长相。想要出去闯一片天地, 但还要为一日三餐和落脚地打拼。梦想是高潮,现实却是性冷淡。还能怎么办呢?先养活自己再说吧”。于是,你找了一份莫名其妙的工作,你一日三餐是不愁了,你做着日复一日重复的工作,但是你不敢停,你越来越迷茫,越来越看不清生活的方向。\n\n你害怕那种怀揣梦想,但却又碌碌无为的日子,但你却不知道从哪里开始改变。于是你只能在焦虑中慢慢对现实妥协,然后你变成了自己曾经最讨厌的那种人。冷漠、没有激情、不思进取、浑浑噩噩,就像影片中的人物一样。曾经那些他们坚信的东西在面对现实时,都变得不堪一击。铁男说,“我没有办法啊,你知道子弹从脸上呼啸而过的感觉吗”?像不像我们经常说的,“我没办法啊,现实就是这样”。\n\n是啊,现实就是这样!作为芸芸众生,普通屁民,谁TM还没被现实强奸过啊。但想要活得更好,重要的不是治愈,而是带着病痛活下去。而且我们要清醒的认识到一个事实,有时我们之所以像傻逼一样努力,不是为了改变世界,而是为了不让世界改变我们。或许,这才是我们对这个世界最大的善意。\n","slug":"摘录/《驴得水》影评","published":1,"updated":"2019-08-15T21:48:56.000Z","_id":"cka1y594r00054huunm0reb46","comments":1,"layout":"post","photos":[],"link":"","content":"
\n

追求自由的人,疯了,死了。
\n不愿低头的人,成了听话的牲口。
\n宽容大度的人,成了唯利是图的小人。
\n淳朴憨厚的人,成了狡诈的恶棍。
\n正面积极的人,用谎言掩盖真相。

\n
\n

你觉得这是电影吗?其实,这是现实。我们先来看一下电影故事讲的是什么:

\n

一群怀揣伟大梦想的人,却敌不过山区缺水的现实,养了一头驴拉水。上头却不给养驴费,于是就把驴谎报成老师。上头来检查,不能因为一头驴毁了梦想啊。于是为了捍卫梦想的道路,却失去了梦想的意义。《驴得水》的海报上说,“讲个笑话,你可别哭啊”。 就像另一句笑话讲的那样, “小的时候我想拯救世界,长大后却发现世界都拯救不了我”。

\n

好笑,但却想哭。

\n

谁TM还没点梦想啊。但有时梦想很脆弱,甚至敌不过一碗炸酱面。你想让自己闪闪发光,但总得先养活自己,饿着肚子的人怎么去谈梦想?这也是很多刚毕业不久的人,所要面对的最为矛盾的情况。“我有很多想法,有很多想做的事。但我现在没钱、没人脉、没背景,甚至还没长相。想要出去闯一片天地, 但还要为一日三餐和落脚地打拼。梦想是高潮,现实却是性冷淡。还能怎么办呢?先养活自己再说吧”。于是,你找了一份莫名其妙的工作,你一日三餐是不愁了,你做着日复一日重复的工作,但是你不敢停,你越来越迷茫,越来越看不清生活的方向。

\n

你害怕那种怀揣梦想,但却又碌碌无为的日子,但你却不知道从哪里开始改变。于是你只能在焦虑中慢慢对现实妥协,然后你变成了自己曾经最讨厌的那种人。冷漠、没有激情、不思进取、浑浑噩噩,就像影片中的人物一样。曾经那些他们坚信的东西在面对现实时,都变得不堪一击。铁男说,“我没有办法啊,你知道子弹从脸上呼啸而过的感觉吗”?像不像我们经常说的,“我没办法啊,现实就是这样”。

\n

是啊,现实就是这样!作为芸芸众生,普通屁民,谁TM还没被现实强奸过啊。但想要活得更好,重要的不是治愈,而是带着病痛活下去。而且我们要清醒的认识到一个事实,有时我们之所以像傻逼一样努力,不是为了改变世界,而是为了不让世界改变我们。或许,这才是我们对这个世界最大的善意。

","site":{"data":{}},"excerpt":"

","more":"
\n

追求自由的人,疯了,死了。
\n不愿低头的人,成了听话的牲口。
\n宽容大度的人,成了唯利是图的小人。
\n淳朴憨厚的人,成了狡诈的恶棍。
\n正面积极的人,用谎言掩盖真相。

\n
\n

你觉得这是电影吗?其实,这是现实。我们先来看一下电影故事讲的是什么:

\n

一群怀揣伟大梦想的人,却敌不过山区缺水的现实,养了一头驴拉水。上头却不给养驴费,于是就把驴谎报成老师。上头来检查,不能因为一头驴毁了梦想啊。于是为了捍卫梦想的道路,却失去了梦想的意义。《驴得水》的海报上说,“讲个笑话,你可别哭啊”。 就像另一句笑话讲的那样, “小的时候我想拯救世界,长大后却发现世界都拯救不了我”。

\n

好笑,但却想哭。

\n

谁TM还没点梦想啊。但有时梦想很脆弱,甚至敌不过一碗炸酱面。你想让自己闪闪发光,但总得先养活自己,饿着肚子的人怎么去谈梦想?这也是很多刚毕业不久的人,所要面对的最为矛盾的情况。“我有很多想法,有很多想做的事。但我现在没钱、没人脉、没背景,甚至还没长相。想要出去闯一片天地, 但还要为一日三餐和落脚地打拼。梦想是高潮,现实却是性冷淡。还能怎么办呢?先养活自己再说吧”。于是,你找了一份莫名其妙的工作,你一日三餐是不愁了,你做着日复一日重复的工作,但是你不敢停,你越来越迷茫,越来越看不清生活的方向。

\n

你害怕那种怀揣梦想,但却又碌碌无为的日子,但你却不知道从哪里开始改变。于是你只能在焦虑中慢慢对现实妥协,然后你变成了自己曾经最讨厌的那种人。冷漠、没有激情、不思进取、浑浑噩噩,就像影片中的人物一样。曾经那些他们坚信的东西在面对现实时,都变得不堪一击。铁男说,“我没有办法啊,你知道子弹从脸上呼啸而过的感觉吗”?像不像我们经常说的,“我没办法啊,现实就是这样”。

\n

是啊,现实就是这样!作为芸芸众生,普通屁民,谁TM还没被现实强奸过啊。但想要活得更好,重要的不是治愈,而是带着病痛活下去。而且我们要清醒的认识到一个事实,有时我们之所以像傻逼一样努力,不是为了改变世界,而是为了不让世界改变我们。或许,这才是我们对这个世界最大的善意。

"},{"title":"典故","date":"2019-07-29T06:45:50.000Z","urlname":"old-stories-collection","toc":true,"notshow":true,"_content":"\n###### 豫让刺赵简子\n\n晋毕阳之孙豫让,始事范、中行氏而不说,去而就知伯,知伯宠之。及三晋分知氏,赵襄子最恐知伯,而将其头以为饮器。豫让遁逃山中曰:“磋乎!士为知己者死,女为悦己者容。吾其报知氏之仇矣。”\n\n\n\n乃变姓名,为刑人,入宫涂厕,欲以刺襄子。 襄子如厕,心动,执问涂者,则豫让也。 刃其曰:“欲为知伯报仇!”左右欲杀之。 赵襄子曰:“彼义士也,吾谨避之耳。且知伯已死,无后,而其臣至为报仇,此天下之贤人也。”卒释之。 豫让又漆身为厉,灭须去眉,自刑以变其容,为乞人而往乞,其妻不识,曰:“状貌不似吾夫,其音何类吾夫之甚也。”又吞炭为哑,变其音。 其友谓之曰:“子之道甚难而无功,谓子有志,则然矣,谓子知,则否。以子之才,而善事襄子,襄子必近幸子;子之得近而行所欲,此甚易而功必成。”豫让乃笑而应之曰:“是为先知报后知,为故君贼新君,大乱君臣之义者无此矣。凡吾所谓为此者,以明君臣之义,非从易也。且夫委质而事人,而求弑之,是怀二心以事君也。吾所为难,亦将以愧天下后世人臣怀二心者。”\n\n居顷之,襄子当出,豫让伏所当过桥下。 襄子至桥而马惊。 襄子曰:“此必豫让也。”使人问之,果豫让。 于是赵襄子面数豫让曰:“子不尝事范中行氏乎?知伯灭范中行氏,而子不为报仇,反委质事知伯。知伯已死,子独何为报仇之深也?”豫让曰:“臣事范中行氏,范中行氏以众人遇臣,臣故众人报之;知伯以国士遇臣,臣故国士报之。”襄子乃喟然叹泣曰:“嗟乎,豫子!豫子之为知伯,名既成矣,寡人舍子,亦以足矣。子自为计,寡人不舍子。”使兵环之。 豫让曰:“臣闻明主不掩人之义,忠臣不爱死以成名。君前已宽舍臣,天下莫不称君之贤。今日之事,臣故伏诛,然愿请君之衣而击之,虽死不恨。非所望也,敢布腹心。”于是襄子义之,乃使使者持衣与豫让。 豫让拔剑三跃,呼天击之曰:“而可以报知伯矣。”遂伏剑而死。 死之日,赵国之士闻之,皆为涕泣。\n\n—— 《战国策》\n","source":"_posts/摘录/典故.md","raw":"---\ntitle: 典故\ndate: 2019-07-29 08:45:50\nurlname: old-stories-collection\ntoc: true\ntags: [历史政治]\ncategories: [摘录]\nnotshow: true\n\n---\n\n###### 豫让刺赵简子\n\n晋毕阳之孙豫让,始事范、中行氏而不说,去而就知伯,知伯宠之。及三晋分知氏,赵襄子最恐知伯,而将其头以为饮器。豫让遁逃山中曰:“磋乎!士为知己者死,女为悦己者容。吾其报知氏之仇矣。”\n\n\n\n乃变姓名,为刑人,入宫涂厕,欲以刺襄子。 襄子如厕,心动,执问涂者,则豫让也。 刃其曰:“欲为知伯报仇!”左右欲杀之。 赵襄子曰:“彼义士也,吾谨避之耳。且知伯已死,无后,而其臣至为报仇,此天下之贤人也。”卒释之。 豫让又漆身为厉,灭须去眉,自刑以变其容,为乞人而往乞,其妻不识,曰:“状貌不似吾夫,其音何类吾夫之甚也。”又吞炭为哑,变其音。 其友谓之曰:“子之道甚难而无功,谓子有志,则然矣,谓子知,则否。以子之才,而善事襄子,襄子必近幸子;子之得近而行所欲,此甚易而功必成。”豫让乃笑而应之曰:“是为先知报后知,为故君贼新君,大乱君臣之义者无此矣。凡吾所谓为此者,以明君臣之义,非从易也。且夫委质而事人,而求弑之,是怀二心以事君也。吾所为难,亦将以愧天下后世人臣怀二心者。”\n\n居顷之,襄子当出,豫让伏所当过桥下。 襄子至桥而马惊。 襄子曰:“此必豫让也。”使人问之,果豫让。 于是赵襄子面数豫让曰:“子不尝事范中行氏乎?知伯灭范中行氏,而子不为报仇,反委质事知伯。知伯已死,子独何为报仇之深也?”豫让曰:“臣事范中行氏,范中行氏以众人遇臣,臣故众人报之;知伯以国士遇臣,臣故国士报之。”襄子乃喟然叹泣曰:“嗟乎,豫子!豫子之为知伯,名既成矣,寡人舍子,亦以足矣。子自为计,寡人不舍子。”使兵环之。 豫让曰:“臣闻明主不掩人之义,忠臣不爱死以成名。君前已宽舍臣,天下莫不称君之贤。今日之事,臣故伏诛,然愿请君之衣而击之,虽死不恨。非所望也,敢布腹心。”于是襄子义之,乃使使者持衣与豫让。 豫让拔剑三跃,呼天击之曰:“而可以报知伯矣。”遂伏剑而死。 死之日,赵国之士闻之,皆为涕泣。\n\n—— 《战国策》\n","slug":"摘录/典故","published":1,"updated":"2019-07-31T03:51:35.000Z","_id":"cka1y594x00084huu6k4ch39z","comments":1,"layout":"post","photos":[],"link":"","content":"
豫让刺赵简子
\n

晋毕阳之孙豫让,始事范、中行氏而不说,去而就知伯,知伯宠之。及三晋分知氏,赵襄子最恐知伯,而将其头以为饮器。豫让遁逃山中曰:“磋乎!士为知己者死,女为悦己者容。吾其报知氏之仇矣。”

\n\n

乃变姓名,为刑人,入宫涂厕,欲以刺襄子。 襄子如厕,心动,执问涂者,则豫让也。 刃其曰:“欲为知伯报仇!”左右欲杀之。 赵襄子曰:“彼义士也,吾谨避之耳。且知伯已死,无后,而其臣至为报仇,此天下之贤人也。”卒释之。 豫让又漆身为厉,灭须去眉,自刑以变其容,为乞人而往乞,其妻不识,曰:“状貌不似吾夫,其音何类吾夫之甚也。”又吞炭为哑,变其音。 其友谓之曰:“子之道甚难而无功,谓子有志,则然矣,谓子知,则否。以子之才,而善事襄子,襄子必近幸子;子之得近而行所欲,此甚易而功必成。”豫让乃笑而应之曰:“是为先知报后知,为故君贼新君,大乱君臣之义者无此矣。凡吾所谓为此者,以明君臣之义,非从易也。且夫委质而事人,而求弑之,是怀二心以事君也。吾所为难,亦将以愧天下后世人臣怀二心者。”

\n

居顷之,襄子当出,豫让伏所当过桥下。 襄子至桥而马惊。 襄子曰:“此必豫让也。”使人问之,果豫让。 于是赵襄子面数豫让曰:“子不尝事范中行氏乎?知伯灭范中行氏,而子不为报仇,反委质事知伯。知伯已死,子独何为报仇之深也?”豫让曰:“臣事范中行氏,范中行氏以众人遇臣,臣故众人报之;知伯以国士遇臣,臣故国士报之。”襄子乃喟然叹泣曰:“嗟乎,豫子!豫子之为知伯,名既成矣,寡人舍子,亦以足矣。子自为计,寡人不舍子。”使兵环之。 豫让曰:“臣闻明主不掩人之义,忠臣不爱死以成名。君前已宽舍臣,天下莫不称君之贤。今日之事,臣故伏诛,然愿请君之衣而击之,虽死不恨。非所望也,敢布腹心。”于是襄子义之,乃使使者持衣与豫让。 豫让拔剑三跃,呼天击之曰:“而可以报知伯矣。”遂伏剑而死。 死之日,赵国之士闻之,皆为涕泣。

\n

—— 《战国策》

\n","site":{"data":{}},"excerpt":"
豫让刺赵简子
\n

晋毕阳之孙豫让,始事范、中行氏而不说,去而就知伯,知伯宠之。及三晋分知氏,赵襄子最恐知伯,而将其头以为饮器。豫让遁逃山中曰:“磋乎!士为知己者死,女为悦己者容。吾其报知氏之仇矣。”

","more":"

乃变姓名,为刑人,入宫涂厕,欲以刺襄子。 襄子如厕,心动,执问涂者,则豫让也。 刃其曰:“欲为知伯报仇!”左右欲杀之。 赵襄子曰:“彼义士也,吾谨避之耳。且知伯已死,无后,而其臣至为报仇,此天下之贤人也。”卒释之。 豫让又漆身为厉,灭须去眉,自刑以变其容,为乞人而往乞,其妻不识,曰:“状貌不似吾夫,其音何类吾夫之甚也。”又吞炭为哑,变其音。 其友谓之曰:“子之道甚难而无功,谓子有志,则然矣,谓子知,则否。以子之才,而善事襄子,襄子必近幸子;子之得近而行所欲,此甚易而功必成。”豫让乃笑而应之曰:“是为先知报后知,为故君贼新君,大乱君臣之义者无此矣。凡吾所谓为此者,以明君臣之义,非从易也。且夫委质而事人,而求弑之,是怀二心以事君也。吾所为难,亦将以愧天下后世人臣怀二心者。”

\n

居顷之,襄子当出,豫让伏所当过桥下。 襄子至桥而马惊。 襄子曰:“此必豫让也。”使人问之,果豫让。 于是赵襄子面数豫让曰:“子不尝事范中行氏乎?知伯灭范中行氏,而子不为报仇,反委质事知伯。知伯已死,子独何为报仇之深也?”豫让曰:“臣事范中行氏,范中行氏以众人遇臣,臣故众人报之;知伯以国士遇臣,臣故国士报之。”襄子乃喟然叹泣曰:“嗟乎,豫子!豫子之为知伯,名既成矣,寡人舍子,亦以足矣。子自为计,寡人不舍子。”使兵环之。 豫让曰:“臣闻明主不掩人之义,忠臣不爱死以成名。君前已宽舍臣,天下莫不称君之贤。今日之事,臣故伏诛,然愿请君之衣而击之,虽死不恨。非所望也,敢布腹心。”于是襄子义之,乃使使者持衣与豫让。 豫让拔剑三跃,呼天击之曰:“而可以报知伯矣。”遂伏剑而死。 死之日,赵国之士闻之,皆为涕泣。

\n

—— 《战国策》

"},{"title":"RZF Organisation","urlname":"rzf-organisation","toc":true,"notshow":true,"date":"2019-07-22T18:23:00.000Z","_content":"\n# Kontakt\n\n## Abteilung\n- Verteiler \"**V-Krank**\"\n Für Ihre Krank- bzw. Gesundmeldung sowie alle übrigen Mitteilungen zum Thema Krankheit nutzen Sie bitte den Verteiler V-Krank (V-Krank-5011@fv.nrw.de).\n- Verteiler \"**V-Heimarbeitszeiten**\"\n Für die Meldung der Heimarbeitszeiten nutzen Sie bitte den Verteiler V-Heimarbeitszeiten (V-Heimarbeitszeiten-5011@fv.nrw.de).\n- Verteiler \"**V-Dienstreisezeiten**\"\n Über den Verteiler V-Dienstreisezeiten (V-Dienstreisezeiten-5011@fv.nrw.de) teilen Sie bitte Ihre Dienstreisezeiten, Lehrgangzeiten sowie das Ende des Dienstgeschäftes bei Dienstgängen mit. Zur Berechnung der Reisezeiten nutzen Sie bitte das im OASE-Vordruckschrank hinterlegte Berechnungsblatt (Vordruck H76 Reisezeitenberechnung).\n- Verteiler \"**V-GST**\"\n Den Verteiler V-GST (V-GST-5011@fv.nrw.de) verwenden Sie insbesondere für die nachfolgenden Angelegenheiten:\n Fragen/Mitteilungen zum Thema Urlaub, Sonderurlaub, Dienstbefreiung\n - Mitteilung von Zeiten bei vergessenen oder fehlerhaften GLAZ-Buchungen\n - Mitteilung über die ganztägige Kernzeitinanspruchnahme (GLAZ-Tag)\n - alle Fragen/Mitteilungen zu den übrigen Personalangelegenheiten, die nicht über die vorgenannten Verteiler abgedeckt sind.\n\n## Personal\n### Rohde, Rainer\nTelefon : (0211) 4572 - 2554\nE-Mail: rainer.rohde@fv.nrw.de\n### Uphoff, Christian\nchristian.uphoff@fv.nrw.de\n\n\\Drucker \\C0114237\\DR011226","source":"_posts/文档/RZF-Organisation.md","raw":"---\ntitle: RZF Organisation\nurlname: rzf-organisation\ntoc: true\ntags: [工作]\ncategories: 文档\nnotshow: true\ndate: 2019-07-22 20:23:00\n\n---\n\n# Kontakt\n\n## Abteilung\n- Verteiler \"**V-Krank**\"\n Für Ihre Krank- bzw. Gesundmeldung sowie alle übrigen Mitteilungen zum Thema Krankheit nutzen Sie bitte den Verteiler V-Krank (V-Krank-5011@fv.nrw.de).\n- Verteiler \"**V-Heimarbeitszeiten**\"\n Für die Meldung der Heimarbeitszeiten nutzen Sie bitte den Verteiler V-Heimarbeitszeiten (V-Heimarbeitszeiten-5011@fv.nrw.de).\n- Verteiler \"**V-Dienstreisezeiten**\"\n Über den Verteiler V-Dienstreisezeiten (V-Dienstreisezeiten-5011@fv.nrw.de) teilen Sie bitte Ihre Dienstreisezeiten, Lehrgangzeiten sowie das Ende des Dienstgeschäftes bei Dienstgängen mit. Zur Berechnung der Reisezeiten nutzen Sie bitte das im OASE-Vordruckschrank hinterlegte Berechnungsblatt (Vordruck H76 Reisezeitenberechnung).\n- Verteiler \"**V-GST**\"\n Den Verteiler V-GST (V-GST-5011@fv.nrw.de) verwenden Sie insbesondere für die nachfolgenden Angelegenheiten:\n Fragen/Mitteilungen zum Thema Urlaub, Sonderurlaub, Dienstbefreiung\n - Mitteilung von Zeiten bei vergessenen oder fehlerhaften GLAZ-Buchungen\n - Mitteilung über die ganztägige Kernzeitinanspruchnahme (GLAZ-Tag)\n - alle Fragen/Mitteilungen zu den übrigen Personalangelegenheiten, die nicht über die vorgenannten Verteiler abgedeckt sind.\n\n## Personal\n### Rohde, Rainer\nTelefon : (0211) 4572 - 2554\nE-Mail: rainer.rohde@fv.nrw.de\n### Uphoff, Christian\nchristian.uphoff@fv.nrw.de\n\n\\Drucker \\C0114237\\DR011226","slug":"文档/RZF-Organisation","published":1,"updated":"2019-08-22T08:39:21.000Z","_id":"cka1y595000094huuoh5kztsj","comments":1,"layout":"post","photos":[],"link":"","content":"

Kontakt

\n

Abteilung

\n\n

Personal

\n

Rohde, Rainer

\n

Telefon : (0211) 4572 - 2554
\nE-Mail: rainer.rohde@fv.nrw.de

\n

Uphoff, Christian

\n

christian.uphoff@fv.nrw.de

\n

\\Drucker \\C0114237\\DR011226

\n","site":{"data":{}},"excerpt":"","more":"

Kontakt

\n

Abteilung

\n\n

Personal

\n

Rohde, Rainer

\n

Telefon : (0211) 4572 - 2554
\nE-Mail: rainer.rohde@fv.nrw.de

\n

Uphoff, Christian

\n

christian.uphoff@fv.nrw.de

\n

\\Drucker \\C0114237\\DR011226

\n"},{"title":"Hello World","urlname":"hellow-world","date":"2019-06-26T15:51:03.000Z","sage":false,"notshow":true,"password":123456,"abstract":"此文章含敏感性描述。","message":"输入通用密码,查看文章。","_content":"Welcome to [Hexo](https://hexo.io/)! This is your very first post. Check [documentation](https://hexo.io/docs/) for more info. If you get any problems when using Hexo, you can find the answer in [troubleshooting](https://hexo.io/docs/troubleshooting.html) or you can ask me on [GitHub](https://github.com/hexojs/hexo/issues).\n\n## Quick Start\n\n### Create a new post\n\n``` bash\n$ hexo new \"My New Post\"\n```\n\nMore info: [Writing](https://hexo.io/docs/writing.html)\n\n### Run server\n\n``` bash\n$ hexo server\n```\n\nMore info: [Server](https://hexo.io/docs/server.html)\n\n### Generate static files\n\n``` bash\n$ hexo generate\n```\n\nMore info: [Generating](https://hexo.io/docs/generating.html)\n\n### Deploy to remote sites\n\n``` bash\n$ hexo deploy\n```\n\nMore info: [Deployment](https://hexo.io/docs/deployment.html)\n","source":"_posts/随笔/hello-world.md","raw":"---\ntitle: Hello World\nurlname: hellow-world\ndate: 2019-06-26 17:51:03\ntags: [Hexo]\ncategories: 随笔\nsage: false\nnotshow: true\npassword: 123456\nabstract: 此文章含敏感性描述。\nmessage: 输入通用密码,查看文章。\n\n---\nWelcome to [Hexo](https://hexo.io/)! This is your very first post. Check [documentation](https://hexo.io/docs/) for more info. If you get any problems when using Hexo, you can find the answer in [troubleshooting](https://hexo.io/docs/troubleshooting.html) or you can ask me on [GitHub](https://github.com/hexojs/hexo/issues).\n\n## Quick Start\n\n### Create a new post\n\n``` bash\n$ hexo new \"My New Post\"\n```\n\nMore info: [Writing](https://hexo.io/docs/writing.html)\n\n### Run server\n\n``` bash\n$ hexo server\n```\n\nMore info: [Server](https://hexo.io/docs/server.html)\n\n### Generate static files\n\n``` bash\n$ hexo generate\n```\n\nMore info: [Generating](https://hexo.io/docs/generating.html)\n\n### Deploy to remote sites\n\n``` bash\n$ hexo deploy\n```\n\nMore info: [Deployment](https://hexo.io/docs/deployment.html)\n","slug":"随笔/hello-world","published":1,"updated":"2019-07-31T03:51:35.000Z","_id":"cka1y5952000a4huuo6qb7h3o","comments":1,"layout":"post","photos":[],"link":"","content":"\n
\n
\n \n \n
\n
\n
\n
Incorrect Password!
\n
No content to display!
\n
\nU2FsdGVkX1+7TT9oNPf8Ce6TsmnuE5YQQXxozWhmsuuF8mq1PvXU4mByRPaYweIRznY6oCgPv8PipL/etOooY2bmAe5/3BxQPyniuSdeXJ0C8awHa6up+5gRmhbjHKwIyovE/4OXJCIEADUg4aMBMa9uSdqheJEgFVNyPPHF0SaFQ52G3ucPq54SmB4P4g9x3NQUTCy3LZOw3KP4fN3hEQXaitjd6Cn6Lm9AmvAzXtLiGjHUcV6IuwFqWko+akLURrPiZQDdJ6Wses5F/+F8sPMAcYdJQsn0nRpUhtggnhCysFe8FBNX9eoICJITSymRzNMIymZvJi+1q8pVPEj89QDy91U9gQwoHEy1G7bGNr4dnS+l7KWbill6olGvfwu7rJbMgUnnEiu/7B511/VkDVUSUVlggncrZ/KEU4XT8Gx4OYLgZfS7r9uNDceAq694BMF4m1dVeagck8ls2+DCVvQRe3ciyrHhrkK1ouAwMxYcf1IR8kCyyScnx4X4XIk+5P2KhjZiP+z0pb0GWxX30qVUHsQrCveU0Amhdc2F70VRUghCOo83gRWgs8HlQXaqWmTPJmrFkOuKELGTlW08UKA6RR7Wx21bZcH9k+ZVxatWfUhob3K9hZuROPfo5t/xFby5Jp035iZggzfT3J7Zj22X0WD1+mTIepPLg98r6WFGnIVadH4o1kQOSX6zUrknvBqVVm4toRD25n2RgCw0EpxpAmyyvFe6nDVqrCIpe9W4NkfYXM+yR5oclXdvAdOB9M3FFc1iizhNZzCrWNI2c+m+DGnqeKBHb5AB/cpbv0RdolELqm9KsuoE3GHMBFZp78H1ef+4SNONQVKmaiTrI2WBiGvhGYcQd8xHtq3uCDf99oREjkBDn86xTCk0KgrAg53Ijn5k0+P/PehZStsYZc5ysJxIgaANrW+hyuSwPblwsHUBUEGm/ZB84NvzgIZPYLVWqC+6ujB10CAY0M3XOGo2u8U2VZ5IAD27XMiwZC+pLJBHQFFwsO2T99xuJw1OBWF9BhslpeMtxIRByV1z/6znnolei0ZgDIPCcbEeuqJb7zeoWp70sdEZQGHI5BNOEew2uCpLJjw5uaVGZCY0uZkLYBW5XD0WlOpXbqqPIrRT/naYC3YywZCBOenymdhbRKlCHoopCccLbfgFQJqDvlVQen3fA/eqnmw37wk8j7XKHb4nKIOl1q6P2YFQ+qVNNb1qiIC66SNXqrbyNWHyhDkqFSlzcrJAcSqTVtCsVqhw42BotrpjPiJ/8Zyq4aSfnR6G+eZsznHvoGqM237/Vy/faDFZTA6d/MrkExzhwjllt1svb00ZBFyF2CNv5H9daJ1EvG+HZXhPKOVq/ryYh59UXG3ypmIvKlMXjzzMHKwLfYHeel8s8kjel7u2iGAXML5uSbaCqCmfIxAazPuKhlapElEGH2AgjNRqwLoM3BH+Nq5rgYlVQkmympCoOSgTquAx6hxsiUId+sL5nCAkGb5flhQdChPYAvlhLVVaMUesmJuUF4OqAmY4sfd5BHR2uCmdSYTaborGQtTIEhnwcpUF6qYVrwes4K8nOYXZKGk6ELLHa1IlChe70KxP6qHeQ3Xq+X4teFvbcyZ/3z6SDNhob1WLAfYb2szPGOVtdT3DEsFw7YHGhgcI5X1njL4b4Vkd3Fd98PZQdrgfZlB8QO5/YC75EgdfDFqUgaR86+9Sa6AzFlXvZscPtgPMvG6RIveULyZDflsFgCqJy9W3UiU9H9wiEb+9tPEgRlf0SZ4F0V3lqksOdj6qEv6YM4KtFF1Y+mlSocp0tCIW2PcwUcJPMB54y5NwI7Qji6FbP/SmYkHBOS2HAAKyx3dnxuoIJneAfQOT70PoXt8YVxZyPtg17hcLlORU/KqcGXZhks9VvS/4bbsM5CLH6wJUAeom/NOZZkMQgK/KAiUL4WM6bjLaMYCFx/bt6WAPYeFYFZ3wyQrAhd+EFs68+79klIdtzNYivK+j3GuIRfAF+/rhqZ6ISgQEBqD6AmlRnRsFaW8AKier61VuISlGlJ3WebWf/DViHUI5RrxNJnZDLGT6ENuGvYmzVRWOsoks3tObuimBl4G7ZZVxYNCrm+uSJQ34dh+f0rg7ckoANFDBHnZsDsIF/4doX/umiCMPufqfZIKDaJKnVzd8SdiArq9vprdrDNLYHhz+I6vM8IW3ZILl0rQFx6enT4XvVeuG1fiY30b6wzNqH21Mp6w3nSpVu0tZ82R79xr1iQn9KT+ekQCqwJNGbp9yRurcB3Myv78DEN0329B+eNUXqtc64xivaiIMOHMxOVHu6UGPryNFvA+iKrBM1a5DXyjkJwOIGzIoqf0Y8vDlB92PScUk4pVymupZ5BTBk++ziHDir/CkkALuBsJqe+Z7Ct/tvAsVUbsbJPO+4bY8W0ZK++cUh8Y32x62D2j7M1nQ4wpcxsmIPngGVsuFT41WCSF6d4u56Brz+DVdBpsiMODiXQr74zKFWubjzkSou9f11FLr2dnjhx1DrGNn1mqsx0gRBWBKtdFc849injMomeJrCUhaPwV4f3EjkMrsMi3x0MzV0xBvf2ktwNck+eTY6AQa1UvH63Cka9J7Z8DsciBgkCNkd7exgtboc6bqI7c2Ai4/HMP+hQtdYg0uie7GBbRdOVqhuR++GZL6UBrEois54aUPJxK6Xype6v7qHIf3XSH7NR5qlLIOcPE6rp7lfdhUvB9mkJ5jQ1phkJjkbZ0HcohfzhlledQb5njrA6JndP0+3eKyvwLYuZxCup92FrS6X+u/PVFkuUD/y9PNmU/RsJrRsGWt0qPSvyRIzVKFdP6tdvwkUYHdHlbe0/Y5TXcGUyB0tuNCBNsJXLZvQq+3vZ8MI8ZQW7I7zpbwcIvK/n1HEISPZF974e7CROWpAcUSKFYzoC7QF4kDDbab5mbetaWclUh7qMOt0q5orAGCMTcejIRGivHMODoq6S8eeExpVqSEwn7OTsDk02z6k7kWjANzYSpClR6RGgHJa0aFNoAbFeo83/p21XFcLL/eVCrfku5kEOfyERL/nuycdX/g/rVmgxL8Lskvql8HJAxy4bzQARWazQn9xGqLnVQGjmuTETf7A1I/IcxIdV+7ojCQxb5rLxVcUiQLOMgqb74XJzDtMgBqXkRUVnVwHPosQg8L4eYg9wgUET1jQayMzEeR+e22wvEMDvM2qz7yffFtpI4B3xRIbTsDJA==\n
\n","site":{"data":{}},"excerpt":"此文章含敏感性描述。","more":"此文章含敏感性描述。","origin":"

Welcome to Hexo! This is your very first post. Check documentation for more info. If you get any problems when using Hexo, you can find the answer in troubleshooting or you can ask me on GitHub.

\n

Quick Start

\n

Create a new post

\n\n

More info: Writing

\n

Run server

\n\n

More info: Server

\n

Generate static files

\n\n

More info: Generating

\n

Deploy to remote sites

\n\n

More info: Deployment

\n","encrypt":true,"template":"\n
\n
\n \n \n
\n
\n
\n
Incorrect Password!
\n
No content to display!
\n
\nU2FsdGVkX1+7TT9oNPf8Ce6TsmnuE5YQQXxozWhmsuuF8mq1PvXU4mByRPaYweIRznY6oCgPv8PipL/etOooY2bmAe5/3BxQPyniuSdeXJ0C8awHa6up+5gRmhbjHKwIyovE/4OXJCIEADUg4aMBMa9uSdqheJEgFVNyPPHF0SaFQ52G3ucPq54SmB4P4g9x3NQUTCy3LZOw3KP4fN3hEQXaitjd6Cn6Lm9AmvAzXtLiGjHUcV6IuwFqWko+akLURrPiZQDdJ6Wses5F/+F8sPMAcYdJQsn0nRpUhtggnhCysFe8FBNX9eoICJITSymRzNMIymZvJi+1q8pVPEj89QDy91U9gQwoHEy1G7bGNr4dnS+l7KWbill6olGvfwu7rJbMgUnnEiu/7B511/VkDVUSUVlggncrZ/KEU4XT8Gx4OYLgZfS7r9uNDceAq694BMF4m1dVeagck8ls2+DCVvQRe3ciyrHhrkK1ouAwMxYcf1IR8kCyyScnx4X4XIk+5P2KhjZiP+z0pb0GWxX30qVUHsQrCveU0Amhdc2F70VRUghCOo83gRWgs8HlQXaqWmTPJmrFkOuKELGTlW08UKA6RR7Wx21bZcH9k+ZVxatWfUhob3K9hZuROPfo5t/xFby5Jp035iZggzfT3J7Zj22X0WD1+mTIepPLg98r6WFGnIVadH4o1kQOSX6zUrknvBqVVm4toRD25n2RgCw0EpxpAmyyvFe6nDVqrCIpe9W4NkfYXM+yR5oclXdvAdOB9M3FFc1iizhNZzCrWNI2c+m+DGnqeKBHb5AB/cpbv0RdolELqm9KsuoE3GHMBFZp78H1ef+4SNONQVKmaiTrI2WBiGvhGYcQd8xHtq3uCDf99oREjkBDn86xTCk0KgrAg53Ijn5k0+P/PehZStsYZc5ysJxIgaANrW+hyuSwPblwsHUBUEGm/ZB84NvzgIZPYLVWqC+6ujB10CAY0M3XOGo2u8U2VZ5IAD27XMiwZC+pLJBHQFFwsO2T99xuJw1OBWF9BhslpeMtxIRByV1z/6znnolei0ZgDIPCcbEeuqJb7zeoWp70sdEZQGHI5BNOEew2uCpLJjw5uaVGZCY0uZkLYBW5XD0WlOpXbqqPIrRT/naYC3YywZCBOenymdhbRKlCHoopCccLbfgFQJqDvlVQen3fA/eqnmw37wk8j7XKHb4nKIOl1q6P2YFQ+qVNNb1qiIC66SNXqrbyNWHyhDkqFSlzcrJAcSqTVtCsVqhw42BotrpjPiJ/8Zyq4aSfnR6G+eZsznHvoGqM237/Vy/faDFZTA6d/MrkExzhwjllt1svb00ZBFyF2CNv5H9daJ1EvG+HZXhPKOVq/ryYh59UXG3ypmIvKlMXjzzMHKwLfYHeel8s8kjel7u2iGAXML5uSbaCqCmfIxAazPuKhlapElEGH2AgjNRqwLoM3BH+Nq5rgYlVQkmympCoOSgTquAx6hxsiUId+sL5nCAkGb5flhQdChPYAvlhLVVaMUesmJuUF4OqAmY4sfd5BHR2uCmdSYTaborGQtTIEhnwcpUF6qYVrwes4K8nOYXZKGk6ELLHa1IlChe70KxP6qHeQ3Xq+X4teFvbcyZ/3z6SDNhob1WLAfYb2szPGOVtdT3DEsFw7YHGhgcI5X1njL4b4Vkd3Fd98PZQdrgfZlB8QO5/YC75EgdfDFqUgaR86+9Sa6AzFlXvZscPtgPMvG6RIveULyZDflsFgCqJy9W3UiU9H9wiEb+9tPEgRlf0SZ4F0V3lqksOdj6qEv6YM4KtFF1Y+mlSocp0tCIW2PcwUcJPMB54y5NwI7Qji6FbP/SmYkHBOS2HAAKyx3dnxuoIJneAfQOT70PoXt8YVxZyPtg17hcLlORU/KqcGXZhks9VvS/4bbsM5CLH6wJUAeom/NOZZkMQgK/KAiUL4WM6bjLaMYCFx/bt6WAPYeFYFZ3wyQrAhd+EFs68+79klIdtzNYivK+j3GuIRfAF+/rhqZ6ISgQEBqD6AmlRnRsFaW8AKier61VuISlGlJ3WebWf/DViHUI5RrxNJnZDLGT6ENuGvYmzVRWOsoks3tObuimBl4G7ZZVxYNCrm+uSJQ34dh+f0rg7ckoANFDBHnZsDsIF/4doX/umiCMPufqfZIKDaJKnVzd8SdiArq9vprdrDNLYHhz+I6vM8IW3ZILl0rQFx6enT4XvVeuG1fiY30b6wzNqH21Mp6w3nSpVu0tZ82R79xr1iQn9KT+ekQCqwJNGbp9yRurcB3Myv78DEN0329B+eNUXqtc64xivaiIMOHMxOVHu6UGPryNFvA+iKrBM1a5DXyjkJwOIGzIoqf0Y8vDlB92PScUk4pVymupZ5BTBk++ziHDir/CkkALuBsJqe+Z7Ct/tvAsVUbsbJPO+4bY8W0ZK++cUh8Y32x62D2j7M1nQ4wpcxsmIPngGVsuFT41WCSF6d4u56Brz+DVdBpsiMODiXQr74zKFWubjzkSou9f11FLr2dnjhx1DrGNn1mqsx0gRBWBKtdFc849injMomeJrCUhaPwV4f3EjkMrsMi3x0MzV0xBvf2ktwNck+eTY6AQa1UvH63Cka9J7Z8DsciBgkCNkd7exgtboc6bqI7c2Ai4/HMP+hQtdYg0uie7GBbRdOVqhuR++GZL6UBrEois54aUPJxK6Xype6v7qHIf3XSH7NR5qlLIOcPE6rp7lfdhUvB9mkJ5jQ1phkJjkbZ0HcohfzhlledQb5njrA6JndP0+3eKyvwLYuZxCup92FrS6X+u/PVFkuUD/y9PNmU/RsJrRsGWt0qPSvyRIzVKFdP6tdvwkUYHdHlbe0/Y5TXcGUyB0tuNCBNsJXLZvQq+3vZ8MI8ZQW7I7zpbwcIvK/n1HEISPZF974e7CROWpAcUSKFYzoC7QF4kDDbab5mbetaWclUh7qMOt0q5orAGCMTcejIRGivHMODoq6S8eeExpVqSEwn7OTsDk02z6k7kWjANzYSpClR6RGgHJa0aFNoAbFeo83/p21XFcLL/eVCrfku5kEOfyERL/nuycdX/g/rVmgxL8Lskvql8HJAxy4bzQARWazQn9xGqLnVQGjmuTETf7A1I/IcxIdV+7ojCQxb5rLxVcUiQLOMgqb74XJzDtMgBqXkRUVnVwHPosQg8L4eYg9wgUET1jQayMzEeR+e22wvEMDvM2qz7yffFtpI4B3xRIbTsDJA==\n
\n","decryptionError":"Incorrect Password!","noContentError":"No content to display!"},{"title":"爱乐之城——影评","date":"2019-07-21T19:17:19.000Z","urlname":"lalaland-film","_content":"\n![ ](https://github.com/maiernte/img/raw/master/collection/lalaland.jpg)\n\n\n\n我在凌晨三点醒来的夜里,想起已失去的你,曾经说着永远一起,现在却不再联系。如果当时的我们能少一些固执,是否会有更好的结局。\n\n洛杉矶,华纳兄弟电影厂旁边的咖啡馆,明星来往不息。一身素雅的米娅是这里的收银员。她的梦想就是成为一个知名演员及编剧。所以她经常请假去试镜,跑遍大大小小的片场。虽然每次她都充满希望,但现实却是四处碰壁。这天,又一次遭受打击的米娅垂头丧气回到家中。洗去一身疲态后,她站在镜子面前暗自神伤哼起歌来 。这时室友火急火燎的出现,邀请她一起去参加派对。本来心情极度郁闷的米娅不想去凑热闹。经不住一帮二货室友的游说,精心打扮一番后她们就出发了。\n\n洛杉矶的月色下,灯红酒绿,觥筹交错。但热闹是属于他们的,安静下来后她却感到愈加落寞。人潮中充斥着过剩的荷尔蒙,但却没有她想要的一双眼睛。世界瞬息万变,她却岿然不动。逃离狂欢派对后,违规停放的车子又被拖走。米娅只能走路回家,在安静的街头上。忽然一阵悠扬的钢琴声传来,如梦似幻,温润缠绵。米娅停下脚步,来到了一个毫不起眼的地下酒吧。一个优雅的男人坐在无人注意的角落里安静的弹奏着。此刻,全世界好像都暗了下来,只有他闪着耀眼的光芒。男人名叫塞巴斯汀,是一个爵士乐钢琴师。他对音乐有着自己独特的追求,不愿弹奏靡靡之音。可一曲弹罢,没有人为他鼓掌,他也被老板炒了鱿鱼。塞巴斯汀愤愤的离开,米娅鼓起勇气迎面走过去,想要认识这个让她着迷的男人。但一句话还没说完,男人就径直的走开了。米娅扑了个空,尴尬的站在那里不知所措。\n\n生活依然按部就班,米娅依然忙着追逐她的梦想。一次派对上,米娅又遇上了塞巴斯汀。他加入了一个爵士乐队,但他们的演奏依旧没人捧场。为了惩罚这个「严肃」的音乐人,也为了报复上次给她造成的尴尬,米娅点了一首非常不严肃的音乐,她甚至随着音乐舞动起来。而塞巴斯汀却站在那里既尴尬又无奈。米娅的行为让塞巴斯汀想起了那晚的无礼。他向米娅道了歉,两人算是相识了。聚会结束后,米娅又找不到车子,于是两人在夜色下散步。洛杉矶的夜色此刻显得如此迷人,在暧昧的氛围中,他们默契地跳着属于他们的舞蹈。\n\n第二天塞巴斯汀来到米娅工作的咖啡店,下班后他们一起在片场附近的街头闲聊,塞巴斯汀鼓励米娅给自己写剧本,而不是去演别人的剧本。自己给自己创造角色,说不定会有意想不到的效果。米娅也向塞巴斯汀坦白说,她讨厌爵士乐。于是固执的塞巴斯汀就带米娅来到一个演奏爵士乐的酒吧,他试图改变米娅对爵士乐的看法,向她解释爵士乐的起源。然而米娅还是不能理解,对音乐有执念的塞巴斯汀表示,他不想让爵士乐就此消亡,他想要创建自己的俱乐部,在那里只有纯粹的爵士乐,那是他一直以来的梦想。\n\n这天又一次试镜失败的米娅心情沮丧,经过电影院门口时,她想起和塞巴斯汀的电影院之约。顿时心情变得愉悦,这时几个月不见一次的男友却来接她一起吃饭。餐桌上米娅心不在焉,男友却把她晾在一边,自顾自的和哥哥聊天。而在电影院门口的塞巴斯汀焦急的等着米娅,此时餐厅传来了熟悉的曲子,那个夜晚塞巴斯汀弹奏的正是这首曲子。米娅随即起身跑了出去,穿过色彩缤纷的霓虹灯,她找到了失落的塞巴斯汀,此时的两个人根本无心观看电影。他们指尖轻触,随后十指紧扣,接着互相靠近……但灯光却忽然打开,两人无奈的相视一笑。之后米娅带着塞巴斯汀来到天文馆,他们在浪漫的氛围中翩翩起舞,魅惑的蓝色星空下,两人仿佛和整个宇宙融为一体。\n\n金风玉露终于相逢,热恋之吻甘之如饴。随后两人一边热恋,一边为各自的梦想努力。他们一起旅行、一起恶作剧,他们走遍大街小巷,他弹琴、她跳舞,在塞巴斯汀的影响下,米娅渐渐喜欢上了爵士乐。这天早上,塞巴斯汀无意中听到了米娅和她母亲的通话。米娅的母亲对她们的未来很担忧,因为塞巴斯汀没有稳定的工作。寥寥几句话,就将塞巴斯汀从梦中拉回现实。他接受了前乐队主唱的邀请,成为了他们的键盘手。但这就意味着塞巴斯汀必须放弃自己的坚持,跟着乐队的风格走。晚上回家的米娅,听到塞巴斯汀的琴声,感受到了他失落的情绪。无需过多的话语,米娅和着琴声唱着歌,这种默契让他们心照不宣。就这样两人互相鼓励,互相安慰,塞巴斯汀的乐队开始走红。米娅也陆陆续续接到了一些大大小小的角色。看着梦想之门慢慢打开,他们也变得越来越忙碌。乐队巡演时,米娅站在台下看着万众瞩目的塞巴斯汀,喧闹的人群,闪烁的灯光,流行的爵士乐,一切看起来都那么美好……台上的男人意气风发、星光闪耀,米娅却觉得和他有了距离。晚上回到家的米娅得到了一个大大的惊喜。忙碌的他们很久都没有见面了,塞巴斯汀明天一早又要离开,他想要让米娅跟他一起,米娅却问他喜不喜欢现在弹奏的音乐?但此时的塞巴斯汀已经尝到了名利带来的甜头,他放弃了曾经的梦想,也放弃了曾经的坚持。他以为这些是米娅想要的:稳定的生活,不菲的收入,以及聚少离多的爱情。他说以前那些梦想太虚无缥缈,现在他需要成熟起来。最后激动的塞巴斯汀对米娅说,你喜欢以前不堪的我,是因为相比而言,那会让你感觉自我良好。这句伤人的话使得他们关系僵化,接着米娅一声不响的离开。第二天在给乐队拍宣传片的时候,摄影师让塞巴斯汀随便弹,于是他弹起了熟悉的曲子,接着他似乎想起了什么……再一次试镜被嘲笑后,米娅心情降至冰点。她准备返回老家,这个城市再没什么值得她留恋,梦想也好,爱人也罢,终究只是一场梦。面对挽留的塞巴斯汀,她再也无法忍受,哭着说她受够了。米娅回到了自己的家,塞巴斯汀也回到了乐队。\n\n一段时间后,塞巴斯汀出现在了米娅家门口。一个知名导演正在选角,试镜电话打给了塞巴斯汀,在塞巴斯汀的鼓励下,米娅鼓起勇气决定再试一次。导演让米娅随便讲一个故事,于是她用歌声讲述了自己的梦想。面试过后,他们来到天文馆门口,一起谈论着对未来的打算。他说你的梦想一定会实现的。秋天的洛杉矶,纯净而理性。他们的感情在这里开始,也在这里结束……\n\n五年后米娅成了知名演员,实现了自己的梦想。她事业有成,结婚生子,生活安稳,家庭美满。晚上米娅和丈夫遭遇堵车,路边散步时发现了一个酒吧。热闹的气氛吸引了米娅的注意,这正是当年塞巴斯汀带她去的酒吧。米娅发现酒吧的名字是她多年前为塞巴斯汀取的。这里只有纯粹的爵士乐,塞巴斯汀的梦想就是拥有这样一个地方。落坐以后,塞巴斯汀看到了台下的米娅,沉默片刻后,他弹起了那首熟悉的音乐。\n***\n*就像最初他们相见时那样,他们忘记了全世界。那个夜晚,那次初见,时间仿佛从未流逝。但这次不等她说完一句话,他就热烈的吻上了她唇。他毫无顾忌,她毫无防备,他们痴迷于彼此的味道。他们翩翩起舞,一路走向梦想,走进热恋,相互陪伴,相互成全,一起成长,一起狂欢。然后携手走进那片星空。他眼神温柔,她身姿婀娜。他们打造着自己的小窝,享受着二人世界。爱的结晶来到他们身边,放佛那些美好是和他一起度过的。直到今天这个夜晚,他们始终如一,此志不渝。*\n\n___\n曲终之后,她被拉回现实,然后和丈夫一起离开。在拐角处她转身,回头,两人遥遥相望,然后互相报以微笑。时隔经年,若我遇见你,我该如何与你致意?以眼泪,以沉默!\n\n我一同学特别喜欢这部电影,我知道那是因为她在电影中看到了自己。她的挚爱,七年长跑,可终究还是没能走到一起。或许这就是所谓的「在别人的故事里,流着自己的眼泪」。你是否也在无人的深夜,想起某个人,然后哭着醒来。看着周围的一切,熟悉又陌生,那个藏在心里的人啊,此时你身在哪里?可知有人还在深爱着你。虽然思念依然刻骨铭心,但你们之间却只剩下曾经。最怕的莫过于,在寂静无声的日子里,莫名其妙的,突然听懂了一首歌,只是你听到的不再是歌曲,而是人生。\n\n**「初识不知曲中意,再听已是曲中人」**……就像是做了一场梦,醒来之时万籁俱寂,物是人非事事休,欲语泪先流……年少时我们总想给最爱的TA更多,却忽略了TA最想要的只是真实的你。后来的我们什么都有了,但却没了我们。我还是我,你还是你,我们却不再是我们。……于是你只能在某个深夜,听着歌,流着泪,然后默默的在心里对那个人说,今夜,我不关心世界,今夜,我只想你。\n\n","source":"_posts/摘录/爱乐之城——影评.md","raw":"---\ntitle: 爱乐之城——影评\ndate: 2019-07-21 21:17:19\nurlname: lalaland-film\ntags: [影视]\ncategories: 摘录\n\n---\n\n![ ](https://github.com/maiernte/img/raw/master/collection/lalaland.jpg)\n\n\n\n我在凌晨三点醒来的夜里,想起已失去的你,曾经说着永远一起,现在却不再联系。如果当时的我们能少一些固执,是否会有更好的结局。\n\n洛杉矶,华纳兄弟电影厂旁边的咖啡馆,明星来往不息。一身素雅的米娅是这里的收银员。她的梦想就是成为一个知名演员及编剧。所以她经常请假去试镜,跑遍大大小小的片场。虽然每次她都充满希望,但现实却是四处碰壁。这天,又一次遭受打击的米娅垂头丧气回到家中。洗去一身疲态后,她站在镜子面前暗自神伤哼起歌来 。这时室友火急火燎的出现,邀请她一起去参加派对。本来心情极度郁闷的米娅不想去凑热闹。经不住一帮二货室友的游说,精心打扮一番后她们就出发了。\n\n洛杉矶的月色下,灯红酒绿,觥筹交错。但热闹是属于他们的,安静下来后她却感到愈加落寞。人潮中充斥着过剩的荷尔蒙,但却没有她想要的一双眼睛。世界瞬息万变,她却岿然不动。逃离狂欢派对后,违规停放的车子又被拖走。米娅只能走路回家,在安静的街头上。忽然一阵悠扬的钢琴声传来,如梦似幻,温润缠绵。米娅停下脚步,来到了一个毫不起眼的地下酒吧。一个优雅的男人坐在无人注意的角落里安静的弹奏着。此刻,全世界好像都暗了下来,只有他闪着耀眼的光芒。男人名叫塞巴斯汀,是一个爵士乐钢琴师。他对音乐有着自己独特的追求,不愿弹奏靡靡之音。可一曲弹罢,没有人为他鼓掌,他也被老板炒了鱿鱼。塞巴斯汀愤愤的离开,米娅鼓起勇气迎面走过去,想要认识这个让她着迷的男人。但一句话还没说完,男人就径直的走开了。米娅扑了个空,尴尬的站在那里不知所措。\n\n生活依然按部就班,米娅依然忙着追逐她的梦想。一次派对上,米娅又遇上了塞巴斯汀。他加入了一个爵士乐队,但他们的演奏依旧没人捧场。为了惩罚这个「严肃」的音乐人,也为了报复上次给她造成的尴尬,米娅点了一首非常不严肃的音乐,她甚至随着音乐舞动起来。而塞巴斯汀却站在那里既尴尬又无奈。米娅的行为让塞巴斯汀想起了那晚的无礼。他向米娅道了歉,两人算是相识了。聚会结束后,米娅又找不到车子,于是两人在夜色下散步。洛杉矶的夜色此刻显得如此迷人,在暧昧的氛围中,他们默契地跳着属于他们的舞蹈。\n\n第二天塞巴斯汀来到米娅工作的咖啡店,下班后他们一起在片场附近的街头闲聊,塞巴斯汀鼓励米娅给自己写剧本,而不是去演别人的剧本。自己给自己创造角色,说不定会有意想不到的效果。米娅也向塞巴斯汀坦白说,她讨厌爵士乐。于是固执的塞巴斯汀就带米娅来到一个演奏爵士乐的酒吧,他试图改变米娅对爵士乐的看法,向她解释爵士乐的起源。然而米娅还是不能理解,对音乐有执念的塞巴斯汀表示,他不想让爵士乐就此消亡,他想要创建自己的俱乐部,在那里只有纯粹的爵士乐,那是他一直以来的梦想。\n\n这天又一次试镜失败的米娅心情沮丧,经过电影院门口时,她想起和塞巴斯汀的电影院之约。顿时心情变得愉悦,这时几个月不见一次的男友却来接她一起吃饭。餐桌上米娅心不在焉,男友却把她晾在一边,自顾自的和哥哥聊天。而在电影院门口的塞巴斯汀焦急的等着米娅,此时餐厅传来了熟悉的曲子,那个夜晚塞巴斯汀弹奏的正是这首曲子。米娅随即起身跑了出去,穿过色彩缤纷的霓虹灯,她找到了失落的塞巴斯汀,此时的两个人根本无心观看电影。他们指尖轻触,随后十指紧扣,接着互相靠近……但灯光却忽然打开,两人无奈的相视一笑。之后米娅带着塞巴斯汀来到天文馆,他们在浪漫的氛围中翩翩起舞,魅惑的蓝色星空下,两人仿佛和整个宇宙融为一体。\n\n金风玉露终于相逢,热恋之吻甘之如饴。随后两人一边热恋,一边为各自的梦想努力。他们一起旅行、一起恶作剧,他们走遍大街小巷,他弹琴、她跳舞,在塞巴斯汀的影响下,米娅渐渐喜欢上了爵士乐。这天早上,塞巴斯汀无意中听到了米娅和她母亲的通话。米娅的母亲对她们的未来很担忧,因为塞巴斯汀没有稳定的工作。寥寥几句话,就将塞巴斯汀从梦中拉回现实。他接受了前乐队主唱的邀请,成为了他们的键盘手。但这就意味着塞巴斯汀必须放弃自己的坚持,跟着乐队的风格走。晚上回家的米娅,听到塞巴斯汀的琴声,感受到了他失落的情绪。无需过多的话语,米娅和着琴声唱着歌,这种默契让他们心照不宣。就这样两人互相鼓励,互相安慰,塞巴斯汀的乐队开始走红。米娅也陆陆续续接到了一些大大小小的角色。看着梦想之门慢慢打开,他们也变得越来越忙碌。乐队巡演时,米娅站在台下看着万众瞩目的塞巴斯汀,喧闹的人群,闪烁的灯光,流行的爵士乐,一切看起来都那么美好……台上的男人意气风发、星光闪耀,米娅却觉得和他有了距离。晚上回到家的米娅得到了一个大大的惊喜。忙碌的他们很久都没有见面了,塞巴斯汀明天一早又要离开,他想要让米娅跟他一起,米娅却问他喜不喜欢现在弹奏的音乐?但此时的塞巴斯汀已经尝到了名利带来的甜头,他放弃了曾经的梦想,也放弃了曾经的坚持。他以为这些是米娅想要的:稳定的生活,不菲的收入,以及聚少离多的爱情。他说以前那些梦想太虚无缥缈,现在他需要成熟起来。最后激动的塞巴斯汀对米娅说,你喜欢以前不堪的我,是因为相比而言,那会让你感觉自我良好。这句伤人的话使得他们关系僵化,接着米娅一声不响的离开。第二天在给乐队拍宣传片的时候,摄影师让塞巴斯汀随便弹,于是他弹起了熟悉的曲子,接着他似乎想起了什么……再一次试镜被嘲笑后,米娅心情降至冰点。她准备返回老家,这个城市再没什么值得她留恋,梦想也好,爱人也罢,终究只是一场梦。面对挽留的塞巴斯汀,她再也无法忍受,哭着说她受够了。米娅回到了自己的家,塞巴斯汀也回到了乐队。\n\n一段时间后,塞巴斯汀出现在了米娅家门口。一个知名导演正在选角,试镜电话打给了塞巴斯汀,在塞巴斯汀的鼓励下,米娅鼓起勇气决定再试一次。导演让米娅随便讲一个故事,于是她用歌声讲述了自己的梦想。面试过后,他们来到天文馆门口,一起谈论着对未来的打算。他说你的梦想一定会实现的。秋天的洛杉矶,纯净而理性。他们的感情在这里开始,也在这里结束……\n\n五年后米娅成了知名演员,实现了自己的梦想。她事业有成,结婚生子,生活安稳,家庭美满。晚上米娅和丈夫遭遇堵车,路边散步时发现了一个酒吧。热闹的气氛吸引了米娅的注意,这正是当年塞巴斯汀带她去的酒吧。米娅发现酒吧的名字是她多年前为塞巴斯汀取的。这里只有纯粹的爵士乐,塞巴斯汀的梦想就是拥有这样一个地方。落坐以后,塞巴斯汀看到了台下的米娅,沉默片刻后,他弹起了那首熟悉的音乐。\n***\n*就像最初他们相见时那样,他们忘记了全世界。那个夜晚,那次初见,时间仿佛从未流逝。但这次不等她说完一句话,他就热烈的吻上了她唇。他毫无顾忌,她毫无防备,他们痴迷于彼此的味道。他们翩翩起舞,一路走向梦想,走进热恋,相互陪伴,相互成全,一起成长,一起狂欢。然后携手走进那片星空。他眼神温柔,她身姿婀娜。他们打造着自己的小窝,享受着二人世界。爱的结晶来到他们身边,放佛那些美好是和他一起度过的。直到今天这个夜晚,他们始终如一,此志不渝。*\n\n___\n曲终之后,她被拉回现实,然后和丈夫一起离开。在拐角处她转身,回头,两人遥遥相望,然后互相报以微笑。时隔经年,若我遇见你,我该如何与你致意?以眼泪,以沉默!\n\n我一同学特别喜欢这部电影,我知道那是因为她在电影中看到了自己。她的挚爱,七年长跑,可终究还是没能走到一起。或许这就是所谓的「在别人的故事里,流着自己的眼泪」。你是否也在无人的深夜,想起某个人,然后哭着醒来。看着周围的一切,熟悉又陌生,那个藏在心里的人啊,此时你身在哪里?可知有人还在深爱着你。虽然思念依然刻骨铭心,但你们之间却只剩下曾经。最怕的莫过于,在寂静无声的日子里,莫名其妙的,突然听懂了一首歌,只是你听到的不再是歌曲,而是人生。\n\n**「初识不知曲中意,再听已是曲中人」**……就像是做了一场梦,醒来之时万籁俱寂,物是人非事事休,欲语泪先流……年少时我们总想给最爱的TA更多,却忽略了TA最想要的只是真实的你。后来的我们什么都有了,但却没了我们。我还是我,你还是你,我们却不再是我们。……于是你只能在某个深夜,听着歌,流着泪,然后默默的在心里对那个人说,今夜,我不关心世界,今夜,我只想你。\n\n","slug":"摘录/爱乐之城——影评","published":1,"updated":"2019-08-14T06:31:50.000Z","_id":"cka1y596d000s4huu6s41uv14","comments":1,"layout":"post","photos":[],"link":"","content":"

\"

\n\n

我在凌晨三点醒来的夜里,想起已失去的你,曾经说着永远一起,现在却不再联系。如果当时的我们能少一些固执,是否会有更好的结局。

\n

洛杉矶,华纳兄弟电影厂旁边的咖啡馆,明星来往不息。一身素雅的米娅是这里的收银员。她的梦想就是成为一个知名演员及编剧。所以她经常请假去试镜,跑遍大大小小的片场。虽然每次她都充满希望,但现实却是四处碰壁。这天,又一次遭受打击的米娅垂头丧气回到家中。洗去一身疲态后,她站在镜子面前暗自神伤哼起歌来 。这时室友火急火燎的出现,邀请她一起去参加派对。本来心情极度郁闷的米娅不想去凑热闹。经不住一帮二货室友的游说,精心打扮一番后她们就出发了。

\n

洛杉矶的月色下,灯红酒绿,觥筹交错。但热闹是属于他们的,安静下来后她却感到愈加落寞。人潮中充斥着过剩的荷尔蒙,但却没有她想要的一双眼睛。世界瞬息万变,她却岿然不动。逃离狂欢派对后,违规停放的车子又被拖走。米娅只能走路回家,在安静的街头上。忽然一阵悠扬的钢琴声传来,如梦似幻,温润缠绵。米娅停下脚步,来到了一个毫不起眼的地下酒吧。一个优雅的男人坐在无人注意的角落里安静的弹奏着。此刻,全世界好像都暗了下来,只有他闪着耀眼的光芒。男人名叫塞巴斯汀,是一个爵士乐钢琴师。他对音乐有着自己独特的追求,不愿弹奏靡靡之音。可一曲弹罢,没有人为他鼓掌,他也被老板炒了鱿鱼。塞巴斯汀愤愤的离开,米娅鼓起勇气迎面走过去,想要认识这个让她着迷的男人。但一句话还没说完,男人就径直的走开了。米娅扑了个空,尴尬的站在那里不知所措。

\n

生活依然按部就班,米娅依然忙着追逐她的梦想。一次派对上,米娅又遇上了塞巴斯汀。他加入了一个爵士乐队,但他们的演奏依旧没人捧场。为了惩罚这个「严肃」的音乐人,也为了报复上次给她造成的尴尬,米娅点了一首非常不严肃的音乐,她甚至随着音乐舞动起来。而塞巴斯汀却站在那里既尴尬又无奈。米娅的行为让塞巴斯汀想起了那晚的无礼。他向米娅道了歉,两人算是相识了。聚会结束后,米娅又找不到车子,于是两人在夜色下散步。洛杉矶的夜色此刻显得如此迷人,在暧昧的氛围中,他们默契地跳着属于他们的舞蹈。

\n

第二天塞巴斯汀来到米娅工作的咖啡店,下班后他们一起在片场附近的街头闲聊,塞巴斯汀鼓励米娅给自己写剧本,而不是去演别人的剧本。自己给自己创造角色,说不定会有意想不到的效果。米娅也向塞巴斯汀坦白说,她讨厌爵士乐。于是固执的塞巴斯汀就带米娅来到一个演奏爵士乐的酒吧,他试图改变米娅对爵士乐的看法,向她解释爵士乐的起源。然而米娅还是不能理解,对音乐有执念的塞巴斯汀表示,他不想让爵士乐就此消亡,他想要创建自己的俱乐部,在那里只有纯粹的爵士乐,那是他一直以来的梦想。

\n

这天又一次试镜失败的米娅心情沮丧,经过电影院门口时,她想起和塞巴斯汀的电影院之约。顿时心情变得愉悦,这时几个月不见一次的男友却来接她一起吃饭。餐桌上米娅心不在焉,男友却把她晾在一边,自顾自的和哥哥聊天。而在电影院门口的塞巴斯汀焦急的等着米娅,此时餐厅传来了熟悉的曲子,那个夜晚塞巴斯汀弹奏的正是这首曲子。米娅随即起身跑了出去,穿过色彩缤纷的霓虹灯,她找到了失落的塞巴斯汀,此时的两个人根本无心观看电影。他们指尖轻触,随后十指紧扣,接着互相靠近……但灯光却忽然打开,两人无奈的相视一笑。之后米娅带着塞巴斯汀来到天文馆,他们在浪漫的氛围中翩翩起舞,魅惑的蓝色星空下,两人仿佛和整个宇宙融为一体。

\n

金风玉露终于相逢,热恋之吻甘之如饴。随后两人一边热恋,一边为各自的梦想努力。他们一起旅行、一起恶作剧,他们走遍大街小巷,他弹琴、她跳舞,在塞巴斯汀的影响下,米娅渐渐喜欢上了爵士乐。这天早上,塞巴斯汀无意中听到了米娅和她母亲的通话。米娅的母亲对她们的未来很担忧,因为塞巴斯汀没有稳定的工作。寥寥几句话,就将塞巴斯汀从梦中拉回现实。他接受了前乐队主唱的邀请,成为了他们的键盘手。但这就意味着塞巴斯汀必须放弃自己的坚持,跟着乐队的风格走。晚上回家的米娅,听到塞巴斯汀的琴声,感受到了他失落的情绪。无需过多的话语,米娅和着琴声唱着歌,这种默契让他们心照不宣。就这样两人互相鼓励,互相安慰,塞巴斯汀的乐队开始走红。米娅也陆陆续续接到了一些大大小小的角色。看着梦想之门慢慢打开,他们也变得越来越忙碌。乐队巡演时,米娅站在台下看着万众瞩目的塞巴斯汀,喧闹的人群,闪烁的灯光,流行的爵士乐,一切看起来都那么美好……台上的男人意气风发、星光闪耀,米娅却觉得和他有了距离。晚上回到家的米娅得到了一个大大的惊喜。忙碌的他们很久都没有见面了,塞巴斯汀明天一早又要离开,他想要让米娅跟他一起,米娅却问他喜不喜欢现在弹奏的音乐?但此时的塞巴斯汀已经尝到了名利带来的甜头,他放弃了曾经的梦想,也放弃了曾经的坚持。他以为这些是米娅想要的:稳定的生活,不菲的收入,以及聚少离多的爱情。他说以前那些梦想太虚无缥缈,现在他需要成熟起来。最后激动的塞巴斯汀对米娅说,你喜欢以前不堪的我,是因为相比而言,那会让你感觉自我良好。这句伤人的话使得他们关系僵化,接着米娅一声不响的离开。第二天在给乐队拍宣传片的时候,摄影师让塞巴斯汀随便弹,于是他弹起了熟悉的曲子,接着他似乎想起了什么……再一次试镜被嘲笑后,米娅心情降至冰点。她准备返回老家,这个城市再没什么值得她留恋,梦想也好,爱人也罢,终究只是一场梦。面对挽留的塞巴斯汀,她再也无法忍受,哭着说她受够了。米娅回到了自己的家,塞巴斯汀也回到了乐队。

\n

一段时间后,塞巴斯汀出现在了米娅家门口。一个知名导演正在选角,试镜电话打给了塞巴斯汀,在塞巴斯汀的鼓励下,米娅鼓起勇气决定再试一次。导演让米娅随便讲一个故事,于是她用歌声讲述了自己的梦想。面试过后,他们来到天文馆门口,一起谈论着对未来的打算。他说你的梦想一定会实现的。秋天的洛杉矶,纯净而理性。他们的感情在这里开始,也在这里结束……

\n

五年后米娅成了知名演员,实现了自己的梦想。她事业有成,结婚生子,生活安稳,家庭美满。晚上米娅和丈夫遭遇堵车,路边散步时发现了一个酒吧。热闹的气氛吸引了米娅的注意,这正是当年塞巴斯汀带她去的酒吧。米娅发现酒吧的名字是她多年前为塞巴斯汀取的。这里只有纯粹的爵士乐,塞巴斯汀的梦想就是拥有这样一个地方。落坐以后,塞巴斯汀看到了台下的米娅,沉默片刻后,他弹起了那首熟悉的音乐。

\n
\n

就像最初他们相见时那样,他们忘记了全世界。那个夜晚,那次初见,时间仿佛从未流逝。但这次不等她说完一句话,他就热烈的吻上了她唇。他毫无顾忌,她毫无防备,他们痴迷于彼此的味道。他们翩翩起舞,一路走向梦想,走进热恋,相互陪伴,相互成全,一起成长,一起狂欢。然后携手走进那片星空。他眼神温柔,她身姿婀娜。他们打造着自己的小窝,享受着二人世界。爱的结晶来到他们身边,放佛那些美好是和他一起度过的。直到今天这个夜晚,他们始终如一,此志不渝。

\n
\n

曲终之后,她被拉回现实,然后和丈夫一起离开。在拐角处她转身,回头,两人遥遥相望,然后互相报以微笑。时隔经年,若我遇见你,我该如何与你致意?以眼泪,以沉默!

\n

我一同学特别喜欢这部电影,我知道那是因为她在电影中看到了自己。她的挚爱,七年长跑,可终究还是没能走到一起。或许这就是所谓的「在别人的故事里,流着自己的眼泪」。你是否也在无人的深夜,想起某个人,然后哭着醒来。看着周围的一切,熟悉又陌生,那个藏在心里的人啊,此时你身在哪里?可知有人还在深爱着你。虽然思念依然刻骨铭心,但你们之间却只剩下曾经。最怕的莫过于,在寂静无声的日子里,莫名其妙的,突然听懂了一首歌,只是你听到的不再是歌曲,而是人生。

\n

「初识不知曲中意,再听已是曲中人」……就像是做了一场梦,醒来之时万籁俱寂,物是人非事事休,欲语泪先流……年少时我们总想给最爱的TA更多,却忽略了TA最想要的只是真实的你。后来的我们什么都有了,但却没了我们。我还是我,你还是你,我们却不再是我们。……于是你只能在某个深夜,听着歌,流着泪,然后默默的在心里对那个人说,今夜,我不关心世界,今夜,我只想你。

\n","site":{"data":{}},"excerpt":"

\"

","more":"

我在凌晨三点醒来的夜里,想起已失去的你,曾经说着永远一起,现在却不再联系。如果当时的我们能少一些固执,是否会有更好的结局。

\n

洛杉矶,华纳兄弟电影厂旁边的咖啡馆,明星来往不息。一身素雅的米娅是这里的收银员。她的梦想就是成为一个知名演员及编剧。所以她经常请假去试镜,跑遍大大小小的片场。虽然每次她都充满希望,但现实却是四处碰壁。这天,又一次遭受打击的米娅垂头丧气回到家中。洗去一身疲态后,她站在镜子面前暗自神伤哼起歌来 。这时室友火急火燎的出现,邀请她一起去参加派对。本来心情极度郁闷的米娅不想去凑热闹。经不住一帮二货室友的游说,精心打扮一番后她们就出发了。

\n

洛杉矶的月色下,灯红酒绿,觥筹交错。但热闹是属于他们的,安静下来后她却感到愈加落寞。人潮中充斥着过剩的荷尔蒙,但却没有她想要的一双眼睛。世界瞬息万变,她却岿然不动。逃离狂欢派对后,违规停放的车子又被拖走。米娅只能走路回家,在安静的街头上。忽然一阵悠扬的钢琴声传来,如梦似幻,温润缠绵。米娅停下脚步,来到了一个毫不起眼的地下酒吧。一个优雅的男人坐在无人注意的角落里安静的弹奏着。此刻,全世界好像都暗了下来,只有他闪着耀眼的光芒。男人名叫塞巴斯汀,是一个爵士乐钢琴师。他对音乐有着自己独特的追求,不愿弹奏靡靡之音。可一曲弹罢,没有人为他鼓掌,他也被老板炒了鱿鱼。塞巴斯汀愤愤的离开,米娅鼓起勇气迎面走过去,想要认识这个让她着迷的男人。但一句话还没说完,男人就径直的走开了。米娅扑了个空,尴尬的站在那里不知所措。

\n

生活依然按部就班,米娅依然忙着追逐她的梦想。一次派对上,米娅又遇上了塞巴斯汀。他加入了一个爵士乐队,但他们的演奏依旧没人捧场。为了惩罚这个「严肃」的音乐人,也为了报复上次给她造成的尴尬,米娅点了一首非常不严肃的音乐,她甚至随着音乐舞动起来。而塞巴斯汀却站在那里既尴尬又无奈。米娅的行为让塞巴斯汀想起了那晚的无礼。他向米娅道了歉,两人算是相识了。聚会结束后,米娅又找不到车子,于是两人在夜色下散步。洛杉矶的夜色此刻显得如此迷人,在暧昧的氛围中,他们默契地跳着属于他们的舞蹈。

\n

第二天塞巴斯汀来到米娅工作的咖啡店,下班后他们一起在片场附近的街头闲聊,塞巴斯汀鼓励米娅给自己写剧本,而不是去演别人的剧本。自己给自己创造角色,说不定会有意想不到的效果。米娅也向塞巴斯汀坦白说,她讨厌爵士乐。于是固执的塞巴斯汀就带米娅来到一个演奏爵士乐的酒吧,他试图改变米娅对爵士乐的看法,向她解释爵士乐的起源。然而米娅还是不能理解,对音乐有执念的塞巴斯汀表示,他不想让爵士乐就此消亡,他想要创建自己的俱乐部,在那里只有纯粹的爵士乐,那是他一直以来的梦想。

\n

这天又一次试镜失败的米娅心情沮丧,经过电影院门口时,她想起和塞巴斯汀的电影院之约。顿时心情变得愉悦,这时几个月不见一次的男友却来接她一起吃饭。餐桌上米娅心不在焉,男友却把她晾在一边,自顾自的和哥哥聊天。而在电影院门口的塞巴斯汀焦急的等着米娅,此时餐厅传来了熟悉的曲子,那个夜晚塞巴斯汀弹奏的正是这首曲子。米娅随即起身跑了出去,穿过色彩缤纷的霓虹灯,她找到了失落的塞巴斯汀,此时的两个人根本无心观看电影。他们指尖轻触,随后十指紧扣,接着互相靠近……但灯光却忽然打开,两人无奈的相视一笑。之后米娅带着塞巴斯汀来到天文馆,他们在浪漫的氛围中翩翩起舞,魅惑的蓝色星空下,两人仿佛和整个宇宙融为一体。

\n

金风玉露终于相逢,热恋之吻甘之如饴。随后两人一边热恋,一边为各自的梦想努力。他们一起旅行、一起恶作剧,他们走遍大街小巷,他弹琴、她跳舞,在塞巴斯汀的影响下,米娅渐渐喜欢上了爵士乐。这天早上,塞巴斯汀无意中听到了米娅和她母亲的通话。米娅的母亲对她们的未来很担忧,因为塞巴斯汀没有稳定的工作。寥寥几句话,就将塞巴斯汀从梦中拉回现实。他接受了前乐队主唱的邀请,成为了他们的键盘手。但这就意味着塞巴斯汀必须放弃自己的坚持,跟着乐队的风格走。晚上回家的米娅,听到塞巴斯汀的琴声,感受到了他失落的情绪。无需过多的话语,米娅和着琴声唱着歌,这种默契让他们心照不宣。就这样两人互相鼓励,互相安慰,塞巴斯汀的乐队开始走红。米娅也陆陆续续接到了一些大大小小的角色。看着梦想之门慢慢打开,他们也变得越来越忙碌。乐队巡演时,米娅站在台下看着万众瞩目的塞巴斯汀,喧闹的人群,闪烁的灯光,流行的爵士乐,一切看起来都那么美好……台上的男人意气风发、星光闪耀,米娅却觉得和他有了距离。晚上回到家的米娅得到了一个大大的惊喜。忙碌的他们很久都没有见面了,塞巴斯汀明天一早又要离开,他想要让米娅跟他一起,米娅却问他喜不喜欢现在弹奏的音乐?但此时的塞巴斯汀已经尝到了名利带来的甜头,他放弃了曾经的梦想,也放弃了曾经的坚持。他以为这些是米娅想要的:稳定的生活,不菲的收入,以及聚少离多的爱情。他说以前那些梦想太虚无缥缈,现在他需要成熟起来。最后激动的塞巴斯汀对米娅说,你喜欢以前不堪的我,是因为相比而言,那会让你感觉自我良好。这句伤人的话使得他们关系僵化,接着米娅一声不响的离开。第二天在给乐队拍宣传片的时候,摄影师让塞巴斯汀随便弹,于是他弹起了熟悉的曲子,接着他似乎想起了什么……再一次试镜被嘲笑后,米娅心情降至冰点。她准备返回老家,这个城市再没什么值得她留恋,梦想也好,爱人也罢,终究只是一场梦。面对挽留的塞巴斯汀,她再也无法忍受,哭着说她受够了。米娅回到了自己的家,塞巴斯汀也回到了乐队。

\n

一段时间后,塞巴斯汀出现在了米娅家门口。一个知名导演正在选角,试镜电话打给了塞巴斯汀,在塞巴斯汀的鼓励下,米娅鼓起勇气决定再试一次。导演让米娅随便讲一个故事,于是她用歌声讲述了自己的梦想。面试过后,他们来到天文馆门口,一起谈论着对未来的打算。他说你的梦想一定会实现的。秋天的洛杉矶,纯净而理性。他们的感情在这里开始,也在这里结束……

\n

五年后米娅成了知名演员,实现了自己的梦想。她事业有成,结婚生子,生活安稳,家庭美满。晚上米娅和丈夫遭遇堵车,路边散步时发现了一个酒吧。热闹的气氛吸引了米娅的注意,这正是当年塞巴斯汀带她去的酒吧。米娅发现酒吧的名字是她多年前为塞巴斯汀取的。这里只有纯粹的爵士乐,塞巴斯汀的梦想就是拥有这样一个地方。落坐以后,塞巴斯汀看到了台下的米娅,沉默片刻后,他弹起了那首熟悉的音乐。

\n
\n

就像最初他们相见时那样,他们忘记了全世界。那个夜晚,那次初见,时间仿佛从未流逝。但这次不等她说完一句话,他就热烈的吻上了她唇。他毫无顾忌,她毫无防备,他们痴迷于彼此的味道。他们翩翩起舞,一路走向梦想,走进热恋,相互陪伴,相互成全,一起成长,一起狂欢。然后携手走进那片星空。他眼神温柔,她身姿婀娜。他们打造着自己的小窝,享受着二人世界。爱的结晶来到他们身边,放佛那些美好是和他一起度过的。直到今天这个夜晚,他们始终如一,此志不渝。

\n
\n

曲终之后,她被拉回现实,然后和丈夫一起离开。在拐角处她转身,回头,两人遥遥相望,然后互相报以微笑。时隔经年,若我遇见你,我该如何与你致意?以眼泪,以沉默!

\n

我一同学特别喜欢这部电影,我知道那是因为她在电影中看到了自己。她的挚爱,七年长跑,可终究还是没能走到一起。或许这就是所谓的「在别人的故事里,流着自己的眼泪」。你是否也在无人的深夜,想起某个人,然后哭着醒来。看着周围的一切,熟悉又陌生,那个藏在心里的人啊,此时你身在哪里?可知有人还在深爱着你。虽然思念依然刻骨铭心,但你们之间却只剩下曾经。最怕的莫过于,在寂静无声的日子里,莫名其妙的,突然听懂了一首歌,只是你听到的不再是歌曲,而是人生。

\n

「初识不知曲中意,再听已是曲中人」……就像是做了一场梦,醒来之时万籁俱寂,物是人非事事休,欲语泪先流……年少时我们总想给最爱的TA更多,却忽略了TA最想要的只是真实的你。后来的我们什么都有了,但却没了我们。我还是我,你还是你,我们却不再是我们。……于是你只能在某个深夜,听着歌,流着泪,然后默默的在心里对那个人说,今夜,我不关心世界,今夜,我只想你。

"},{"title":"财富自由之路-李笑来","date":"2019-07-21T07:05:22.000Z","urlname":"road-to-asset-freedom","toc":true,"contentpw":123456,"_content":"\n\n![图片来自七牛](https://github.com/maiernte/img/raw/master/collection/photo.jpg)\n\n\n\n\n\n进度:10课\n\n# 哲学层面\n\n## 金钱、时间、注意力\n\n钱不是最重要,它可以再生。时间也不是,它本质上不属于你,你只能试着与它做朋友。注意力是自己可以做主的。**必须把宝贵的注意力全部放在自己身上**。放在自己的哪儿上?答:“**成长**”。不珍惜自己注意力的人最终注定是贫穷的,因为他们终生被收割,不可能有真正有价值的产出,怎么可能最终变得富有?另外,要放在自己的**真爱**上,以及对整个社会真正**有贡献**的事情上。(对于后两者,关注的焦点还是“成长”。)\n\n\n\n注意力才是你人生最宝贵的财富(不是金钱和时间),你的一切价值都是你的注意力的产出。\n\n> 俗三个大坑:1. 莫名其妙的凑热闹。2. 心急火燎的随大流。3. 操碎了别人的心 (*万众创业关你屁事,干好自己的活*)。\n\n\n\n金钱、时间和注意力的比较:$ 注意力 > 时间 > 金钱 $\n\n- 凡是可以用钱买的其实都是便宜的。\n\n- 凡是能用钱买来的时间就是便宜的。\n\n- 凡是能用时间换来的注意力持续就是有价值的。\n\n\n\n:question: 时间和金钱谁更重要。\n\n> 答案是`时间`。因为财富自由的定义就是“*不为生活需要出售时间*”。另外一个角度是,“*花钱买你的时间更划算*”。\n\n\n\n:question: 注意力和时间更重要。\n\n> 注意力是能让你有所产出的唯一资源!而时间不一定是你的,时间不会自动产出。(李笑来: 花大量时间与老婆沟通,陪伴,以便换来自己集中注意力工作的机会。)\n\n\n\n## 合作与信任\n\n追求百分百的***安全感***,肯定会把自己困在了永恒的当下。必须放弃一部分安全感,才能有深入的、长期的观察和思考。打破枷锁的方法:\n\n1. 放弃部分安全感,才能获得进步。\n2. 通过有效社交,补全主动放弃的安全感。\n\n\n\n:bookmark:【**合作**】​ 的本质是大家各自放弃一小部分安全感,并把那一部分安全感交给合作方来保障。\n\n:bookmark: 【**信任**】就是相信对方不会利用自己主动放弃的那一部分安全感。所谓缺乏安全感,就是不相信别人竟然可以不利用自己放弃的那一部分安全感,所以只能自己去搞定百分之百的安全感,让人心力交瘁。\n\n\n\n- 不要与缺乏安全感的人合作。尤其是婚姻。\n- 最大的勇敢,就是在孑然一身的时候,还勇于放弃部分安全感。“大智若愚”,大智更像是结果。若愚才是原因。\n- 将军赶路不打小鬼。\n\n\n\n## 活在真实中\n\n如果想活在真实的世界,就要勇于面对「真实」。要搞清楚以下几个概念。\n\n\n\n### 什么算落后\n\n1. 20%之后都是落后,因为世界20%的人占了有限资源的80%。在人工智能和新技术时代,可能1%之后都算落后。将来可能是千分之一,万分之一之后都算。\n\n2. 我们每个人都已经可以尽量感知到这个世界的全部。所以要对自己是否处在落后状态有清晰认知。\n\n3. 我们对知识的渴求已经变成害怕落后。这是种危机感和焦虑,但它能帮我们持续进步,摆脱落后。\n\n\n\n**乌比冈湖效应**:Lake Wobegon Effect 每个人都自认高于平均水平。\n\n**邓宁- 克鲁格效应** :Dunning-Kruger Effect 能力欠缺的人有一种虚幻的自我优越感,错误的认为自己比真实情况更加优秀。\n\n **麻烦守恒定律**:以前因为怕麻烦二省去的麻烦,在未来的某一天,或者未来的某一时刻,一定会以另一种形式呈现在你面前。麻烦不会无缘无故的消失,问题也不会无缘无故的解决。\n\n\n\n### 元认知能力\n\n:pencil:**指对自己的思考过程的认知和理解**。\n\n元认知能力起作用的三个步骤:\n\n1. 哦,原来我是这么想的。\n2. 嗯?我这么想难道是不对的吗?\n3. 啊!我应该这么想才对。。。。\n\n认知能力好比是马,而元认知能力是马车夫。所谓可以用来解放自己的“心智”,指的就是具备足够的元认知能力的大脑。人与人之间的技能差异,证据确凿来自于“刻意锻炼”。而一个人能做到“刻意锻炼”,唯一能够仰仗的就是元认知能力。\n\n- 元认知能力是一个人可拥有的最重要的能力。\n- 元认知能力不仅可以习得,还可以通过刻意训练长期持续发展。\n\n\n\n我们知道我们想要改变的,能够改变的,不是“现在的自己”,而是“将来的自己”。通过刻意练习提高元认知能力的三个方法:坐享、兴趣、反思。\n\n- **坐享**:可以增加大脑皮层的沟回。\n\n- **兴趣**:兴趣是最好的教学。\n\n- **反思**:每天花十分钟反思一下自己的思路和思考结果,琢磨一下自己想法有没有逻辑错误。不仅是元认知能力的刻意训练方式,也是调整情绪的根本。\n\n\n\n## 竞争力\n\n### 多维竞争\n\n😂 据说绝大多数人的幸福感是建立在比较之上的。有个玩笑:所谓的幸福就是自己的收入总比妹夫的收入多百分之二十。。。。。\n\n😂 一般人所谓的“成长”,就是不断的把别人比下去的过程。\n\n\n\n维度在生活上有三个体现:\n\n1. 生活是有多个维度的。\n2. 在多个维度打造竞争力。\n3. 至少在一个维度上足够突出。凡事都是有成本。处处平庸是不行的。\n\n\n\n面对维度,要有以下意识:\n\n- 单个维度,大家比的是长度,两个维度上大家比的是面积,三个维度上大家比的是体积。\n- 每次跨界,都是给自己拓展一个新的维度。\n- 对新知识保持开放态度。\n\n\n\n\n\n# 应用层面\n\n## 「活在未来」\n\n如何活在未来\n\n1. 对未来要有个预测\n2. 那个预测需要时间才能得到结果\n3. 笃信你的预测是正确的。\n4. 于是你按照那个预测的结果行动、选择、思考。\n5. 你终将走到那个结果出现的时刻\n6. 最终证明你的预测是正确的。\n7. 那么,由于你提前按未来正确的结果行动、选择、思考,于是,在相当长的时间里,你生活的一部分就是“活在未来”。\n\n## 人际关系的本质\n\n人际关系在本质上还是**交易**。明白这一点,就能更清楚的看清楚关于**贵人**的问题。 \n\n$ 求助别人 != 麻烦别人 $ \n\n求助不是低声下气的行为,而是一种交易。不仅如此,还是一种隐蔽的、`意义巨大的交易`。贵人之所以原因帮助你,是因为他已经看到你的价值。分清楚“求助”、“乞讨”、“添麻烦”、“占便宜”之间的区别。\n\n能够遇到贵人在一定程度上是偶然也是必然,它是自己生活的一面镜子。你是贵人,生活这面镜子就帮你找到更多的贵人。至于是偶然还是必然,其实你是控制不了的。自己首先得是个贵人,才能遇到贵人,甚至更多贵人。最不济,你也已经成为自己的贵人,而且不会轻易离你而去。“遇到贵人”这件事从来不是我们的目的,相反“成为贵人”倒是我们应该努力的方向。在你出手相助的那一瞬间,你已经得到了自然的回报。\n\n\n\n12条遇到贵人的原则:\n\n1. 乐观的人更容易成为他人的贵人\n2. 贵人更容易遇到贵人\n3. 能帮助他人进步,才是真正的贵人\n4. 优秀的、值得尊重的人,更容易获得帮助。\n5. 乐于分享的人容易获得帮助\n6. 不给他人制造负担的人容易获得帮助\n7. 不以求助为耻的人容易获得帮助\n8. 求助的时候不仅仅用金钱作为回报,帮助他人的时候也不应该收取金钱回报。\n9. 贵人不一定是牛人,贵人通常“以和为贵”。\n10. 很多时候,人们的成功,来源于大量的人**希望看到他成功**。反过来,如果大量的人不愿意看到某人成功,那么这个人真的很难获得所谓的“贵人相助”\n11. 正在做“正确”事情,更容易获得贵人相助。也就是所谓的“**得道多助**”。\n12. 活在未来的人更容易遇到贵人,因为别人能在他身上看到**未来**。\n\n\n\n\n\n## 资本的定义\n\n钱和资本不是一样的东西,正如砖头和房子不是一回事。钱要成为资本必须满足三个基本要素:\n\n1. 资金的金额大小\n2. 资金的使用时限\n3. 资金背后的智慧\n\n\n\n残酷的事实,大多数人其实不配站在资本之后。好消息是资本背后的实力是可以习得的。不能被自己心平气和判上无期徒刑的资金,就别假装资本出来混迹江湖。大多数人在股票市场上“投资”的不是资本,而是“装傻充愣的资金”而已。\n\n\n\n\n\n# 暂时不知道往哪里分\n\n- 好的工具应该让人离开它,而不是黏住它。\n- 你创造财富能力取决于你能给别人创造多少真正的价值。(只有你觉得有价值的话,是几乎没有什么意义的)。\n\n\n\n\n\n\n\n财富自由之路 - 思维导图 ([看全景导图请点击链接](uploads/road-to-asset-freedom-mindmap.html))\n\n
","source":"_posts/读书笔记/财富自由之路-李笑来.md","raw":"---\ntitle: 财富自由之路-李笑来\ndate: 2019-07-21 09:05:22\nurlname: road-to-asset-freedom\ntoc: true\ncontentpw: 123456\ntags: [成长, 经济]\ncategories: 读书笔记\n\n---\n\n\n![图片来自七牛](https://github.com/maiernte/img/raw/master/collection/photo.jpg)\n\n\n\n\n\n进度:10课\n\n# 哲学层面\n\n## 金钱、时间、注意力\n\n钱不是最重要,它可以再生。时间也不是,它本质上不属于你,你只能试着与它做朋友。注意力是自己可以做主的。**必须把宝贵的注意力全部放在自己身上**。放在自己的哪儿上?答:“**成长**”。不珍惜自己注意力的人最终注定是贫穷的,因为他们终生被收割,不可能有真正有价值的产出,怎么可能最终变得富有?另外,要放在自己的**真爱**上,以及对整个社会真正**有贡献**的事情上。(对于后两者,关注的焦点还是“成长”。)\n\n\n\n注意力才是你人生最宝贵的财富(不是金钱和时间),你的一切价值都是你的注意力的产出。\n\n> 俗三个大坑:1. 莫名其妙的凑热闹。2. 心急火燎的随大流。3. 操碎了别人的心 (*万众创业关你屁事,干好自己的活*)。\n\n\n\n金钱、时间和注意力的比较:$ 注意力 > 时间 > 金钱 $\n\n- 凡是可以用钱买的其实都是便宜的。\n\n- 凡是能用钱买来的时间就是便宜的。\n\n- 凡是能用时间换来的注意力持续就是有价值的。\n\n\n\n:question: 时间和金钱谁更重要。\n\n> 答案是`时间`。因为财富自由的定义就是“*不为生活需要出售时间*”。另外一个角度是,“*花钱买你的时间更划算*”。\n\n\n\n:question: 注意力和时间更重要。\n\n> 注意力是能让你有所产出的唯一资源!而时间不一定是你的,时间不会自动产出。(李笑来: 花大量时间与老婆沟通,陪伴,以便换来自己集中注意力工作的机会。)\n\n\n\n## 合作与信任\n\n追求百分百的***安全感***,肯定会把自己困在了永恒的当下。必须放弃一部分安全感,才能有深入的、长期的观察和思考。打破枷锁的方法:\n\n1. 放弃部分安全感,才能获得进步。\n2. 通过有效社交,补全主动放弃的安全感。\n\n\n\n:bookmark:【**合作**】​ 的本质是大家各自放弃一小部分安全感,并把那一部分安全感交给合作方来保障。\n\n:bookmark: 【**信任**】就是相信对方不会利用自己主动放弃的那一部分安全感。所谓缺乏安全感,就是不相信别人竟然可以不利用自己放弃的那一部分安全感,所以只能自己去搞定百分之百的安全感,让人心力交瘁。\n\n\n\n- 不要与缺乏安全感的人合作。尤其是婚姻。\n- 最大的勇敢,就是在孑然一身的时候,还勇于放弃部分安全感。“大智若愚”,大智更像是结果。若愚才是原因。\n- 将军赶路不打小鬼。\n\n\n\n## 活在真实中\n\n如果想活在真实的世界,就要勇于面对「真实」。要搞清楚以下几个概念。\n\n\n\n### 什么算落后\n\n1. 20%之后都是落后,因为世界20%的人占了有限资源的80%。在人工智能和新技术时代,可能1%之后都算落后。将来可能是千分之一,万分之一之后都算。\n\n2. 我们每个人都已经可以尽量感知到这个世界的全部。所以要对自己是否处在落后状态有清晰认知。\n\n3. 我们对知识的渴求已经变成害怕落后。这是种危机感和焦虑,但它能帮我们持续进步,摆脱落后。\n\n\n\n**乌比冈湖效应**:Lake Wobegon Effect 每个人都自认高于平均水平。\n\n**邓宁- 克鲁格效应** :Dunning-Kruger Effect 能力欠缺的人有一种虚幻的自我优越感,错误的认为自己比真实情况更加优秀。\n\n **麻烦守恒定律**:以前因为怕麻烦二省去的麻烦,在未来的某一天,或者未来的某一时刻,一定会以另一种形式呈现在你面前。麻烦不会无缘无故的消失,问题也不会无缘无故的解决。\n\n\n\n### 元认知能力\n\n:pencil:**指对自己的思考过程的认知和理解**。\n\n元认知能力起作用的三个步骤:\n\n1. 哦,原来我是这么想的。\n2. 嗯?我这么想难道是不对的吗?\n3. 啊!我应该这么想才对。。。。\n\n认知能力好比是马,而元认知能力是马车夫。所谓可以用来解放自己的“心智”,指的就是具备足够的元认知能力的大脑。人与人之间的技能差异,证据确凿来自于“刻意锻炼”。而一个人能做到“刻意锻炼”,唯一能够仰仗的就是元认知能力。\n\n- 元认知能力是一个人可拥有的最重要的能力。\n- 元认知能力不仅可以习得,还可以通过刻意训练长期持续发展。\n\n\n\n我们知道我们想要改变的,能够改变的,不是“现在的自己”,而是“将来的自己”。通过刻意练习提高元认知能力的三个方法:坐享、兴趣、反思。\n\n- **坐享**:可以增加大脑皮层的沟回。\n\n- **兴趣**:兴趣是最好的教学。\n\n- **反思**:每天花十分钟反思一下自己的思路和思考结果,琢磨一下自己想法有没有逻辑错误。不仅是元认知能力的刻意训练方式,也是调整情绪的根本。\n\n\n\n## 竞争力\n\n### 多维竞争\n\n😂 据说绝大多数人的幸福感是建立在比较之上的。有个玩笑:所谓的幸福就是自己的收入总比妹夫的收入多百分之二十。。。。。\n\n😂 一般人所谓的“成长”,就是不断的把别人比下去的过程。\n\n\n\n维度在生活上有三个体现:\n\n1. 生活是有多个维度的。\n2. 在多个维度打造竞争力。\n3. 至少在一个维度上足够突出。凡事都是有成本。处处平庸是不行的。\n\n\n\n面对维度,要有以下意识:\n\n- 单个维度,大家比的是长度,两个维度上大家比的是面积,三个维度上大家比的是体积。\n- 每次跨界,都是给自己拓展一个新的维度。\n- 对新知识保持开放态度。\n\n\n\n\n\n# 应用层面\n\n## 「活在未来」\n\n如何活在未来\n\n1. 对未来要有个预测\n2. 那个预测需要时间才能得到结果\n3. 笃信你的预测是正确的。\n4. 于是你按照那个预测的结果行动、选择、思考。\n5. 你终将走到那个结果出现的时刻\n6. 最终证明你的预测是正确的。\n7. 那么,由于你提前按未来正确的结果行动、选择、思考,于是,在相当长的时间里,你生活的一部分就是“活在未来”。\n\n## 人际关系的本质\n\n人际关系在本质上还是**交易**。明白这一点,就能更清楚的看清楚关于**贵人**的问题。 \n\n$ 求助别人 != 麻烦别人 $ \n\n求助不是低声下气的行为,而是一种交易。不仅如此,还是一种隐蔽的、`意义巨大的交易`。贵人之所以原因帮助你,是因为他已经看到你的价值。分清楚“求助”、“乞讨”、“添麻烦”、“占便宜”之间的区别。\n\n能够遇到贵人在一定程度上是偶然也是必然,它是自己生活的一面镜子。你是贵人,生活这面镜子就帮你找到更多的贵人。至于是偶然还是必然,其实你是控制不了的。自己首先得是个贵人,才能遇到贵人,甚至更多贵人。最不济,你也已经成为自己的贵人,而且不会轻易离你而去。“遇到贵人”这件事从来不是我们的目的,相反“成为贵人”倒是我们应该努力的方向。在你出手相助的那一瞬间,你已经得到了自然的回报。\n\n\n\n12条遇到贵人的原则:\n\n1. 乐观的人更容易成为他人的贵人\n2. 贵人更容易遇到贵人\n3. 能帮助他人进步,才是真正的贵人\n4. 优秀的、值得尊重的人,更容易获得帮助。\n5. 乐于分享的人容易获得帮助\n6. 不给他人制造负担的人容易获得帮助\n7. 不以求助为耻的人容易获得帮助\n8. 求助的时候不仅仅用金钱作为回报,帮助他人的时候也不应该收取金钱回报。\n9. 贵人不一定是牛人,贵人通常“以和为贵”。\n10. 很多时候,人们的成功,来源于大量的人**希望看到他成功**。反过来,如果大量的人不愿意看到某人成功,那么这个人真的很难获得所谓的“贵人相助”\n11. 正在做“正确”事情,更容易获得贵人相助。也就是所谓的“**得道多助**”。\n12. 活在未来的人更容易遇到贵人,因为别人能在他身上看到**未来**。\n\n\n\n\n\n## 资本的定义\n\n钱和资本不是一样的东西,正如砖头和房子不是一回事。钱要成为资本必须满足三个基本要素:\n\n1. 资金的金额大小\n2. 资金的使用时限\n3. 资金背后的智慧\n\n\n\n残酷的事实,大多数人其实不配站在资本之后。好消息是资本背后的实力是可以习得的。不能被自己心平气和判上无期徒刑的资金,就别假装资本出来混迹江湖。大多数人在股票市场上“投资”的不是资本,而是“装傻充愣的资金”而已。\n\n\n\n\n\n# 暂时不知道往哪里分\n\n- 好的工具应该让人离开它,而不是黏住它。\n- 你创造财富能力取决于你能给别人创造多少真正的价值。(只有你觉得有价值的话,是几乎没有什么意义的)。\n\n\n\n\n\n\n\n财富自由之路 - 思维导图 ([看全景导图请点击链接](uploads/road-to-asset-freedom-mindmap.html))\n\n
","slug":"读书笔记/财富自由之路-李笑来","published":1,"updated":"2019-08-14T06:36:09.000Z","_id":"cka1y596e000t4huuu6ed1frz","comments":1,"layout":"post","photos":[],"link":"","content":"

进度:10课

\n

哲学层面

\n

金钱、时间、注意力

\n

钱不是最重要,它可以再生。时间也不是,它本质上不属于你,你只能试着与它做朋友。注意力是自己可以做主的。必须把宝贵的注意力全部放在自己身上。放在自己的哪儿上?答:“成长”。不珍惜自己注意力的人最终注定是贫穷的,因为他们终生被收割,不可能有真正有价值的产出,怎么可能最终变得富有?另外,要放在自己的真爱上,以及对整个社会真正有贡献的事情上。(对于后两者,关注的焦点还是“成长”。)

\n

注意力才是你人生最宝贵的财富(不是金钱和时间),你的一切价值都是你的注意力的产出。

\n
\n

俗三个大坑:1. 莫名其妙的凑热闹。2. 心急火燎的随大流。3. 操碎了别人的心 (万众创业关你屁事,干好自己的活)。

\n
\n

金钱、时间和注意力的比较:$ 注意力 > 时间 > 金钱 $

\n\n

:question: 时间和金钱谁更重要。

\n
\n

答案是时间。因为财富自由的定义就是“不为生活需要出售时间”。另外一个角度是,“花钱买你的时间更划算”。

\n
\n

:question: 注意力和时间更重要。

\n
\n

注意力是能让你有所产出的唯一资源!而时间不一定是你的,时间不会自动产出。(李笑来: 花大量时间与老婆沟通,陪伴,以便换来自己集中注意力工作的机会。)

\n
\n

合作与信任

\n

追求百分百的安全感,肯定会把自己困在了永恒的当下。必须放弃一部分安全感,才能有深入的、长期的观察和思考。打破枷锁的方法:

\n
    \n
  1. 放弃部分安全感,才能获得进步。
  2. \n
  3. 通过有效社交,补全主动放弃的安全感。
  4. \n
\n

:bookmark:【合作】​ 的本质是大家各自放弃一小部分安全感,并把那一部分安全感交给合作方来保障。

\n

:bookmark: 【信任】就是相信对方不会利用自己主动放弃的那一部分安全感。所谓缺乏安全感,就是不相信别人竟然可以不利用自己放弃的那一部分安全感,所以只能自己去搞定百分之百的安全感,让人心力交瘁。

\n\n

活在真实中

\n

如果想活在真实的世界,就要勇于面对「真实」。要搞清楚以下几个概念。

\n

什么算落后

\n
    \n
  1. \n

    20%之后都是落后,因为世界20%的人占了有限资源的80%。在人工智能和新技术时代,可能1%之后都算落后。将来可能是千分之一,万分之一之后都算。

    \n
  2. \n
  3. \n

    我们每个人都已经可以尽量感知到这个世界的全部。所以要对自己是否处在落后状态有清晰认知。

    \n
  4. \n
  5. \n

    我们对知识的渴求已经变成害怕落后。这是种危机感和焦虑,但它能帮我们持续进步,摆脱落后。

    \n
  6. \n
\n

乌比冈湖效应:Lake Wobegon Effect 每个人都自认高于平均水平。

\n

邓宁- 克鲁格效应 :Dunning-Kruger Effect 能力欠缺的人有一种虚幻的自我优越感,错误的认为自己比真实情况更加优秀。

\n

麻烦守恒定律:以前因为怕麻烦二省去的麻烦,在未来的某一天,或者未来的某一时刻,一定会以另一种形式呈现在你面前。麻烦不会无缘无故的消失,问题也不会无缘无故的解决。

\n

元认知能力

\n

:pencil:指对自己的思考过程的认知和理解

\n

元认知能力起作用的三个步骤:

\n
    \n
  1. 哦,原来我是这么想的。
  2. \n
  3. 嗯?我这么想难道是不对的吗?
  4. \n
  5. 啊!我应该这么想才对。。。。
  6. \n
\n

认知能力好比是马,而元认知能力是马车夫。所谓可以用来解放自己的“心智”,指的就是具备足够的元认知能力的大脑。人与人之间的技能差异,证据确凿来自于“刻意锻炼”。而一个人能做到“刻意锻炼”,唯一能够仰仗的就是元认知能力。

\n\n

我们知道我们想要改变的,能够改变的,不是“现在的自己”,而是“将来的自己”。通过刻意练习提高元认知能力的三个方法:坐享、兴趣、反思。

\n\n

竞争力

\n

多维竞争

\n

😂 据说绝大多数人的幸福感是建立在比较之上的。有个玩笑:所谓的幸福就是自己的收入总比妹夫的收入多百分之二十。。。。。

\n

😂 一般人所谓的“成长”,就是不断的把别人比下去的过程。

\n

维度在生活上有三个体现:

\n
    \n
  1. 生活是有多个维度的。
  2. \n
  3. 在多个维度打造竞争力。
  4. \n
  5. 至少在一个维度上足够突出。凡事都是有成本。处处平庸是不行的。
  6. \n
\n

面对维度,要有以下意识:

\n\n

应用层面

\n

「活在未来」

\n

如何活在未来

\n
    \n
  1. 对未来要有个预测
  2. \n
  3. 那个预测需要时间才能得到结果
  4. \n
  5. 笃信你的预测是正确的。
  6. \n
  7. 于是你按照那个预测的结果行动、选择、思考。
  8. \n
  9. 你终将走到那个结果出现的时刻
  10. \n
  11. 最终证明你的预测是正确的。
  12. \n
  13. 那么,由于你提前按未来正确的结果行动、选择、思考,于是,在相当长的时间里,你生活的一部分就是“活在未来”。
  14. \n
\n

人际关系的本质

\n

人际关系在本质上还是交易。明白这一点,就能更清楚的看清楚关于贵人的问题。

\n

$ 求助别人 != 麻烦别人 $

\n

求助不是低声下气的行为,而是一种交易。不仅如此,还是一种隐蔽的、意义巨大的交易。贵人之所以原因帮助你,是因为他已经看到你的价值。分清楚“求助”、“乞讨”、“添麻烦”、“占便宜”之间的区别。

\n

能够遇到贵人在一定程度上是偶然也是必然,它是自己生活的一面镜子。你是贵人,生活这面镜子就帮你找到更多的贵人。至于是偶然还是必然,其实你是控制不了的。自己首先得是个贵人,才能遇到贵人,甚至更多贵人。最不济,你也已经成为自己的贵人,而且不会轻易离你而去。“遇到贵人”这件事从来不是我们的目的,相反“成为贵人”倒是我们应该努力的方向。在你出手相助的那一瞬间,你已经得到了自然的回报。

\n

12条遇到贵人的原则:

\n
    \n
  1. 乐观的人更容易成为他人的贵人
  2. \n
  3. 贵人更容易遇到贵人
  4. \n
  5. 能帮助他人进步,才是真正的贵人
  6. \n
  7. 优秀的、值得尊重的人,更容易获得帮助。
  8. \n
  9. 乐于分享的人容易获得帮助
  10. \n
  11. 不给他人制造负担的人容易获得帮助
  12. \n
  13. 不以求助为耻的人容易获得帮助
  14. \n
  15. 求助的时候不仅仅用金钱作为回报,帮助他人的时候也不应该收取金钱回报。
  16. \n
  17. 贵人不一定是牛人,贵人通常“以和为贵”。
  18. \n
  19. 很多时候,人们的成功,来源于大量的人希望看到他成功。反过来,如果大量的人不愿意看到某人成功,那么这个人真的很难获得所谓的“贵人相助”
  20. \n
  21. 正在做“正确”事情,更容易获得贵人相助。也就是所谓的“得道多助”。
  22. \n
  23. 活在未来的人更容易遇到贵人,因为别人能在他身上看到未来
  24. \n
\n

资本的定义

\n

钱和资本不是一样的东西,正如砖头和房子不是一回事。钱要成为资本必须满足三个基本要素:

\n
    \n
  1. 资金的金额大小
  2. \n
  3. 资金的使用时限
  4. \n
  5. 资金背后的智慧
  6. \n
\n

残酷的事实,大多数人其实不配站在资本之后。好消息是资本背后的实力是可以习得的。不能被自己心平气和判上无期徒刑的资金,就别假装资本出来混迹江湖。大多数人在股票市场上“投资”的不是资本,而是“装傻充愣的资金”而已。

\n

暂时不知道往哪里分

\n\n

财富自由之路 - 思维导图 (看全景导图请点击链接

\n
","site":{"data":{}},"excerpt":"

\"图片来自七牛\"

","more":"

进度:10课

\n

哲学层面

\n

金钱、时间、注意力

\n

钱不是最重要,它可以再生。时间也不是,它本质上不属于你,你只能试着与它做朋友。注意力是自己可以做主的。必须把宝贵的注意力全部放在自己身上。放在自己的哪儿上?答:“成长”。不珍惜自己注意力的人最终注定是贫穷的,因为他们终生被收割,不可能有真正有价值的产出,怎么可能最终变得富有?另外,要放在自己的真爱上,以及对整个社会真正有贡献的事情上。(对于后两者,关注的焦点还是“成长”。)

\n

注意力才是你人生最宝贵的财富(不是金钱和时间),你的一切价值都是你的注意力的产出。

\n
\n

俗三个大坑:1. 莫名其妙的凑热闹。2. 心急火燎的随大流。3. 操碎了别人的心 (万众创业关你屁事,干好自己的活)。

\n
\n

金钱、时间和注意力的比较:$ 注意力 > 时间 > 金钱 $

\n\n

:question: 时间和金钱谁更重要。

\n
\n

答案是时间。因为财富自由的定义就是“不为生活需要出售时间”。另外一个角度是,“花钱买你的时间更划算”。

\n
\n

:question: 注意力和时间更重要。

\n
\n

注意力是能让你有所产出的唯一资源!而时间不一定是你的,时间不会自动产出。(李笑来: 花大量时间与老婆沟通,陪伴,以便换来自己集中注意力工作的机会。)

\n
\n

合作与信任

\n

追求百分百的安全感,肯定会把自己困在了永恒的当下。必须放弃一部分安全感,才能有深入的、长期的观察和思考。打破枷锁的方法:

\n
    \n
  1. 放弃部分安全感,才能获得进步。
  2. \n
  3. 通过有效社交,补全主动放弃的安全感。
  4. \n
\n

:bookmark:【合作】​ 的本质是大家各自放弃一小部分安全感,并把那一部分安全感交给合作方来保障。

\n

:bookmark: 【信任】就是相信对方不会利用自己主动放弃的那一部分安全感。所谓缺乏安全感,就是不相信别人竟然可以不利用自己放弃的那一部分安全感,所以只能自己去搞定百分之百的安全感,让人心力交瘁。

\n\n

活在真实中

\n

如果想活在真实的世界,就要勇于面对「真实」。要搞清楚以下几个概念。

\n

什么算落后

\n
    \n
  1. \n

    20%之后都是落后,因为世界20%的人占了有限资源的80%。在人工智能和新技术时代,可能1%之后都算落后。将来可能是千分之一,万分之一之后都算。

    \n
  2. \n
  3. \n

    我们每个人都已经可以尽量感知到这个世界的全部。所以要对自己是否处在落后状态有清晰认知。

    \n
  4. \n
  5. \n

    我们对知识的渴求已经变成害怕落后。这是种危机感和焦虑,但它能帮我们持续进步,摆脱落后。

    \n
  6. \n
\n

乌比冈湖效应:Lake Wobegon Effect 每个人都自认高于平均水平。

\n

邓宁- 克鲁格效应 :Dunning-Kruger Effect 能力欠缺的人有一种虚幻的自我优越感,错误的认为自己比真实情况更加优秀。

\n

麻烦守恒定律:以前因为怕麻烦二省去的麻烦,在未来的某一天,或者未来的某一时刻,一定会以另一种形式呈现在你面前。麻烦不会无缘无故的消失,问题也不会无缘无故的解决。

\n

元认知能力

\n

:pencil:指对自己的思考过程的认知和理解

\n

元认知能力起作用的三个步骤:

\n
    \n
  1. 哦,原来我是这么想的。
  2. \n
  3. 嗯?我这么想难道是不对的吗?
  4. \n
  5. 啊!我应该这么想才对。。。。
  6. \n
\n

认知能力好比是马,而元认知能力是马车夫。所谓可以用来解放自己的“心智”,指的就是具备足够的元认知能力的大脑。人与人之间的技能差异,证据确凿来自于“刻意锻炼”。而一个人能做到“刻意锻炼”,唯一能够仰仗的就是元认知能力。

\n\n

我们知道我们想要改变的,能够改变的,不是“现在的自己”,而是“将来的自己”。通过刻意练习提高元认知能力的三个方法:坐享、兴趣、反思。

\n\n

竞争力

\n

多维竞争

\n

😂 据说绝大多数人的幸福感是建立在比较之上的。有个玩笑:所谓的幸福就是自己的收入总比妹夫的收入多百分之二十。。。。。

\n

😂 一般人所谓的“成长”,就是不断的把别人比下去的过程。

\n

维度在生活上有三个体现:

\n
    \n
  1. 生活是有多个维度的。
  2. \n
  3. 在多个维度打造竞争力。
  4. \n
  5. 至少在一个维度上足够突出。凡事都是有成本。处处平庸是不行的。
  6. \n
\n

面对维度,要有以下意识:

\n\n

应用层面

\n

「活在未来」

\n

如何活在未来

\n
    \n
  1. 对未来要有个预测
  2. \n
  3. 那个预测需要时间才能得到结果
  4. \n
  5. 笃信你的预测是正确的。
  6. \n
  7. 于是你按照那个预测的结果行动、选择、思考。
  8. \n
  9. 你终将走到那个结果出现的时刻
  10. \n
  11. 最终证明你的预测是正确的。
  12. \n
  13. 那么,由于你提前按未来正确的结果行动、选择、思考,于是,在相当长的时间里,你生活的一部分就是“活在未来”。
  14. \n
\n

人际关系的本质

\n

人际关系在本质上还是交易。明白这一点,就能更清楚的看清楚关于贵人的问题。

\n

$ 求助别人 != 麻烦别人 $

\n

求助不是低声下气的行为,而是一种交易。不仅如此,还是一种隐蔽的、意义巨大的交易。贵人之所以原因帮助你,是因为他已经看到你的价值。分清楚“求助”、“乞讨”、“添麻烦”、“占便宜”之间的区别。

\n

能够遇到贵人在一定程度上是偶然也是必然,它是自己生活的一面镜子。你是贵人,生活这面镜子就帮你找到更多的贵人。至于是偶然还是必然,其实你是控制不了的。自己首先得是个贵人,才能遇到贵人,甚至更多贵人。最不济,你也已经成为自己的贵人,而且不会轻易离你而去。“遇到贵人”这件事从来不是我们的目的,相反“成为贵人”倒是我们应该努力的方向。在你出手相助的那一瞬间,你已经得到了自然的回报。

\n

12条遇到贵人的原则:

\n
    \n
  1. 乐观的人更容易成为他人的贵人
  2. \n
  3. 贵人更容易遇到贵人
  4. \n
  5. 能帮助他人进步,才是真正的贵人
  6. \n
  7. 优秀的、值得尊重的人,更容易获得帮助。
  8. \n
  9. 乐于分享的人容易获得帮助
  10. \n
  11. 不给他人制造负担的人容易获得帮助
  12. \n
  13. 不以求助为耻的人容易获得帮助
  14. \n
  15. 求助的时候不仅仅用金钱作为回报,帮助他人的时候也不应该收取金钱回报。
  16. \n
  17. 贵人不一定是牛人,贵人通常“以和为贵”。
  18. \n
  19. 很多时候,人们的成功,来源于大量的人希望看到他成功。反过来,如果大量的人不愿意看到某人成功,那么这个人真的很难获得所谓的“贵人相助”
  20. \n
  21. 正在做“正确”事情,更容易获得贵人相助。也就是所谓的“得道多助”。
  22. \n
  23. 活在未来的人更容易遇到贵人,因为别人能在他身上看到未来
  24. \n
\n

资本的定义

\n

钱和资本不是一样的东西,正如砖头和房子不是一回事。钱要成为资本必须满足三个基本要素:

\n
    \n
  1. 资金的金额大小
  2. \n
  3. 资金的使用时限
  4. \n
  5. 资金背后的智慧
  6. \n
\n

残酷的事实,大多数人其实不配站在资本之后。好消息是资本背后的实力是可以习得的。不能被自己心平气和判上无期徒刑的资金,就别假装资本出来混迹江湖。大多数人在股票市场上“投资”的不是资本,而是“装傻充愣的资金”而已。

\n

暂时不知道往哪里分

\n\n

财富自由之路 - 思维导图 (看全景导图请点击链接

\n
"},{"title":"斯多葛主义手册","date":"2019-08-03T19:16:47.000Z","urlname":"storic-summary","toc":true,"_content":"\n\n\n![](https://github.com/maiernte/img/raw/master/collection/马可奥勒留.jpg)\n\n世间的事,有些可控,有些不可控。可控的有:观点,追求,欲望,和喜恶等。这些都是我们自己可以做出选择的。不可控的是身体,财物,名声,指令等。这些我们都无法选择。\n\n\n\n1. 世间的事,有些可控,有些不可控。可控的有:观点,追求,欲望,和喜恶等。这些都是我们自己可以做出选择的。不可控的是身体,财物,名声,指令等。这些我们都无法选择。\n\n 可控范围之内的东西在本质上是自由的,不被束缚、阻碍的。那些不可控的是虚的,是被奴役的,是我们受控于他人。记住,如果你觉得那些不可控的事物是自由的,那些受控于别人的也是你的,那么你就会被控制,被束缚。你会悲痛,你会受扰,你会指责神以及他人。但如果你只专注于你所能控制的,不被他人所拥有的干扰,那么就没有人能够影响你、束缚你。并且,你不会把过错推在他人身上。你不会去做违背你的意志的事。你不会有敌人。你也不会被伤害。\n\n 把这些当做你的目标,不让自己受那些没有意义的事诱惑,哪怕就一点点也不可以。放弃那些不可控的。如果你既想把握住可控的,又想拥有财富和权力,那么你将会什么都得不到,更不用说幸福和自由-因为幸福和自由是依赖于可控事物。\n\n 尽你最大的努力。这样你就可以对看似艰难的每一件事说:“你只不过是看起来艰难而已。” 然后比照你为自己制定的原则:这件事是否可控。如果在你控制范围之外,那么结果就无关乎于你。\n\n2. 欲望要求你去追求你想要的;厌恶则让你尽量避免你所讨厌的。但是,如果你得不到你想要的,你就会十分失望;如果你无法避免你所讨厌的,那你就会被厌恶扭曲。那么,如果你只讨厌那些在你出自本质所做选择的对立事物(即在你控制范围内你不会选择的事物),那么你就永远不需要去为之伤神。但是,如果你厌恶疾病、死亡、贫穷等你无法选择和改变的,那你就会被厌恶扭曲。不厌恶你所不能控制的,把厌恶限制在和你本性对立的事物。但是,就目前来说,压制你的欲望:因为如果你追求任何可控范围之外的事物,那你就必然会失望。不要轻易追求或者厌恶。\n\n3. 对于给你带来乐趣、有用处以及你十分喜欢的东西,从最不重要的事情开始,记得提醒你自己:他们真正的本质是什么。比如说,你很喜欢某个陶瓷杯,提醒你自己那只是因为你喜欢陶瓷杯而已,而不在于具体是哪个杯子。这样,如果杯子碎了,你也不会太伤心。当你亲吻你的家人时,提醒你自己你只是在亲吻和你亲近的人,这样当他们离世时,你就不会太难过。\n\n4. 当你做事情时,提醒你自己事情的本质是什么,你可能遇到哪些情况。比如说洗澡。在你洗澡之前,先想想洗澡时会发生哪些事情。有的人可能会把水溅得哪都是,有人可能会推娜,有人会诅咒,有人会偷东西。这样你在洗澡之前就可以跟自己说:“我现在要去洗澡了,任何这些事都有可能发生,但是这不是我能控制的,所以我会保持好的心态”。如果你以同样的心态去对待任何其他事情,你内心的平和就不会被打扰。因为你可以对自己说:”我希望的不仅仅是洗澡,还有不被任何意外困扰”。\n\n5. 人内心困扰时,通常不是被事物本身困扰,而是被他们自己的原则和概念所困扰。比如说,死亡本身并不可怕,要不然苏格拉底面临死亡时该有多么惊慌。我们对死亡的恐惧是源于我们对死亡的概念:死亡是可怕的。当我们被困扰、阻碍,伤心难过时,我们不要从事物本身或者他人身上找原因,而应该反省我们自己,还有我们的原则。一个还不通明的人,会把自己的糟糕情况怪罪于他人。一个刚刚开始学习处理这些情况的人,会从自己身上找原因。而一个已经通彻的人,既不会怪罪别人,也不会苛求自己。\n\n6. 不要为任何身外之物骄傲。一匹马可以因为自己的英爽豪气自豪,因为这是它本身拥有的。但是如果你因为拥有这样一匹马儿骄傲,事实上,你所自豪的,不过是马所拥有的好。那么,什么才是属于你的呢?你对事物的反应和态度。如果你对任何事物的形态的处之泰然,那么你就可以为你的理性自豪,因为这是属于你的。\n\n7. 想象以下情况:在一次航海旅行中,你的船抛锚靠岸了,你上岸去找水,途中你还捡了些你喜欢的贝壳,或者买个洋葱。但是,你的所有注意力必须一直集中在那艘船上,注意船长什么时候呼叫大家上船继续航行。当船长呼叫时,你必须立刻放下手中所有的东西,否则你就会被手脚捆绑得像只羊一样抛到船上。生活也是这样。生活给你老婆孩子,而不是洋葱贝壳。如果生活的船长呼叫了,你必须离开他们,立马跑到船上,而不是光顾着他们。如果你年纪大了,那你就不能离开船太远,否则你可能来不及回到船上。\n\n8. 不要苛求生活给予你所有你想要的,该发生的就会发生,随遇而安就好。\n\n9. 疾病影响的只是你的身体,而不是你选择的能力,除非那是你的选择。瘸的是腿,而不是你的脑子。不管发生什么事,只要这么跟自己说,你就会明白困难阻碍的是事物,而不是你。\n\n10. 对于每一件发生的事,检视你自己的能力,问你自己能够用哪些能力从每一件事情中获得什么适当的用处。遇到一个十分有吸引力的人时,你就会发现你的自控就是你的能力。当你痛苦时,你会发现自己的坚强。听到坏话时,你会发现自己的耐心。形成了这样的习惯之后,你就不会被事物的表象所影响。\n\n11. 不要说:“我失去了什么”。而应该说:“我归还了什么”。如果你的孩子或者妻子不幸离世了,你不是失去他们了,而是他们回归了。如果你的房子被夺走了,同样的,你是归还它们了。你可能会说:“可是那些夺走我房子的人是坏人!“。可是,给予你的人让谁来夺走你的房子真的那么重要吗?当你拥有时,照顾好它,但不要把它当做永久财物,就当自己是一个在那暂住的旅行者。\n\n12. 如果你想要提高自己,那就要拒绝以下思考方式:“如果我忽视那些琐事,那我就没有收入;如果我不更正我的仆人,那他们就会变坏”。 如果能够免于悲伤和恐惧,即使死于饥饿,那也比富得流油但备受精神困扰好得多。比起坏仆人,难道你的开心不是更重要吗?\n\n 如果你想要让自己变得更好,那就从小事做起。油洒了,酒被偷了,没关系,告诉你自己:“那只不过是平静生活的一点点代价。任何事情都是有代价的”。当你召集你的仆人时,他们可能不会来,也可能来了但是做的事情不合你意。但是他们并没有重要得以至于你必须打破自己的平静。\n\n13. 如果你想要让自己变得更好,那就不要在乎被人认为你是愚蠢的。不要希望别人认为你无所不知。即使你看上去好像对别人来说很重要,也不要被这种虚名欺骗。因为想要既保持内心平和又拥有外在事物是非常困难的。当你专注于二者之一时,你必然会忽略剩下的那个。\n\n14. 如果你希望你的家人、朋友长生不老,那是很愚蠢的想法。因为生死是在你控制范围之外的,是关乎他人的。同样地,如果你希望你的仆人不犯错,那你和傻瓜无异,因为你希望错误不是错误。但是,如果你希望你的欲望不带来失望,那是在你所能控制的范围之内的。练习控制你所能控制的。一个能够控制自己的喜恶的人,是自己生活的主人。这样的人,是真正自由的,不会成为被自己的欲望控制的奴隶,不会喜欢或者厌恶那些受别人控制的事物。\n\n15. 记住生活就像是一个晚餐聚会一样。如果别人递给你一盘食物,你应该伸出手去接,舀起适当份量给自己。如果盘子从你身边递过,不要试图去截取。如果还没轮到你这,不要起身去拿,而是等着别人递到你面前。用相同的态度对待孩子,配偶,财物,公共职位,这样你最终自然就会成为诸神宴会的搭档。如果你不仅能够做到这些,还能够做到不去拿你面前的食物,甚至是有能力拒绝你自己的欲望,这样你不仅仅能够成为诸神宴会的搭档,你还能进入他们的国度,成为为他们的一员。像Diogenes, Heraclitus这些人就是因为他们的尊贵行为而被视为神一般神圣。\n\n16. 当你看到别人因为孩子出国了,或者离世了,或者因为被琐事困扰而哭泣伤心时,不要让这些情感表象误导你。你必须作出自己的判断,明白他的伤心难过不是因为发生的事情本身,因为其他同样身处其中的人并没有受到同样的影响。他之所以受到那么大的困扰,是因为他自己本身对事情的判断。不要让自己和他一样受影响,不要让自己一样受困扰,不管是外在表现还是内心感受上。\n\n17. 记住你只是一出戏里的一个演员,而戏份角色并不是由你决定的。不管角色故事长短,不管你是一个穷人,瘸子,政府官员,或者是一个很私密的人,把你的角色演好演自然了就行。把分配给你的角色演好,那是你的本分;而到底是哪个角色,那不是由你决定的。\n\n18. 如果一只乌鸦向你预示不幸的事即将发生,不要让你内心的平静被这个表象破坏。要即刻告诉自己,“我不知道会发生什么,我不知道我的身体,财物,名声,或者家人会受什么影响,如果我愿意理性地去想,那么所有的这些恶兆就会变成幸运,因为我可以控制我要用什么态度去对待这些事情。不管发生什么,我都可以从中获得对我有利的。\n\n19. 如果你不去参与在你控制范围之外的任何战斗,那你就不会被打败。当你看到那些声名显赫,社会地位高,或者在任何方面做得很好的人,不要着急认为他们是开心的。因为如果我们清楚明白幸福只在于我们所能够控制的范围内,那我们就不会去羡慕或者攀比。不要向往头衔,而是要向往内心自由和平静。而要做到这一点,唯一的途径是要看轻我们控制范围之外的一切事物。\n\n20. 记住,那些对你出言不逊或者动手的人他本身并不是一种羞辱,而是代表那些言行的原则让你感觉到被羞辱。如果有人激怒你了,那是你对这种行为的观点激怒了你。试着不要被事情的表象牵引你的情感。给予适当的时间和稍作休息,你就能够很好地调整控制自己的情感。\n\n21. 把死亡和流放这些看似可怕的事看作是日常,那你就赢了。不用害怕贫穷,也不要刻意贪求任何东西。\n\n22. 如果你真心希望从哲学中获益,那么就要做好被众人嘲笑的准备:“她这是准备要成为一个哲学家呢”,“瞧她那傲慢的样子”……这个时候,你该做的,不是摆起傲慢的样子,而是要以神圣的态度忠诚于你所认定的,这样总有一天嘲笑你的人会开始尊敬你崇拜你。但是如果你被这些嘲笑打败,那你就成了双重的笑话。\n\n23. 如果你为了取悦他人而把你的注意力转移到那些外在的你无法控制的事物上,那么恭喜你,你已经成功地毁了你自己的生活了。\n\n24. 不要让以下这些思考方式困扰你:“我将会颜面丢尽,而且什么都不是。”耻辱是邪恶的,我们不应该被耻辱感所控制。因为获取权力或着被人嘲笑,这些都在你的控制范围之外。我们不用为任何在我们控制范围之外的事而感到耻辱。在我们可控范围之内,我们是自由的,能够左右我们自己的事情,是自我的主人-从这个角度看,我们永远不会什么都不是。“可是我帮不了我的朋友啊”,你可能会这么说。可是,怎么算是帮助朋友呢?你不能给他们钱,或者帮他们成为罗马市民。这些都是你所能控制范围之内的,是他们自己应该处理的事情。而且,如果这些都是你自己所没有的,那你怎么能够给他们呢?你可能会说:“如果我帮助他们获得这些的话,说不定我也能够得到一份呢“。如果我能够在保存我自己的尊严,忠诚和思想得到这些的话,请你帮我指明道路。可是如果你要我损害自己去得到你的利益,那这样的做法不仅不公平,而且愚蠢至极。\n\n25. 如果别人,而不是你,被邀请去宴会,或者被赞美,或者被别人咨询,不要懊恼。如果这些是好事,你应该为他人高兴。如果是坏事,不要难过。记住:这些都是在你的控制范围之外的,这样的对待一般是有对应的代价的。如果你不愿意付出这样的代价而希望得到同样的对待,那是不公平的。比如说别人用50分买了一棵生菜,但是你不想花这50分,那你就不应该认为拥有生菜的人占了便宜。那个人付出50分得到了生菜,而你口袋里还有那没有花出去的50分。同理,宴会邀请,别人的赞美,这些都是有代价的。如果你觉得这些对你是有价值的,那你就要付出同等的价值去拥有。如果你不付出就想要得到这些,那么你就是个贪得无厌的傻瓜。换个角度想,在决定不和别人交换价值的时候,你真的什么都没有得到吗?不是的:你得到了不赞美你不想赞美的人的自由,而且也不需要容忍你不想容忍的行为。\n\n26. 记住:很多事情不应该分自我或者他人。举个例子,如果邻居家的孩子打破了个杯子或者其他什么东西,我们很容易会说:“没事的,打碎东西是正常的”。可是如果打碎的是你自己的杯子呢?你应该作出相同的反应,而不是心生懊恼。同理,当别人的孩子或者妻子去世了,我们知道死亡的悲剧有时候是不可避免的,但是如果发生在我们自己身上的时候,我们却心如刀割。但是,我们应该清醒的认识到类似的悲剧不是我们能够控制的,我们所能够控制的是自己的情绪和反应,因为即使是发生在自己的身上,死亡本身并没有因为我们和死者的关系而变的更糟糕。\n\n27. 立一个靶子的目的,不是为了射失它(靶子的目的都是为了让人射中它)。那么同样的道理,大道创造出一个“恶”的事物(至少看起来如此),不是为了让人绕开它。\n\n28. 如果别人把你的身体交给一个路上遇到的陌生人,你一定会很生气。可是当别人用恶语打击你的时候,你为什么要心甘情愿地让别人控制你的思想,困惑你呢?\n\n29. 做每件事情都要考虑缘由和后果之后才能开始行动。如果你兴高采烈地开始而没有考虑可能发生的后果,当某些不好的后果开始出现时,你就会停止前进。拿参加奥林匹克赛事为例子。如果你把所有前因后果都考虑周全后认为参加比赛对你时有益的,那就全力以赴。其中,应该考虑的事情包括:你要遵守规则,节制饮食;不管风吹日晒雨淋都要雷打不动地坚持按时锻炼;你不能喝凉水活着酒。你必须全身心地、完全忘我地投入训练。而且,要做思想准备准备,比赛中你有可能会摔入沟里,胳膊脱臼,脚踝受伤,吃入尘土,被鞭打,甚至最后以失败告终。当你评估完所有的可能性之后还是一心想比赛,那就以战争的姿态出发。否则,你就会像孩子过家家一样:一会扮摔跤手,一会扮角斗士,一会吹喇叭,一会又想参加戏剧演出。这样,即使你什么都做过,但是什么都不是。就想大猩猩一样,你模仿你所看到的一切,不停地换把戏可能是一件好玩的事,但是你很快就玩腻了。你从来都没有完全投入过任何事,没有深度地从各个角度考虑和研究所有相关的细节,而只是凭一时的兴趣蜻蜓点水般地接触了各种行业。有些人当他们看到一个人说话的方式和Euphrates十分相像(不过事实上,真的有人能和Euphrates一样犀利善辩吗?),他们认为自己也能够拥有和哲学家一样的思想。但是,如果你细想一下,如果你想要成为一个摔跤手,那么你必须具备有摔跤手的宽阔肩膀,强有力的背部和大腿。但是每一个人的身体构造都是不一样的,你必须具有必备的条件才能称为一个好的摔跤手。同理,要想成为一个哲学家,你不能像你现在这样随心所欲地吃喝,不能让愤怒和不满控制你的情绪,你必须细心观察,劳作,控制自己的欲望,你必须能够忍受孤独,仆人的不敬,和外人的嘲笑,你必须能够接受别人在其他方面做得比你好。如果你已经仔细考虑过这些情况,如果你认为如果做到以上这些可以让你享受自由和宁静,那就尽情去追求哲学家的道路。如果你无法做到这些的话,那么就请不要继续,不要像孩子一样,一会试试做哲学,一会又想当政治家,演讲者,或者凯撒的军官。这些追求是互相矛盾的,你只能成为其中一个,不管做得好坏。你必须培养你自己内在的能够掌控行为的能力,或者外在的技术,二者只能取其一。\n\n30. 一个人的责任是由和别人的关系定义和衡量的。如果一个人拥有父亲的角色,那么他就有以下权利:他的孩子要照顾他,遵从他,耐心听他训话和教导。那如果他不是一个好父亲呢?他也应该受到同等的对待,因为我们无法选择我们的父亲是谁。不管他做了什么,你必须做到让自己心安理得。因为只有你能够让别人的行为伤害到你。当你觉得你被伤害了,那你就会被伤害。如果你以同样的逻辑看待邻居,市民,将军这些不同的角色,你就能够清楚地明白与这些角色相对应的社会责任。","source":"_posts/读书笔记/斯多葛主义手册.md","raw":"---\ntitle: 斯多葛主义手册\ndate: 2019-08-03 21:16:47\nurlname: storic-summary\ntoc: true\ntags: [哲理, 书籍]\ncategories: [读书笔记]\n---\n\n\n\n![](https://github.com/maiernte/img/raw/master/collection/马可奥勒留.jpg)\n\n世间的事,有些可控,有些不可控。可控的有:观点,追求,欲望,和喜恶等。这些都是我们自己可以做出选择的。不可控的是身体,财物,名声,指令等。这些我们都无法选择。\n\n\n\n1. 世间的事,有些可控,有些不可控。可控的有:观点,追求,欲望,和喜恶等。这些都是我们自己可以做出选择的。不可控的是身体,财物,名声,指令等。这些我们都无法选择。\n\n 可控范围之内的东西在本质上是自由的,不被束缚、阻碍的。那些不可控的是虚的,是被奴役的,是我们受控于他人。记住,如果你觉得那些不可控的事物是自由的,那些受控于别人的也是你的,那么你就会被控制,被束缚。你会悲痛,你会受扰,你会指责神以及他人。但如果你只专注于你所能控制的,不被他人所拥有的干扰,那么就没有人能够影响你、束缚你。并且,你不会把过错推在他人身上。你不会去做违背你的意志的事。你不会有敌人。你也不会被伤害。\n\n 把这些当做你的目标,不让自己受那些没有意义的事诱惑,哪怕就一点点也不可以。放弃那些不可控的。如果你既想把握住可控的,又想拥有财富和权力,那么你将会什么都得不到,更不用说幸福和自由-因为幸福和自由是依赖于可控事物。\n\n 尽你最大的努力。这样你就可以对看似艰难的每一件事说:“你只不过是看起来艰难而已。” 然后比照你为自己制定的原则:这件事是否可控。如果在你控制范围之外,那么结果就无关乎于你。\n\n2. 欲望要求你去追求你想要的;厌恶则让你尽量避免你所讨厌的。但是,如果你得不到你想要的,你就会十分失望;如果你无法避免你所讨厌的,那你就会被厌恶扭曲。那么,如果你只讨厌那些在你出自本质所做选择的对立事物(即在你控制范围内你不会选择的事物),那么你就永远不需要去为之伤神。但是,如果你厌恶疾病、死亡、贫穷等你无法选择和改变的,那你就会被厌恶扭曲。不厌恶你所不能控制的,把厌恶限制在和你本性对立的事物。但是,就目前来说,压制你的欲望:因为如果你追求任何可控范围之外的事物,那你就必然会失望。不要轻易追求或者厌恶。\n\n3. 对于给你带来乐趣、有用处以及你十分喜欢的东西,从最不重要的事情开始,记得提醒你自己:他们真正的本质是什么。比如说,你很喜欢某个陶瓷杯,提醒你自己那只是因为你喜欢陶瓷杯而已,而不在于具体是哪个杯子。这样,如果杯子碎了,你也不会太伤心。当你亲吻你的家人时,提醒你自己你只是在亲吻和你亲近的人,这样当他们离世时,你就不会太难过。\n\n4. 当你做事情时,提醒你自己事情的本质是什么,你可能遇到哪些情况。比如说洗澡。在你洗澡之前,先想想洗澡时会发生哪些事情。有的人可能会把水溅得哪都是,有人可能会推娜,有人会诅咒,有人会偷东西。这样你在洗澡之前就可以跟自己说:“我现在要去洗澡了,任何这些事都有可能发生,但是这不是我能控制的,所以我会保持好的心态”。如果你以同样的心态去对待任何其他事情,你内心的平和就不会被打扰。因为你可以对自己说:”我希望的不仅仅是洗澡,还有不被任何意外困扰”。\n\n5. 人内心困扰时,通常不是被事物本身困扰,而是被他们自己的原则和概念所困扰。比如说,死亡本身并不可怕,要不然苏格拉底面临死亡时该有多么惊慌。我们对死亡的恐惧是源于我们对死亡的概念:死亡是可怕的。当我们被困扰、阻碍,伤心难过时,我们不要从事物本身或者他人身上找原因,而应该反省我们自己,还有我们的原则。一个还不通明的人,会把自己的糟糕情况怪罪于他人。一个刚刚开始学习处理这些情况的人,会从自己身上找原因。而一个已经通彻的人,既不会怪罪别人,也不会苛求自己。\n\n6. 不要为任何身外之物骄傲。一匹马可以因为自己的英爽豪气自豪,因为这是它本身拥有的。但是如果你因为拥有这样一匹马儿骄傲,事实上,你所自豪的,不过是马所拥有的好。那么,什么才是属于你的呢?你对事物的反应和态度。如果你对任何事物的形态的处之泰然,那么你就可以为你的理性自豪,因为这是属于你的。\n\n7. 想象以下情况:在一次航海旅行中,你的船抛锚靠岸了,你上岸去找水,途中你还捡了些你喜欢的贝壳,或者买个洋葱。但是,你的所有注意力必须一直集中在那艘船上,注意船长什么时候呼叫大家上船继续航行。当船长呼叫时,你必须立刻放下手中所有的东西,否则你就会被手脚捆绑得像只羊一样抛到船上。生活也是这样。生活给你老婆孩子,而不是洋葱贝壳。如果生活的船长呼叫了,你必须离开他们,立马跑到船上,而不是光顾着他们。如果你年纪大了,那你就不能离开船太远,否则你可能来不及回到船上。\n\n8. 不要苛求生活给予你所有你想要的,该发生的就会发生,随遇而安就好。\n\n9. 疾病影响的只是你的身体,而不是你选择的能力,除非那是你的选择。瘸的是腿,而不是你的脑子。不管发生什么事,只要这么跟自己说,你就会明白困难阻碍的是事物,而不是你。\n\n10. 对于每一件发生的事,检视你自己的能力,问你自己能够用哪些能力从每一件事情中获得什么适当的用处。遇到一个十分有吸引力的人时,你就会发现你的自控就是你的能力。当你痛苦时,你会发现自己的坚强。听到坏话时,你会发现自己的耐心。形成了这样的习惯之后,你就不会被事物的表象所影响。\n\n11. 不要说:“我失去了什么”。而应该说:“我归还了什么”。如果你的孩子或者妻子不幸离世了,你不是失去他们了,而是他们回归了。如果你的房子被夺走了,同样的,你是归还它们了。你可能会说:“可是那些夺走我房子的人是坏人!“。可是,给予你的人让谁来夺走你的房子真的那么重要吗?当你拥有时,照顾好它,但不要把它当做永久财物,就当自己是一个在那暂住的旅行者。\n\n12. 如果你想要提高自己,那就要拒绝以下思考方式:“如果我忽视那些琐事,那我就没有收入;如果我不更正我的仆人,那他们就会变坏”。 如果能够免于悲伤和恐惧,即使死于饥饿,那也比富得流油但备受精神困扰好得多。比起坏仆人,难道你的开心不是更重要吗?\n\n 如果你想要让自己变得更好,那就从小事做起。油洒了,酒被偷了,没关系,告诉你自己:“那只不过是平静生活的一点点代价。任何事情都是有代价的”。当你召集你的仆人时,他们可能不会来,也可能来了但是做的事情不合你意。但是他们并没有重要得以至于你必须打破自己的平静。\n\n13. 如果你想要让自己变得更好,那就不要在乎被人认为你是愚蠢的。不要希望别人认为你无所不知。即使你看上去好像对别人来说很重要,也不要被这种虚名欺骗。因为想要既保持内心平和又拥有外在事物是非常困难的。当你专注于二者之一时,你必然会忽略剩下的那个。\n\n14. 如果你希望你的家人、朋友长生不老,那是很愚蠢的想法。因为生死是在你控制范围之外的,是关乎他人的。同样地,如果你希望你的仆人不犯错,那你和傻瓜无异,因为你希望错误不是错误。但是,如果你希望你的欲望不带来失望,那是在你所能控制的范围之内的。练习控制你所能控制的。一个能够控制自己的喜恶的人,是自己生活的主人。这样的人,是真正自由的,不会成为被自己的欲望控制的奴隶,不会喜欢或者厌恶那些受别人控制的事物。\n\n15. 记住生活就像是一个晚餐聚会一样。如果别人递给你一盘食物,你应该伸出手去接,舀起适当份量给自己。如果盘子从你身边递过,不要试图去截取。如果还没轮到你这,不要起身去拿,而是等着别人递到你面前。用相同的态度对待孩子,配偶,财物,公共职位,这样你最终自然就会成为诸神宴会的搭档。如果你不仅能够做到这些,还能够做到不去拿你面前的食物,甚至是有能力拒绝你自己的欲望,这样你不仅仅能够成为诸神宴会的搭档,你还能进入他们的国度,成为为他们的一员。像Diogenes, Heraclitus这些人就是因为他们的尊贵行为而被视为神一般神圣。\n\n16. 当你看到别人因为孩子出国了,或者离世了,或者因为被琐事困扰而哭泣伤心时,不要让这些情感表象误导你。你必须作出自己的判断,明白他的伤心难过不是因为发生的事情本身,因为其他同样身处其中的人并没有受到同样的影响。他之所以受到那么大的困扰,是因为他自己本身对事情的判断。不要让自己和他一样受影响,不要让自己一样受困扰,不管是外在表现还是内心感受上。\n\n17. 记住你只是一出戏里的一个演员,而戏份角色并不是由你决定的。不管角色故事长短,不管你是一个穷人,瘸子,政府官员,或者是一个很私密的人,把你的角色演好演自然了就行。把分配给你的角色演好,那是你的本分;而到底是哪个角色,那不是由你决定的。\n\n18. 如果一只乌鸦向你预示不幸的事即将发生,不要让你内心的平静被这个表象破坏。要即刻告诉自己,“我不知道会发生什么,我不知道我的身体,财物,名声,或者家人会受什么影响,如果我愿意理性地去想,那么所有的这些恶兆就会变成幸运,因为我可以控制我要用什么态度去对待这些事情。不管发生什么,我都可以从中获得对我有利的。\n\n19. 如果你不去参与在你控制范围之外的任何战斗,那你就不会被打败。当你看到那些声名显赫,社会地位高,或者在任何方面做得很好的人,不要着急认为他们是开心的。因为如果我们清楚明白幸福只在于我们所能够控制的范围内,那我们就不会去羡慕或者攀比。不要向往头衔,而是要向往内心自由和平静。而要做到这一点,唯一的途径是要看轻我们控制范围之外的一切事物。\n\n20. 记住,那些对你出言不逊或者动手的人他本身并不是一种羞辱,而是代表那些言行的原则让你感觉到被羞辱。如果有人激怒你了,那是你对这种行为的观点激怒了你。试着不要被事情的表象牵引你的情感。给予适当的时间和稍作休息,你就能够很好地调整控制自己的情感。\n\n21. 把死亡和流放这些看似可怕的事看作是日常,那你就赢了。不用害怕贫穷,也不要刻意贪求任何东西。\n\n22. 如果你真心希望从哲学中获益,那么就要做好被众人嘲笑的准备:“她这是准备要成为一个哲学家呢”,“瞧她那傲慢的样子”……这个时候,你该做的,不是摆起傲慢的样子,而是要以神圣的态度忠诚于你所认定的,这样总有一天嘲笑你的人会开始尊敬你崇拜你。但是如果你被这些嘲笑打败,那你就成了双重的笑话。\n\n23. 如果你为了取悦他人而把你的注意力转移到那些外在的你无法控制的事物上,那么恭喜你,你已经成功地毁了你自己的生活了。\n\n24. 不要让以下这些思考方式困扰你:“我将会颜面丢尽,而且什么都不是。”耻辱是邪恶的,我们不应该被耻辱感所控制。因为获取权力或着被人嘲笑,这些都在你的控制范围之外。我们不用为任何在我们控制范围之外的事而感到耻辱。在我们可控范围之内,我们是自由的,能够左右我们自己的事情,是自我的主人-从这个角度看,我们永远不会什么都不是。“可是我帮不了我的朋友啊”,你可能会这么说。可是,怎么算是帮助朋友呢?你不能给他们钱,或者帮他们成为罗马市民。这些都是你所能控制范围之内的,是他们自己应该处理的事情。而且,如果这些都是你自己所没有的,那你怎么能够给他们呢?你可能会说:“如果我帮助他们获得这些的话,说不定我也能够得到一份呢“。如果我能够在保存我自己的尊严,忠诚和思想得到这些的话,请你帮我指明道路。可是如果你要我损害自己去得到你的利益,那这样的做法不仅不公平,而且愚蠢至极。\n\n25. 如果别人,而不是你,被邀请去宴会,或者被赞美,或者被别人咨询,不要懊恼。如果这些是好事,你应该为他人高兴。如果是坏事,不要难过。记住:这些都是在你的控制范围之外的,这样的对待一般是有对应的代价的。如果你不愿意付出这样的代价而希望得到同样的对待,那是不公平的。比如说别人用50分买了一棵生菜,但是你不想花这50分,那你就不应该认为拥有生菜的人占了便宜。那个人付出50分得到了生菜,而你口袋里还有那没有花出去的50分。同理,宴会邀请,别人的赞美,这些都是有代价的。如果你觉得这些对你是有价值的,那你就要付出同等的价值去拥有。如果你不付出就想要得到这些,那么你就是个贪得无厌的傻瓜。换个角度想,在决定不和别人交换价值的时候,你真的什么都没有得到吗?不是的:你得到了不赞美你不想赞美的人的自由,而且也不需要容忍你不想容忍的行为。\n\n26. 记住:很多事情不应该分自我或者他人。举个例子,如果邻居家的孩子打破了个杯子或者其他什么东西,我们很容易会说:“没事的,打碎东西是正常的”。可是如果打碎的是你自己的杯子呢?你应该作出相同的反应,而不是心生懊恼。同理,当别人的孩子或者妻子去世了,我们知道死亡的悲剧有时候是不可避免的,但是如果发生在我们自己身上的时候,我们却心如刀割。但是,我们应该清醒的认识到类似的悲剧不是我们能够控制的,我们所能够控制的是自己的情绪和反应,因为即使是发生在自己的身上,死亡本身并没有因为我们和死者的关系而变的更糟糕。\n\n27. 立一个靶子的目的,不是为了射失它(靶子的目的都是为了让人射中它)。那么同样的道理,大道创造出一个“恶”的事物(至少看起来如此),不是为了让人绕开它。\n\n28. 如果别人把你的身体交给一个路上遇到的陌生人,你一定会很生气。可是当别人用恶语打击你的时候,你为什么要心甘情愿地让别人控制你的思想,困惑你呢?\n\n29. 做每件事情都要考虑缘由和后果之后才能开始行动。如果你兴高采烈地开始而没有考虑可能发生的后果,当某些不好的后果开始出现时,你就会停止前进。拿参加奥林匹克赛事为例子。如果你把所有前因后果都考虑周全后认为参加比赛对你时有益的,那就全力以赴。其中,应该考虑的事情包括:你要遵守规则,节制饮食;不管风吹日晒雨淋都要雷打不动地坚持按时锻炼;你不能喝凉水活着酒。你必须全身心地、完全忘我地投入训练。而且,要做思想准备准备,比赛中你有可能会摔入沟里,胳膊脱臼,脚踝受伤,吃入尘土,被鞭打,甚至最后以失败告终。当你评估完所有的可能性之后还是一心想比赛,那就以战争的姿态出发。否则,你就会像孩子过家家一样:一会扮摔跤手,一会扮角斗士,一会吹喇叭,一会又想参加戏剧演出。这样,即使你什么都做过,但是什么都不是。就想大猩猩一样,你模仿你所看到的一切,不停地换把戏可能是一件好玩的事,但是你很快就玩腻了。你从来都没有完全投入过任何事,没有深度地从各个角度考虑和研究所有相关的细节,而只是凭一时的兴趣蜻蜓点水般地接触了各种行业。有些人当他们看到一个人说话的方式和Euphrates十分相像(不过事实上,真的有人能和Euphrates一样犀利善辩吗?),他们认为自己也能够拥有和哲学家一样的思想。但是,如果你细想一下,如果你想要成为一个摔跤手,那么你必须具备有摔跤手的宽阔肩膀,强有力的背部和大腿。但是每一个人的身体构造都是不一样的,你必须具有必备的条件才能称为一个好的摔跤手。同理,要想成为一个哲学家,你不能像你现在这样随心所欲地吃喝,不能让愤怒和不满控制你的情绪,你必须细心观察,劳作,控制自己的欲望,你必须能够忍受孤独,仆人的不敬,和外人的嘲笑,你必须能够接受别人在其他方面做得比你好。如果你已经仔细考虑过这些情况,如果你认为如果做到以上这些可以让你享受自由和宁静,那就尽情去追求哲学家的道路。如果你无法做到这些的话,那么就请不要继续,不要像孩子一样,一会试试做哲学,一会又想当政治家,演讲者,或者凯撒的军官。这些追求是互相矛盾的,你只能成为其中一个,不管做得好坏。你必须培养你自己内在的能够掌控行为的能力,或者外在的技术,二者只能取其一。\n\n30. 一个人的责任是由和别人的关系定义和衡量的。如果一个人拥有父亲的角色,那么他就有以下权利:他的孩子要照顾他,遵从他,耐心听他训话和教导。那如果他不是一个好父亲呢?他也应该受到同等的对待,因为我们无法选择我们的父亲是谁。不管他做了什么,你必须做到让自己心安理得。因为只有你能够让别人的行为伤害到你。当你觉得你被伤害了,那你就会被伤害。如果你以同样的逻辑看待邻居,市民,将军这些不同的角色,你就能够清楚地明白与这些角色相对应的社会责任。","slug":"读书笔记/斯多葛主义手册","published":1,"updated":"2019-08-14T06:31:28.000Z","_id":"cka1y597o00124huu1wtf5iy9","comments":1,"layout":"post","photos":[],"link":"","content":"
    \n
  1. \n

    世间的事,有些可控,有些不可控。可控的有:观点,追求,欲望,和喜恶等。这些都是我们自己可以做出选择的。不可控的是身体,财物,名声,指令等。这些我们都无法选择。

    \n

    可控范围之内的东西在本质上是自由的,不被束缚、阻碍的。那些不可控的是虚的,是被奴役的,是我们受控于他人。记住,如果你觉得那些不可控的事物是自由的,那些受控于别人的也是你的,那么你就会被控制,被束缚。你会悲痛,你会受扰,你会指责神以及他人。但如果你只专注于你所能控制的,不被他人所拥有的干扰,那么就没有人能够影响你、束缚你。并且,你不会把过错推在他人身上。你不会去做违背你的意志的事。你不会有敌人。你也不会被伤害。

    \n

    把这些当做你的目标,不让自己受那些没有意义的事诱惑,哪怕就一点点也不可以。放弃那些不可控的。如果你既想把握住可控的,又想拥有财富和权力,那么你将会什么都得不到,更不用说幸福和自由-因为幸福和自由是依赖于可控事物。

    \n

    尽你最大的努力。这样你就可以对看似艰难的每一件事说:“你只不过是看起来艰难而已。” 然后比照你为自己制定的原则:这件事是否可控。如果在你控制范围之外,那么结果就无关乎于你。

    \n
  2. \n
  3. \n

    欲望要求你去追求你想要的;厌恶则让你尽量避免你所讨厌的。但是,如果你得不到你想要的,你就会十分失望;如果你无法避免你所讨厌的,那你就会被厌恶扭曲。那么,如果你只讨厌那些在你出自本质所做选择的对立事物(即在你控制范围内你不会选择的事物),那么你就永远不需要去为之伤神。但是,如果你厌恶疾病、死亡、贫穷等你无法选择和改变的,那你就会被厌恶扭曲。不厌恶你所不能控制的,把厌恶限制在和你本性对立的事物。但是,就目前来说,压制你的欲望:因为如果你追求任何可控范围之外的事物,那你就必然会失望。不要轻易追求或者厌恶。

    \n
  4. \n
  5. \n

    对于给你带来乐趣、有用处以及你十分喜欢的东西,从最不重要的事情开始,记得提醒你自己:他们真正的本质是什么。比如说,你很喜欢某个陶瓷杯,提醒你自己那只是因为你喜欢陶瓷杯而已,而不在于具体是哪个杯子。这样,如果杯子碎了,你也不会太伤心。当你亲吻你的家人时,提醒你自己你只是在亲吻和你亲近的人,这样当他们离世时,你就不会太难过。

    \n
  6. \n
  7. \n

    当你做事情时,提醒你自己事情的本质是什么,你可能遇到哪些情况。比如说洗澡。在你洗澡之前,先想想洗澡时会发生哪些事情。有的人可能会把水溅得哪都是,有人可能会推娜,有人会诅咒,有人会偷东西。这样你在洗澡之前就可以跟自己说:“我现在要去洗澡了,任何这些事都有可能发生,但是这不是我能控制的,所以我会保持好的心态”。如果你以同样的心态去对待任何其他事情,你内心的平和就不会被打扰。因为你可以对自己说:”我希望的不仅仅是洗澡,还有不被任何意外困扰”。

    \n
  8. \n
  9. \n

    人内心困扰时,通常不是被事物本身困扰,而是被他们自己的原则和概念所困扰。比如说,死亡本身并不可怕,要不然苏格拉底面临死亡时该有多么惊慌。我们对死亡的恐惧是源于我们对死亡的概念:死亡是可怕的。当我们被困扰、阻碍,伤心难过时,我们不要从事物本身或者他人身上找原因,而应该反省我们自己,还有我们的原则。一个还不通明的人,会把自己的糟糕情况怪罪于他人。一个刚刚开始学习处理这些情况的人,会从自己身上找原因。而一个已经通彻的人,既不会怪罪别人,也不会苛求自己。

    \n
  10. \n
  11. \n

    不要为任何身外之物骄傲。一匹马可以因为自己的英爽豪气自豪,因为这是它本身拥有的。但是如果你因为拥有这样一匹马儿骄傲,事实上,你所自豪的,不过是马所拥有的好。那么,什么才是属于你的呢?你对事物的反应和态度。如果你对任何事物的形态的处之泰然,那么你就可以为你的理性自豪,因为这是属于你的。

    \n
  12. \n
  13. \n

    想象以下情况:在一次航海旅行中,你的船抛锚靠岸了,你上岸去找水,途中你还捡了些你喜欢的贝壳,或者买个洋葱。但是,你的所有注意力必须一直集中在那艘船上,注意船长什么时候呼叫大家上船继续航行。当船长呼叫时,你必须立刻放下手中所有的东西,否则你就会被手脚捆绑得像只羊一样抛到船上。生活也是这样。生活给你老婆孩子,而不是洋葱贝壳。如果生活的船长呼叫了,你必须离开他们,立马跑到船上,而不是光顾着他们。如果你年纪大了,那你就不能离开船太远,否则你可能来不及回到船上。

    \n
  14. \n
  15. \n

    不要苛求生活给予你所有你想要的,该发生的就会发生,随遇而安就好。

    \n
  16. \n
  17. \n

    疾病影响的只是你的身体,而不是你选择的能力,除非那是你的选择。瘸的是腿,而不是你的脑子。不管发生什么事,只要这么跟自己说,你就会明白困难阻碍的是事物,而不是你。

    \n
  18. \n
  19. \n

    对于每一件发生的事,检视你自己的能力,问你自己能够用哪些能力从每一件事情中获得什么适当的用处。遇到一个十分有吸引力的人时,你就会发现你的自控就是你的能力。当你痛苦时,你会发现自己的坚强。听到坏话时,你会发现自己的耐心。形成了这样的习惯之后,你就不会被事物的表象所影响。

    \n
  20. \n
  21. \n

    不要说:“我失去了什么”。而应该说:“我归还了什么”。如果你的孩子或者妻子不幸离世了,你不是失去他们了,而是他们回归了。如果你的房子被夺走了,同样的,你是归还它们了。你可能会说:“可是那些夺走我房子的人是坏人!“。可是,给予你的人让谁来夺走你的房子真的那么重要吗?当你拥有时,照顾好它,但不要把它当做永久财物,就当自己是一个在那暂住的旅行者。

    \n
  22. \n
  23. \n

    如果你想要提高自己,那就要拒绝以下思考方式:“如果我忽视那些琐事,那我就没有收入;如果我不更正我的仆人,那他们就会变坏”。 如果能够免于悲伤和恐惧,即使死于饥饿,那也比富得流油但备受精神困扰好得多。比起坏仆人,难道你的开心不是更重要吗?

    \n

    如果你想要让自己变得更好,那就从小事做起。油洒了,酒被偷了,没关系,告诉你自己:“那只不过是平静生活的一点点代价。任何事情都是有代价的”。当你召集你的仆人时,他们可能不会来,也可能来了但是做的事情不合你意。但是他们并没有重要得以至于你必须打破自己的平静。

    \n
  24. \n
  25. \n

    如果你想要让自己变得更好,那就不要在乎被人认为你是愚蠢的。不要希望别人认为你无所不知。即使你看上去好像对别人来说很重要,也不要被这种虚名欺骗。因为想要既保持内心平和又拥有外在事物是非常困难的。当你专注于二者之一时,你必然会忽略剩下的那个。

    \n
  26. \n
  27. \n

    如果你希望你的家人、朋友长生不老,那是很愚蠢的想法。因为生死是在你控制范围之外的,是关乎他人的。同样地,如果你希望你的仆人不犯错,那你和傻瓜无异,因为你希望错误不是错误。但是,如果你希望你的欲望不带来失望,那是在你所能控制的范围之内的。练习控制你所能控制的。一个能够控制自己的喜恶的人,是自己生活的主人。这样的人,是真正自由的,不会成为被自己的欲望控制的奴隶,不会喜欢或者厌恶那些受别人控制的事物。

    \n
  28. \n
  29. \n

    记住生活就像是一个晚餐聚会一样。如果别人递给你一盘食物,你应该伸出手去接,舀起适当份量给自己。如果盘子从你身边递过,不要试图去截取。如果还没轮到你这,不要起身去拿,而是等着别人递到你面前。用相同的态度对待孩子,配偶,财物,公共职位,这样你最终自然就会成为诸神宴会的搭档。如果你不仅能够做到这些,还能够做到不去拿你面前的食物,甚至是有能力拒绝你自己的欲望,这样你不仅仅能够成为诸神宴会的搭档,你还能进入他们的国度,成为为他们的一员。像Diogenes, Heraclitus这些人就是因为他们的尊贵行为而被视为神一般神圣。

    \n
  30. \n
  31. \n

    当你看到别人因为孩子出国了,或者离世了,或者因为被琐事困扰而哭泣伤心时,不要让这些情感表象误导你。你必须作出自己的判断,明白他的伤心难过不是因为发生的事情本身,因为其他同样身处其中的人并没有受到同样的影响。他之所以受到那么大的困扰,是因为他自己本身对事情的判断。不要让自己和他一样受影响,不要让自己一样受困扰,不管是外在表现还是内心感受上。

    \n
  32. \n
  33. \n

    记住你只是一出戏里的一个演员,而戏份角色并不是由你决定的。不管角色故事长短,不管你是一个穷人,瘸子,政府官员,或者是一个很私密的人,把你的角色演好演自然了就行。把分配给你的角色演好,那是你的本分;而到底是哪个角色,那不是由你决定的。

    \n
  34. \n
  35. \n

    如果一只乌鸦向你预示不幸的事即将发生,不要让你内心的平静被这个表象破坏。要即刻告诉自己,“我不知道会发生什么,我不知道我的身体,财物,名声,或者家人会受什么影响,如果我愿意理性地去想,那么所有的这些恶兆就会变成幸运,因为我可以控制我要用什么态度去对待这些事情。不管发生什么,我都可以从中获得对我有利的。

    \n
  36. \n
  37. \n

    如果你不去参与在你控制范围之外的任何战斗,那你就不会被打败。当你看到那些声名显赫,社会地位高,或者在任何方面做得很好的人,不要着急认为他们是开心的。因为如果我们清楚明白幸福只在于我们所能够控制的范围内,那我们就不会去羡慕或者攀比。不要向往头衔,而是要向往内心自由和平静。而要做到这一点,唯一的途径是要看轻我们控制范围之外的一切事物。

    \n
  38. \n
  39. \n

    记住,那些对你出言不逊或者动手的人他本身并不是一种羞辱,而是代表那些言行的原则让你感觉到被羞辱。如果有人激怒你了,那是你对这种行为的观点激怒了你。试着不要被事情的表象牵引你的情感。给予适当的时间和稍作休息,你就能够很好地调整控制自己的情感。

    \n
  40. \n
  41. \n

    把死亡和流放这些看似可怕的事看作是日常,那你就赢了。不用害怕贫穷,也不要刻意贪求任何东西。

    \n
  42. \n
  43. \n

    如果你真心希望从哲学中获益,那么就要做好被众人嘲笑的准备:“她这是准备要成为一个哲学家呢”,“瞧她那傲慢的样子”……这个时候,你该做的,不是摆起傲慢的样子,而是要以神圣的态度忠诚于你所认定的,这样总有一天嘲笑你的人会开始尊敬你崇拜你。但是如果你被这些嘲笑打败,那你就成了双重的笑话。

    \n
  44. \n
  45. \n

    如果你为了取悦他人而把你的注意力转移到那些外在的你无法控制的事物上,那么恭喜你,你已经成功地毁了你自己的生活了。

    \n
  46. \n
  47. \n

    不要让以下这些思考方式困扰你:“我将会颜面丢尽,而且什么都不是。”耻辱是邪恶的,我们不应该被耻辱感所控制。因为获取权力或着被人嘲笑,这些都在你的控制范围之外。我们不用为任何在我们控制范围之外的事而感到耻辱。在我们可控范围之内,我们是自由的,能够左右我们自己的事情,是自我的主人-从这个角度看,我们永远不会什么都不是。“可是我帮不了我的朋友啊”,你可能会这么说。可是,怎么算是帮助朋友呢?你不能给他们钱,或者帮他们成为罗马市民。这些都是你所能控制范围之内的,是他们自己应该处理的事情。而且,如果这些都是你自己所没有的,那你怎么能够给他们呢?你可能会说:“如果我帮助他们获得这些的话,说不定我也能够得到一份呢“。如果我能够在保存我自己的尊严,忠诚和思想得到这些的话,请你帮我指明道路。可是如果你要我损害自己去得到你的利益,那这样的做法不仅不公平,而且愚蠢至极。

    \n
  48. \n
  49. \n

    如果别人,而不是你,被邀请去宴会,或者被赞美,或者被别人咨询,不要懊恼。如果这些是好事,你应该为他人高兴。如果是坏事,不要难过。记住:这些都是在你的控制范围之外的,这样的对待一般是有对应的代价的。如果你不愿意付出这样的代价而希望得到同样的对待,那是不公平的。比如说别人用50分买了一棵生菜,但是你不想花这50分,那你就不应该认为拥有生菜的人占了便宜。那个人付出50分得到了生菜,而你口袋里还有那没有花出去的50分。同理,宴会邀请,别人的赞美,这些都是有代价的。如果你觉得这些对你是有价值的,那你就要付出同等的价值去拥有。如果你不付出就想要得到这些,那么你就是个贪得无厌的傻瓜。换个角度想,在决定不和别人交换价值的时候,你真的什么都没有得到吗?不是的:你得到了不赞美你不想赞美的人的自由,而且也不需要容忍你不想容忍的行为。

    \n
  50. \n
  51. \n

    记住:很多事情不应该分自我或者他人。举个例子,如果邻居家的孩子打破了个杯子或者其他什么东西,我们很容易会说:“没事的,打碎东西是正常的”。可是如果打碎的是你自己的杯子呢?你应该作出相同的反应,而不是心生懊恼。同理,当别人的孩子或者妻子去世了,我们知道死亡的悲剧有时候是不可避免的,但是如果发生在我们自己身上的时候,我们却心如刀割。但是,我们应该清醒的认识到类似的悲剧不是我们能够控制的,我们所能够控制的是自己的情绪和反应,因为即使是发生在自己的身上,死亡本身并没有因为我们和死者的关系而变的更糟糕。

    \n
  52. \n
  53. \n

    立一个靶子的目的,不是为了射失它(靶子的目的都是为了让人射中它)。那么同样的道理,大道创造出一个“恶”的事物(至少看起来如此),不是为了让人绕开它。

    \n
  54. \n
  55. \n

    如果别人把你的身体交给一个路上遇到的陌生人,你一定会很生气。可是当别人用恶语打击你的时候,你为什么要心甘情愿地让别人控制你的思想,困惑你呢?

    \n
  56. \n
  57. \n

    做每件事情都要考虑缘由和后果之后才能开始行动。如果你兴高采烈地开始而没有考虑可能发生的后果,当某些不好的后果开始出现时,你就会停止前进。拿参加奥林匹克赛事为例子。如果你把所有前因后果都考虑周全后认为参加比赛对你时有益的,那就全力以赴。其中,应该考虑的事情包括:你要遵守规则,节制饮食;不管风吹日晒雨淋都要雷打不动地坚持按时锻炼;你不能喝凉水活着酒。你必须全身心地、完全忘我地投入训练。而且,要做思想准备准备,比赛中你有可能会摔入沟里,胳膊脱臼,脚踝受伤,吃入尘土,被鞭打,甚至最后以失败告终。当你评估完所有的可能性之后还是一心想比赛,那就以战争的姿态出发。否则,你就会像孩子过家家一样:一会扮摔跤手,一会扮角斗士,一会吹喇叭,一会又想参加戏剧演出。这样,即使你什么都做过,但是什么都不是。就想大猩猩一样,你模仿你所看到的一切,不停地换把戏可能是一件好玩的事,但是你很快就玩腻了。你从来都没有完全投入过任何事,没有深度地从各个角度考虑和研究所有相关的细节,而只是凭一时的兴趣蜻蜓点水般地接触了各种行业。有些人当他们看到一个人说话的方式和Euphrates十分相像(不过事实上,真的有人能和Euphrates一样犀利善辩吗?),他们认为自己也能够拥有和哲学家一样的思想。但是,如果你细想一下,如果你想要成为一个摔跤手,那么你必须具备有摔跤手的宽阔肩膀,强有力的背部和大腿。但是每一个人的身体构造都是不一样的,你必须具有必备的条件才能称为一个好的摔跤手。同理,要想成为一个哲学家,你不能像你现在这样随心所欲地吃喝,不能让愤怒和不满控制你的情绪,你必须细心观察,劳作,控制自己的欲望,你必须能够忍受孤独,仆人的不敬,和外人的嘲笑,你必须能够接受别人在其他方面做得比你好。如果你已经仔细考虑过这些情况,如果你认为如果做到以上这些可以让你享受自由和宁静,那就尽情去追求哲学家的道路。如果你无法做到这些的话,那么就请不要继续,不要像孩子一样,一会试试做哲学,一会又想当政治家,演讲者,或者凯撒的军官。这些追求是互相矛盾的,你只能成为其中一个,不管做得好坏。你必须培养你自己内在的能够掌控行为的能力,或者外在的技术,二者只能取其一。

    \n
  58. \n
  59. \n

    一个人的责任是由和别人的关系定义和衡量的。如果一个人拥有父亲的角色,那么他就有以下权利:他的孩子要照顾他,遵从他,耐心听他训话和教导。那如果他不是一个好父亲呢?他也应该受到同等的对待,因为我们无法选择我们的父亲是谁。不管他做了什么,你必须做到让自己心安理得。因为只有你能够让别人的行为伤害到你。当你觉得你被伤害了,那你就会被伤害。如果你以同样的逻辑看待邻居,市民,将军这些不同的角色,你就能够清楚地明白与这些角色相对应的社会责任。

    \n
  60. \n
","site":{"data":{}},"excerpt":"

\n

世间的事,有些可控,有些不可控。可控的有:观点,追求,欲望,和喜恶等。这些都是我们自己可以做出选择的。不可控的是身体,财物,名声,指令等。这些我们都无法选择。

","more":"
    \n
  1. \n

    世间的事,有些可控,有些不可控。可控的有:观点,追求,欲望,和喜恶等。这些都是我们自己可以做出选择的。不可控的是身体,财物,名声,指令等。这些我们都无法选择。

    \n

    可控范围之内的东西在本质上是自由的,不被束缚、阻碍的。那些不可控的是虚的,是被奴役的,是我们受控于他人。记住,如果你觉得那些不可控的事物是自由的,那些受控于别人的也是你的,那么你就会被控制,被束缚。你会悲痛,你会受扰,你会指责神以及他人。但如果你只专注于你所能控制的,不被他人所拥有的干扰,那么就没有人能够影响你、束缚你。并且,你不会把过错推在他人身上。你不会去做违背你的意志的事。你不会有敌人。你也不会被伤害。

    \n

    把这些当做你的目标,不让自己受那些没有意义的事诱惑,哪怕就一点点也不可以。放弃那些不可控的。如果你既想把握住可控的,又想拥有财富和权力,那么你将会什么都得不到,更不用说幸福和自由-因为幸福和自由是依赖于可控事物。

    \n

    尽你最大的努力。这样你就可以对看似艰难的每一件事说:“你只不过是看起来艰难而已。” 然后比照你为自己制定的原则:这件事是否可控。如果在你控制范围之外,那么结果就无关乎于你。

    \n
  2. \n
  3. \n

    欲望要求你去追求你想要的;厌恶则让你尽量避免你所讨厌的。但是,如果你得不到你想要的,你就会十分失望;如果你无法避免你所讨厌的,那你就会被厌恶扭曲。那么,如果你只讨厌那些在你出自本质所做选择的对立事物(即在你控制范围内你不会选择的事物),那么你就永远不需要去为之伤神。但是,如果你厌恶疾病、死亡、贫穷等你无法选择和改变的,那你就会被厌恶扭曲。不厌恶你所不能控制的,把厌恶限制在和你本性对立的事物。但是,就目前来说,压制你的欲望:因为如果你追求任何可控范围之外的事物,那你就必然会失望。不要轻易追求或者厌恶。

    \n
  4. \n
  5. \n

    对于给你带来乐趣、有用处以及你十分喜欢的东西,从最不重要的事情开始,记得提醒你自己:他们真正的本质是什么。比如说,你很喜欢某个陶瓷杯,提醒你自己那只是因为你喜欢陶瓷杯而已,而不在于具体是哪个杯子。这样,如果杯子碎了,你也不会太伤心。当你亲吻你的家人时,提醒你自己你只是在亲吻和你亲近的人,这样当他们离世时,你就不会太难过。

    \n
  6. \n
  7. \n

    当你做事情时,提醒你自己事情的本质是什么,你可能遇到哪些情况。比如说洗澡。在你洗澡之前,先想想洗澡时会发生哪些事情。有的人可能会把水溅得哪都是,有人可能会推娜,有人会诅咒,有人会偷东西。这样你在洗澡之前就可以跟自己说:“我现在要去洗澡了,任何这些事都有可能发生,但是这不是我能控制的,所以我会保持好的心态”。如果你以同样的心态去对待任何其他事情,你内心的平和就不会被打扰。因为你可以对自己说:”我希望的不仅仅是洗澡,还有不被任何意外困扰”。

    \n
  8. \n
  9. \n

    人内心困扰时,通常不是被事物本身困扰,而是被他们自己的原则和概念所困扰。比如说,死亡本身并不可怕,要不然苏格拉底面临死亡时该有多么惊慌。我们对死亡的恐惧是源于我们对死亡的概念:死亡是可怕的。当我们被困扰、阻碍,伤心难过时,我们不要从事物本身或者他人身上找原因,而应该反省我们自己,还有我们的原则。一个还不通明的人,会把自己的糟糕情况怪罪于他人。一个刚刚开始学习处理这些情况的人,会从自己身上找原因。而一个已经通彻的人,既不会怪罪别人,也不会苛求自己。

    \n
  10. \n
  11. \n

    不要为任何身外之物骄傲。一匹马可以因为自己的英爽豪气自豪,因为这是它本身拥有的。但是如果你因为拥有这样一匹马儿骄傲,事实上,你所自豪的,不过是马所拥有的好。那么,什么才是属于你的呢?你对事物的反应和态度。如果你对任何事物的形态的处之泰然,那么你就可以为你的理性自豪,因为这是属于你的。

    \n
  12. \n
  13. \n

    想象以下情况:在一次航海旅行中,你的船抛锚靠岸了,你上岸去找水,途中你还捡了些你喜欢的贝壳,或者买个洋葱。但是,你的所有注意力必须一直集中在那艘船上,注意船长什么时候呼叫大家上船继续航行。当船长呼叫时,你必须立刻放下手中所有的东西,否则你就会被手脚捆绑得像只羊一样抛到船上。生活也是这样。生活给你老婆孩子,而不是洋葱贝壳。如果生活的船长呼叫了,你必须离开他们,立马跑到船上,而不是光顾着他们。如果你年纪大了,那你就不能离开船太远,否则你可能来不及回到船上。

    \n
  14. \n
  15. \n

    不要苛求生活给予你所有你想要的,该发生的就会发生,随遇而安就好。

    \n
  16. \n
  17. \n

    疾病影响的只是你的身体,而不是你选择的能力,除非那是你的选择。瘸的是腿,而不是你的脑子。不管发生什么事,只要这么跟自己说,你就会明白困难阻碍的是事物,而不是你。

    \n
  18. \n
  19. \n

    对于每一件发生的事,检视你自己的能力,问你自己能够用哪些能力从每一件事情中获得什么适当的用处。遇到一个十分有吸引力的人时,你就会发现你的自控就是你的能力。当你痛苦时,你会发现自己的坚强。听到坏话时,你会发现自己的耐心。形成了这样的习惯之后,你就不会被事物的表象所影响。

    \n
  20. \n
  21. \n

    不要说:“我失去了什么”。而应该说:“我归还了什么”。如果你的孩子或者妻子不幸离世了,你不是失去他们了,而是他们回归了。如果你的房子被夺走了,同样的,你是归还它们了。你可能会说:“可是那些夺走我房子的人是坏人!“。可是,给予你的人让谁来夺走你的房子真的那么重要吗?当你拥有时,照顾好它,但不要把它当做永久财物,就当自己是一个在那暂住的旅行者。

    \n
  22. \n
  23. \n

    如果你想要提高自己,那就要拒绝以下思考方式:“如果我忽视那些琐事,那我就没有收入;如果我不更正我的仆人,那他们就会变坏”。 如果能够免于悲伤和恐惧,即使死于饥饿,那也比富得流油但备受精神困扰好得多。比起坏仆人,难道你的开心不是更重要吗?

    \n

    如果你想要让自己变得更好,那就从小事做起。油洒了,酒被偷了,没关系,告诉你自己:“那只不过是平静生活的一点点代价。任何事情都是有代价的”。当你召集你的仆人时,他们可能不会来,也可能来了但是做的事情不合你意。但是他们并没有重要得以至于你必须打破自己的平静。

    \n
  24. \n
  25. \n

    如果你想要让自己变得更好,那就不要在乎被人认为你是愚蠢的。不要希望别人认为你无所不知。即使你看上去好像对别人来说很重要,也不要被这种虚名欺骗。因为想要既保持内心平和又拥有外在事物是非常困难的。当你专注于二者之一时,你必然会忽略剩下的那个。

    \n
  26. \n
  27. \n

    如果你希望你的家人、朋友长生不老,那是很愚蠢的想法。因为生死是在你控制范围之外的,是关乎他人的。同样地,如果你希望你的仆人不犯错,那你和傻瓜无异,因为你希望错误不是错误。但是,如果你希望你的欲望不带来失望,那是在你所能控制的范围之内的。练习控制你所能控制的。一个能够控制自己的喜恶的人,是自己生活的主人。这样的人,是真正自由的,不会成为被自己的欲望控制的奴隶,不会喜欢或者厌恶那些受别人控制的事物。

    \n
  28. \n
  29. \n

    记住生活就像是一个晚餐聚会一样。如果别人递给你一盘食物,你应该伸出手去接,舀起适当份量给自己。如果盘子从你身边递过,不要试图去截取。如果还没轮到你这,不要起身去拿,而是等着别人递到你面前。用相同的态度对待孩子,配偶,财物,公共职位,这样你最终自然就会成为诸神宴会的搭档。如果你不仅能够做到这些,还能够做到不去拿你面前的食物,甚至是有能力拒绝你自己的欲望,这样你不仅仅能够成为诸神宴会的搭档,你还能进入他们的国度,成为为他们的一员。像Diogenes, Heraclitus这些人就是因为他们的尊贵行为而被视为神一般神圣。

    \n
  30. \n
  31. \n

    当你看到别人因为孩子出国了,或者离世了,或者因为被琐事困扰而哭泣伤心时,不要让这些情感表象误导你。你必须作出自己的判断,明白他的伤心难过不是因为发生的事情本身,因为其他同样身处其中的人并没有受到同样的影响。他之所以受到那么大的困扰,是因为他自己本身对事情的判断。不要让自己和他一样受影响,不要让自己一样受困扰,不管是外在表现还是内心感受上。

    \n
  32. \n
  33. \n

    记住你只是一出戏里的一个演员,而戏份角色并不是由你决定的。不管角色故事长短,不管你是一个穷人,瘸子,政府官员,或者是一个很私密的人,把你的角色演好演自然了就行。把分配给你的角色演好,那是你的本分;而到底是哪个角色,那不是由你决定的。

    \n
  34. \n
  35. \n

    如果一只乌鸦向你预示不幸的事即将发生,不要让你内心的平静被这个表象破坏。要即刻告诉自己,“我不知道会发生什么,我不知道我的身体,财物,名声,或者家人会受什么影响,如果我愿意理性地去想,那么所有的这些恶兆就会变成幸运,因为我可以控制我要用什么态度去对待这些事情。不管发生什么,我都可以从中获得对我有利的。

    \n
  36. \n
  37. \n

    如果你不去参与在你控制范围之外的任何战斗,那你就不会被打败。当你看到那些声名显赫,社会地位高,或者在任何方面做得很好的人,不要着急认为他们是开心的。因为如果我们清楚明白幸福只在于我们所能够控制的范围内,那我们就不会去羡慕或者攀比。不要向往头衔,而是要向往内心自由和平静。而要做到这一点,唯一的途径是要看轻我们控制范围之外的一切事物。

    \n
  38. \n
  39. \n

    记住,那些对你出言不逊或者动手的人他本身并不是一种羞辱,而是代表那些言行的原则让你感觉到被羞辱。如果有人激怒你了,那是你对这种行为的观点激怒了你。试着不要被事情的表象牵引你的情感。给予适当的时间和稍作休息,你就能够很好地调整控制自己的情感。

    \n
  40. \n
  41. \n

    把死亡和流放这些看似可怕的事看作是日常,那你就赢了。不用害怕贫穷,也不要刻意贪求任何东西。

    \n
  42. \n
  43. \n

    如果你真心希望从哲学中获益,那么就要做好被众人嘲笑的准备:“她这是准备要成为一个哲学家呢”,“瞧她那傲慢的样子”……这个时候,你该做的,不是摆起傲慢的样子,而是要以神圣的态度忠诚于你所认定的,这样总有一天嘲笑你的人会开始尊敬你崇拜你。但是如果你被这些嘲笑打败,那你就成了双重的笑话。

    \n
  44. \n
  45. \n

    如果你为了取悦他人而把你的注意力转移到那些外在的你无法控制的事物上,那么恭喜你,你已经成功地毁了你自己的生活了。

    \n
  46. \n
  47. \n

    不要让以下这些思考方式困扰你:“我将会颜面丢尽,而且什么都不是。”耻辱是邪恶的,我们不应该被耻辱感所控制。因为获取权力或着被人嘲笑,这些都在你的控制范围之外。我们不用为任何在我们控制范围之外的事而感到耻辱。在我们可控范围之内,我们是自由的,能够左右我们自己的事情,是自我的主人-从这个角度看,我们永远不会什么都不是。“可是我帮不了我的朋友啊”,你可能会这么说。可是,怎么算是帮助朋友呢?你不能给他们钱,或者帮他们成为罗马市民。这些都是你所能控制范围之内的,是他们自己应该处理的事情。而且,如果这些都是你自己所没有的,那你怎么能够给他们呢?你可能会说:“如果我帮助他们获得这些的话,说不定我也能够得到一份呢“。如果我能够在保存我自己的尊严,忠诚和思想得到这些的话,请你帮我指明道路。可是如果你要我损害自己去得到你的利益,那这样的做法不仅不公平,而且愚蠢至极。

    \n
  48. \n
  49. \n

    如果别人,而不是你,被邀请去宴会,或者被赞美,或者被别人咨询,不要懊恼。如果这些是好事,你应该为他人高兴。如果是坏事,不要难过。记住:这些都是在你的控制范围之外的,这样的对待一般是有对应的代价的。如果你不愿意付出这样的代价而希望得到同样的对待,那是不公平的。比如说别人用50分买了一棵生菜,但是你不想花这50分,那你就不应该认为拥有生菜的人占了便宜。那个人付出50分得到了生菜,而你口袋里还有那没有花出去的50分。同理,宴会邀请,别人的赞美,这些都是有代价的。如果你觉得这些对你是有价值的,那你就要付出同等的价值去拥有。如果你不付出就想要得到这些,那么你就是个贪得无厌的傻瓜。换个角度想,在决定不和别人交换价值的时候,你真的什么都没有得到吗?不是的:你得到了不赞美你不想赞美的人的自由,而且也不需要容忍你不想容忍的行为。

    \n
  50. \n
  51. \n

    记住:很多事情不应该分自我或者他人。举个例子,如果邻居家的孩子打破了个杯子或者其他什么东西,我们很容易会说:“没事的,打碎东西是正常的”。可是如果打碎的是你自己的杯子呢?你应该作出相同的反应,而不是心生懊恼。同理,当别人的孩子或者妻子去世了,我们知道死亡的悲剧有时候是不可避免的,但是如果发生在我们自己身上的时候,我们却心如刀割。但是,我们应该清醒的认识到类似的悲剧不是我们能够控制的,我们所能够控制的是自己的情绪和反应,因为即使是发生在自己的身上,死亡本身并没有因为我们和死者的关系而变的更糟糕。

    \n
  52. \n
  53. \n

    立一个靶子的目的,不是为了射失它(靶子的目的都是为了让人射中它)。那么同样的道理,大道创造出一个“恶”的事物(至少看起来如此),不是为了让人绕开它。

    \n
  54. \n
  55. \n

    如果别人把你的身体交给一个路上遇到的陌生人,你一定会很生气。可是当别人用恶语打击你的时候,你为什么要心甘情愿地让别人控制你的思想,困惑你呢?

    \n
  56. \n
  57. \n

    做每件事情都要考虑缘由和后果之后才能开始行动。如果你兴高采烈地开始而没有考虑可能发生的后果,当某些不好的后果开始出现时,你就会停止前进。拿参加奥林匹克赛事为例子。如果你把所有前因后果都考虑周全后认为参加比赛对你时有益的,那就全力以赴。其中,应该考虑的事情包括:你要遵守规则,节制饮食;不管风吹日晒雨淋都要雷打不动地坚持按时锻炼;你不能喝凉水活着酒。你必须全身心地、完全忘我地投入训练。而且,要做思想准备准备,比赛中你有可能会摔入沟里,胳膊脱臼,脚踝受伤,吃入尘土,被鞭打,甚至最后以失败告终。当你评估完所有的可能性之后还是一心想比赛,那就以战争的姿态出发。否则,你就会像孩子过家家一样:一会扮摔跤手,一会扮角斗士,一会吹喇叭,一会又想参加戏剧演出。这样,即使你什么都做过,但是什么都不是。就想大猩猩一样,你模仿你所看到的一切,不停地换把戏可能是一件好玩的事,但是你很快就玩腻了。你从来都没有完全投入过任何事,没有深度地从各个角度考虑和研究所有相关的细节,而只是凭一时的兴趣蜻蜓点水般地接触了各种行业。有些人当他们看到一个人说话的方式和Euphrates十分相像(不过事实上,真的有人能和Euphrates一样犀利善辩吗?),他们认为自己也能够拥有和哲学家一样的思想。但是,如果你细想一下,如果你想要成为一个摔跤手,那么你必须具备有摔跤手的宽阔肩膀,强有力的背部和大腿。但是每一个人的身体构造都是不一样的,你必须具有必备的条件才能称为一个好的摔跤手。同理,要想成为一个哲学家,你不能像你现在这样随心所欲地吃喝,不能让愤怒和不满控制你的情绪,你必须细心观察,劳作,控制自己的欲望,你必须能够忍受孤独,仆人的不敬,和外人的嘲笑,你必须能够接受别人在其他方面做得比你好。如果你已经仔细考虑过这些情况,如果你认为如果做到以上这些可以让你享受自由和宁静,那就尽情去追求哲学家的道路。如果你无法做到这些的话,那么就请不要继续,不要像孩子一样,一会试试做哲学,一会又想当政治家,演讲者,或者凯撒的军官。这些追求是互相矛盾的,你只能成为其中一个,不管做得好坏。你必须培养你自己内在的能够掌控行为的能力,或者外在的技术,二者只能取其一。

    \n
  58. \n
  59. \n

    一个人的责任是由和别人的关系定义和衡量的。如果一个人拥有父亲的角色,那么他就有以下权利:他的孩子要照顾他,遵从他,耐心听他训话和教导。那如果他不是一个好父亲呢?他也应该受到同等的对待,因为我们无法选择我们的父亲是谁。不管他做了什么,你必须做到让自己心安理得。因为只有你能够让别人的行为伤害到你。当你觉得你被伤害了,那你就会被伤害。如果你以同样的逻辑看待邻居,市民,将军这些不同的角色,你就能够清楚地明白与这些角色相对应的社会责任。

    \n
  60. \n
"},{"title":"《少有人走的路》笔记","date":"2019-07-20T22:14:37.000Z","urlname":"road-less-traveled-summary","toc":true,"_content":"\n**成熟 = [自律](#id_zilv) + [爱](#id_ai)**[](def_成熟)\n\n\n\n### 自律\n\n**【自律】**[](def_自律) : 主动要求自己以积极的态度去承受痛苦,解决问题。\n\n自律的四个`原则`:延迟满足感、承担责任、忠于事实、保持平衡。:smile:\n\n#### 1 延迟满足感\n\n
\n\n人生当中总是绕着困难走。一个揍孩子和对孩子大喊大叫的父母就是不懂得延迟满足感的父母。 应该陪着孩子一起经历困难和痛苦。而父母试图通过家庭暴力的方式,试图将父母本身的责任区隔开。父母没有学会延迟满足感,这个孩子将来长大了也不会。很多人延迟满足感的能力非常糟糕,来自于父母的不自律。当父母不自律的时候,孩子就没法获得足够的爱和照顾。—— 所以这个孩子会忽略自我的价值。有的人喜欢浪费时间,而浪费时间的意思就是,_「我这个人的时间没什么价值」_。\n不会延迟满足感的人,在长大后看到问题会假装没看到,以为等着问题慢慢就会过去,期待问题自行消失。\n
\n\n> - 训斥孩子 ~\\> 是为了迅速达成目的,而不是耐心陪孩子面对问题。\n> - 父母不自律 => 孩子不自律\n> - 不会延迟满足感 => 有意忽略问题\n\n#### 2 承担责任\n\n1. **神经官能症**[](def_神经官能症): 把一切东西都认为是自己的问题。\n> _我如果怎么样就好了。我要是不怎么样就好了。总是充满后悔和内疚。祥林嫂_\n2. **人格失调症**[](def_人格失调症):他认为这一切都不是我的问题。他能找到任何一个理由,是因为外在的东西,他就不会责怪自己,他认为都是你们的问题。[](flag_心理学_病症)\n> 「神经官能症」自己活得很痛苦,「人格失调症」让别人活得很痛苦。\n\n
\n\n作者提供在冲绳岛上的一个案例,一个军官的妻子,宁愿自杀也不愿意去学自动挡开车的事。\n从某种意义上说,所有的孩子都患有人格失调症,都会本能的逃避责罚。 同时又患有某种神经官能症,把自己承受的痛苦看成是罪有应得。缺少关心的孩子会自惭形秽,认为自己不够可爱,缺点大于优点等等。\n
\n\n如果你不能解决问题,那么你自己就会成为问题。`我们需要合理的承担责任,既不把责任全部推卸到外部,也不把责任全部揽到自己身上。保持一个合理的平衡。`\n> 如果你不能让自己成为人格更加健全,更加成熟的人。你就会把问题带给你的孩子,带给你的家庭。\n\n#### 3 忠于事实\n\n大量的人是生活在自己的幻想当中的。这叫**人生地图**。他给自己绘制一张人生地图,他认为人生就这样,他已经认定了。这就叫做“不忠于事实”,他只 _忠于自己的幻想_。\n
\n\n案例:有个人小时候被父母欺骗过,就是父母说话经常不算数。导致他潜意识积累了一个信念:“父母是不可信”的。当他的人生地图绘制出来这么一个坐标,认为父母不可信了自后,他几乎就推论到“人人都不可信”。所以在他一生的成长过程当中,他跟警察发生矛盾,跟领导发生矛盾,跟顾客发生矛盾,跟妻子发生矛盾。案例中最后他唯一信任的是他的两个孩子。妻子把两个孩子带走,所以他人生也崩溃了。他跟作者约定时间不来,然后他说能不能星期六,作者说我的时间是跟别人约过的,不能随便调整。他说:“你不是心理医生吗?为什么不能多关心我一点呢”?他认为作者(心理医生)也是不可信任的人,直接拉黑。\n
\n这种人你很难跟他解释,很难让他面对真正的世界。因为在他心目当中完全是用自己的一套逻辑在解决问题。\n\n所以所谓的「心理治疗」,就是鼓励「说真话」的游戏。鼓励大家能够面对事实,能够把自己看到的真相,感受到的真实的感觉,说出来的一个过程。所以没有经过这样的调试,有大量的人是天天活在「幻觉」当中的,就是沉浸在自己的人生地图当中。根本不去看一看,别人的地图是什么样。也根本不去看一看实际的生活当中,事实是什么样的。\n\n **移情**:人们会把对一个人的感情和经验移植在别人身上。会认为别人也这样。\n\n> 应该说移情、或者忽略史实,也是一种懒惰的表现。因为去更新地图是件很费力的事情。\n\n#### 4 保持平衡\n 既要承担责任,也要拒绝承担不该承担的责任。差不多又回到了「中庸」之道。「延迟满足」也不能延迟到无限, 从来不过好日子。既要延迟满足,也要过好当下的生活。要有一个富于弹性的约束机制。好像骑自行车下坡一样,既要享受速度,也要注意刹车。为了待会安全的拐弯,也要捏一捏车闸。\n ```生活就是一个不断放弃的过程。必须能够学会放弃一件又一件的事情。包括接受心理治疗就是「放弃」—— 放弃了一个「自己是正常人」 的想法。```\n\n
\n埃里克 埃里克森列举的人一生当中不断放弃的事情\n\n1. 首先要放弃「无需对外界要求作出回应」的婴儿状态。\n2. 三四岁的时候有「无所不能的幻觉」,这个要放弃掉。(为何小孩子特别喜欢绿巨人、钢铁侠、金刚狼这样的超级英雄?因为每个人在三四岁的时候都曾经幻想过自己是无所不能的超人。所以这种童话永远有市场。)\n3. 放弃完全占有父亲或者母亲的欲望。放弃童年的依赖感。\n4. 放弃心中被扭曲了的父母形象。(我们曾经以为父母是完美的)放弃。\n5. 青春期的自以为拥有「无穷潜力」的感觉。放弃! I am the King of the World!\n6. 无拘无束的自由\n7. 青年时期的灵巧与活力\n8. 青春时期的性吸引力;长生不老的空想。\n9. 对子女的权威(在子女面前总是说了算的)\n10. 各种各样「暂时性」的权力——退休了,社会给你的权力也没有了。\n11. 身体永远健康——放弃\n12. 最后,自我以及生命本身也要放弃。\n
\n\n### 爱\n\n**【爱】**[](def_爱) :为了促进自己和他人心智成熟,而不断拓展自我界限,实现自我完善的一种意愿。\n> 核心观点就是「要看重心智成熟这件事」。心智成熟是发生在你和被爱的那个人之间的,两个人都需要达成心智成熟。\n> _不要以为一昧的付出就是爱。爱的要求很高。要达成两个的`共同成熟`_\n\n一个人懂得什么是真正的爱,才能够是一个真正成熟的人。否则你会看到很多人以「爱」的名义在伤害、控制、占有对方。「爱」有以下四个误区:过度关注、坠入情网、精神灌注、自我牺牲。\n\n#### 过度关注\n* 实际上是一种「依赖」\n例子,一个妈妈,孩子都上高中了,还每天开车接送孩子上学。说孩子一个上学走太让人担心了。「过度关注」实际上是一种「依赖」。(`妈妈在“依赖”这个孩子`)这种类型的人经常说的话是“没有你我活不下去”。这个小孩之所以出现在书中,是因为孩子长大后来做了心理咨询。他在人生当中做任何事情都不成功。他的能力非常的欠缺。为什么?因为他从小到大完全被母爱这样束缚着。他妈妈根本不去管孩子能否「成熟」。他妈妈根本不去管这样做对孩子的心智健康、发展有没有好处。唯一的就是「你别出事,我必须盯着你」!`她不是为对方在做这样的事,她是在为自己做这样的事情。如果发展到极致,变得很严重的话,会变成一种疾病,叫「**消极性依赖人格失调症**」。—— 他必须依赖某一个外在的东西,他才能够觉得自己是存在的。如果有这么一个人,就是死死的缠住他,就是不离开他。有一个人作为对象,他才能找到自己的位置。如果找不到这样的人,就很可能会沉迷于毒品和酒精。\n\n* 对「爱」无度的索求\n对别人的爱根本与对方无关,他只是希望找到一个人,能够投射自己在上面,能够找到自己——「因为有人爱我,我就存在」。(例子,有个人离婚了,生活很痛苦,用酒精麻醉自己。咨询的第二天来跟医生说,我好了,我现在很幸福。因为昨晚在酒吧认识一个女人,她说她爱我。我现在很好。)总是苦思如何获得别人的爱,却没有精力去爱别人。就像饥肠辘辘的人,总想着向别人讨要食物,却拿不出食物来帮助别人。`他们永远孤独寂寞,永远无法体会到满足感。`尤其可怕的是,他们不知道自己患上了「消极性依赖人格失调症」。其造成原因多是童年缺乏爱,然后总觉的自己「没资格被爱」。人要感觉自己是被爱的,才有资格跟别人平起平坐,独立地生活和对话。患有这种心理疾病的人,他根本没有感觉到自己的资格,永远都在怀疑别人不爱他。所以只要别人拒绝他,就会感到无比的痛苦和伤心。而他永远需要找到一个紧紧拉住的,依赖的对象。这不是爱,这是占有。\n\n#### 坠入情网\n**坠入情网是欲望**。是你体内的激素分泌。因为我们的基因要求我们要生殖,见到异性感觉自己爱上他了。实际上是自己的一种欲望。一段时间后当你的欲望被释放掉了,体内的激素的大潮开始退去的时候,会发现这个人看起啦那么讨厌。坠入情网实际上是``「自我界限的短暂崩溃」``。除了自我界限的理论,还有以下几个点:\n* 不是出于主管意愿,它不是一个有计划有意识的选择。(很多人只把它看成一个感觉,而不是一个「动作」,爱是一个动词,不是感觉)\n* 不是自我界限的扩展,而是自我界限的部分的暂时性的崩溃。扩展自我界限需要付出足够的努力,坠入情网却无需努力。\n* 坠入情网唯一的作用是消除寂寞。而不是有目的的促进心灵的成长。\n* 简单来说贪恋爱可能是「爱」的发端,可能能培养出来爱,但它不是「爱」本身。\n\n#### 精神贯注\n`爱宠物、爱好这些也不是爱`,而是「精神贯注」。就是当你把自己的精神贯注在一个事物上的时候,你以为这只狗“懂你”,其实上是“你投射在了它身上”,你在猜想它的想法。跟真正的爱不一样。为什么呢:\n* 首先,我们跟宠物的沟通非常有限。我们不知道他们每天在想什么,却一厢情愿的把自己的想法和感受投射在它们身上。实际上这只是我们的主观愿望罢了。\n* 其次,我们喜欢宠物的原因是因为它们表现乖巧,任凭摆弄。如果宠物不听话,破坏家具,随意大小便,甚至咬上我们几口。我们就可能把它赶出家门。如果要改变宠物的心智,我们只能把它送到宠物学校。如果与某个人相处,局面就完全不同了。\n\n有一种精神贯注叫「婴儿之爱」。 很多妈妈只喜欢婴儿期的孩子。等孩子三四岁以后妈妈开始烦了。赶紧推给爷爷奶奶带。反过来呢,母爱很充沛,喜欢别人家的孩子,刚生的小婴儿。 这种不是爱,而是``「唯命是从的追求」``。 比如二战后美国的「战争新娘」。一开始新娘对丈夫唯命是从,当她们懂得英语,开始融入美国社会以后,矛盾就渐渐开始产生,离婚率开始上升。\n\n以上几种感情我们误以为是爱,其实不是。它们都有共同的特征,就是以「爱」作为幌子,``只想满足自己的需要``。却从来不把对方的心智成熟当一回事。\n\n\n#### 自我牺牲\n甚至还有人人会发展出来「**自我牺牲式的爱**」。有个妻子,她老公总是欺骗她,总是有外遇。每次闹完,老公回来道歉,她又开始接受他。五六次以后,妻子去找心理医生谈。心理医生告诉她要想清楚,不能老是这样接受他。有一次这个妻子说,我又原谅他了,这次他是真的改好了。他特别怎么怎么样。结果医生发现这个妻子有“受虐倾向”。有受虐倾向的人,会把「自我牺牲」当作是「爱」。他们觉得只要我能够牺牲、奉献就好。\n\n这些东西也是来自童年的经历,就是他童年当中如果有一个这样的“楷模”,总是以自我牺牲为标榜,总是以为我为别人牺牲了那么多,所以 “你看我多好,多高尚”,他在潜意识当中就会慢慢接受“自我牺牲就是爱”这种想法。\n\n
\n **自我界限**:\n小孩子刚出生的时候是没有自我界限的。他在挥动胳膊的时候,觉得整个房间都在动,他与这个世界没有是分割的。到了两三岁发现自己挥动胳膊的时候,房间没有动,甚至他发现自己哭的时候,别人并不饿。 才能慢慢感受到原来自己跟他人是不一样的。到青春期这个人的自我界限已经开始完全封闭起来了。原来这个世界只有我自己,连我的父母都不了解我,我的喜怒哀乐他们根本不知道。所以人们开始陷入深深的孤独。青春期的孩子觉得自己最“孤独”,他觉得没人理解他,我是一个完全独一无二的个体,谁跟我都不一样,他的自我界限完全封闭起来。\n到了谈恋爱。谈恋爱是需要冒风险的,你是需要有勇气打开自我的界限,和另外一个人融为一体的。所以初恋的时候,很多人会有「**圣洁**」的感觉。就是“我打开了”,有一个人竟然“完全懂我”。有一个人可以跟我融为一体,那种水乳交融的感觉,他以为自己找到了「真爱」。因为他的边界在短期的崩溃。当他的自我边界崩溃以后,他感受到了生命的狂喜,那个就是短暂的获得了「爱」的感觉。但是那是假象。`因为那个并不建立在令我和对方人格不断成熟的一个过程当中。他并不是希望达成心智的成熟,他只是自我边界的短暂崩溃`。所以过了一两个月以后,这个自我界限慢慢弥合起来,他发现说“这个人怎么跟我也不一样”?“这个人的想法跟我也不同”。 现在的孩子谈恋爱特别快,有感觉就谈,没感觉了就分。把「感觉」当成了「爱」,事实上感觉只是欲望,是性欲。\n 但不要觉得欲望不是一件好事,无论是欲望,还是依赖,或者过度关注这样的东西,都是`培养爱的基础`。\n正是因为两个人打破了边界,走到一起,双方有可能为对方作出了承诺。接下来为了完成自己的承诺,需要不断的努力,需要有自律性。当你的自律性跟承诺相结合在起来的时候,你的这个短暂的恋爱的感觉爱,会慢慢滋生出真正的爱。 能够带来对方和自己心智共同的成熟。\n
\n
\n\n``真正的「爱」`` :爱是实际行动,是真正的付出。\n\n爱的感觉与精神贯注密不可分。后者是把情感与兴趣贯注在对外的对象上,将其当作属于自己的一部分。精神贯注虽然跟真正的爱容易混淆,但是依然有显著的区别。首先,精神贯注的对象不一定是有生命的事物。因此就不见得会有心灵的感受。其次,对某种事物产生精神贯注的人,未必会重视其心智的成熟。(比如无原则溺爱孩子的父母)第三,精神贯注可能与智慧和责任无关。(酒吧认识一个人,立刻就情有所钟。但没有任何计划性,没有后续责任)。最后,精神贯注随时都有可能消失。今晚还很开心,明天不开心就分手啰。\n\n真正的爱需要投入和奉献,需要付出全部的智慧与力量。要使爱的对象得到成长,就必须付出足够多的努力,不然爱的愿望就会落空。 唯有真正的投入与奉献,才是实现爱的有效方式。真正的爱是自主的选择,无论「爱」的「感觉」是否存在, 都要奉献出情感和智慧。\n\n
\n\n**「爱」的表现**\n\n1. 倾听。我们真的能够拿出时间来,认真倾听对方的说话。最起码的尊重是通过倾听来展开的,我们要做一个良好的「倾听者」。\n2. 要有心里准备,接受爱的时候,就要准备承担风险。(有人经历过丧失亲人,之后就特别怕建立亲密关系。因为怕失去,「失去」的痛苦吓坏了他。)(爱还要面临冲突的风险。)\n3. 需要尊重对方的独立性。否则就是占有,就是依赖。\n\n### 信仰\n\n#### 科学也是信仰\n科学也是一种信仰。这个世界上上信科学的人比信宗教的人多。人不是生活在一个真实的世界当中的,人是生活在思想家为我们所设定的思想通道当中的。科学家在不断的拓宽我们人类的视线,建立了科学的信仰。 作者认为宗教的信仰在某种程度上可能会导致人的某些情况下的精神分裂。但是在某些情况下也会带来信念,帮助人们解决心理的问题。比喻:倒洗澡水的时候,千万不要把婴儿也倒出去。对待信仰的时候,不能过于简单化。\n\n#### 原罪\n作者认为人类的`「原罪」`就是`「懒惰」`。\n\n自律需要用力,爱需要用力,这个世界天然的方向是「熵增」,屋子一定会变乱。我花力气把屋子整理干净十个「逆熵」的过程,逆熵是需要话费气力的。 人天生喜欢熵增,喜欢懒惰。在伊甸园,其实上帝经常在园子里散步。这两孩子如果能去问一下,这玩意儿能吃吗?人类的命运就改变了。这两个人为什么不去问 一下上帝呢?因为这两孩子「懒惰」,而「懒惰」的背后是「恐惧」。他们担心问了上帝以后受到上帝的责罚。\n>(天涯:我认为这个解释不对。那个时候的亚当和夏娃没有罪恶感,也从来没有受过责罚,怎么会有这个恐惧呢?而恐惧则是被赶出伊甸园以后人类才有的心智。)\n\n有人不好好学习,是因为就算好好学习了也未必学得好啊。如果好好学了而没有学好,就会面对失去「我不是没能力,只是不愿学而已」这块遮羞布的恐惧。\n\n尽量要做到潜意识和意识「合一」。因为潜意识里面有很多的能量,而我们由于“懒惰”以及“恐惧”不愿意去开发的,不愿意去面对的。\n\n这本书为什么叫【少有人走的路】呢?因为人人都喜欢熵增的方向,都喜欢轻松的方向,人人都喜欢懒惰的方向。喜欢部分什么劲,就得到一切的这种感觉。如果你想要变得成熟,就要费力去做一些逆熵的行为,自律的事,延迟满足的事,用行动表达「爱」的 过程。\n\n#### 两种力量\n这个世界始终是由两种力量来统治的,分别是「政治的力量」和「心灵的力量」。\n\n【政治的力量】[](def_政治的力量):以公开或者隐秘的方式,去强迫别人遵循自己的意愿。这种力量既存在于权力之中,也存在于金钱之中。然而他并不属于拥有权力或者金钱的人。归根到底,政治的力量和德行以及智慧无关,最愚蠢最邪恶的人也可能成为地球的统治者。\n【心灵的力量】[](def_心灵的力量):则完全存在于人类的心中,它和强迫、控制别人的力量没有关系。它是在意识基础上作出决定的力量。也就是「意识的力量」。\n\n如果我们的心理能够得到力量,我们就会感到舒适和愉快,在人生的旅途上稳扎稳打,循序渐进。 进步带给我们的愉悦感难以言喻。没有什么比成为人生的专家,熟知自己所做的事情,更让人感觉到幸福。我们的心灵越是成熟,就越有可能成为人生的专家。当我们的心智成熟到一定的阶段,我们就会更加谦逊而快乐。\n\n---\n\n","source":"_posts/读书笔记/《少有人走的路》笔记.md","raw":"---\ntitle: 《少有人走的路》笔记\ndate: 2019-07-21 00:14:37\nurlname: road-less-traveled-summary\ntoc: true\ntags: [心理, 成长]\ncategories: [读书笔记]\n\n---\n\n**成熟 = [自律](#id_zilv) + [爱](#id_ai)**[](def_成熟)\n\n\n\n### 自律\n\n**【自律】**[](def_自律) : 主动要求自己以积极的态度去承受痛苦,解决问题。\n\n自律的四个`原则`:延迟满足感、承担责任、忠于事实、保持平衡。:smile:\n\n#### 1 延迟满足感\n\n
\n\n人生当中总是绕着困难走。一个揍孩子和对孩子大喊大叫的父母就是不懂得延迟满足感的父母。 应该陪着孩子一起经历困难和痛苦。而父母试图通过家庭暴力的方式,试图将父母本身的责任区隔开。父母没有学会延迟满足感,这个孩子将来长大了也不会。很多人延迟满足感的能力非常糟糕,来自于父母的不自律。当父母不自律的时候,孩子就没法获得足够的爱和照顾。—— 所以这个孩子会忽略自我的价值。有的人喜欢浪费时间,而浪费时间的意思就是,_「我这个人的时间没什么价值」_。\n不会延迟满足感的人,在长大后看到问题会假装没看到,以为等着问题慢慢就会过去,期待问题自行消失。\n
\n\n> - 训斥孩子 ~\\> 是为了迅速达成目的,而不是耐心陪孩子面对问题。\n> - 父母不自律 => 孩子不自律\n> - 不会延迟满足感 => 有意忽略问题\n\n#### 2 承担责任\n\n1. **神经官能症**[](def_神经官能症): 把一切东西都认为是自己的问题。\n> _我如果怎么样就好了。我要是不怎么样就好了。总是充满后悔和内疚。祥林嫂_\n2. **人格失调症**[](def_人格失调症):他认为这一切都不是我的问题。他能找到任何一个理由,是因为外在的东西,他就不会责怪自己,他认为都是你们的问题。[](flag_心理学_病症)\n> 「神经官能症」自己活得很痛苦,「人格失调症」让别人活得很痛苦。\n\n
\n\n作者提供在冲绳岛上的一个案例,一个军官的妻子,宁愿自杀也不愿意去学自动挡开车的事。\n从某种意义上说,所有的孩子都患有人格失调症,都会本能的逃避责罚。 同时又患有某种神经官能症,把自己承受的痛苦看成是罪有应得。缺少关心的孩子会自惭形秽,认为自己不够可爱,缺点大于优点等等。\n
\n\n如果你不能解决问题,那么你自己就会成为问题。`我们需要合理的承担责任,既不把责任全部推卸到外部,也不把责任全部揽到自己身上。保持一个合理的平衡。`\n> 如果你不能让自己成为人格更加健全,更加成熟的人。你就会把问题带给你的孩子,带给你的家庭。\n\n#### 3 忠于事实\n\n大量的人是生活在自己的幻想当中的。这叫**人生地图**。他给自己绘制一张人生地图,他认为人生就这样,他已经认定了。这就叫做“不忠于事实”,他只 _忠于自己的幻想_。\n
\n\n案例:有个人小时候被父母欺骗过,就是父母说话经常不算数。导致他潜意识积累了一个信念:“父母是不可信”的。当他的人生地图绘制出来这么一个坐标,认为父母不可信了自后,他几乎就推论到“人人都不可信”。所以在他一生的成长过程当中,他跟警察发生矛盾,跟领导发生矛盾,跟顾客发生矛盾,跟妻子发生矛盾。案例中最后他唯一信任的是他的两个孩子。妻子把两个孩子带走,所以他人生也崩溃了。他跟作者约定时间不来,然后他说能不能星期六,作者说我的时间是跟别人约过的,不能随便调整。他说:“你不是心理医生吗?为什么不能多关心我一点呢”?他认为作者(心理医生)也是不可信任的人,直接拉黑。\n
\n这种人你很难跟他解释,很难让他面对真正的世界。因为在他心目当中完全是用自己的一套逻辑在解决问题。\n\n所以所谓的「心理治疗」,就是鼓励「说真话」的游戏。鼓励大家能够面对事实,能够把自己看到的真相,感受到的真实的感觉,说出来的一个过程。所以没有经过这样的调试,有大量的人是天天活在「幻觉」当中的,就是沉浸在自己的人生地图当中。根本不去看一看,别人的地图是什么样。也根本不去看一看实际的生活当中,事实是什么样的。\n\n **移情**:人们会把对一个人的感情和经验移植在别人身上。会认为别人也这样。\n\n> 应该说移情、或者忽略史实,也是一种懒惰的表现。因为去更新地图是件很费力的事情。\n\n#### 4 保持平衡\n 既要承担责任,也要拒绝承担不该承担的责任。差不多又回到了「中庸」之道。「延迟满足」也不能延迟到无限, 从来不过好日子。既要延迟满足,也要过好当下的生活。要有一个富于弹性的约束机制。好像骑自行车下坡一样,既要享受速度,也要注意刹车。为了待会安全的拐弯,也要捏一捏车闸。\n ```生活就是一个不断放弃的过程。必须能够学会放弃一件又一件的事情。包括接受心理治疗就是「放弃」—— 放弃了一个「自己是正常人」 的想法。```\n\n
\n埃里克 埃里克森列举的人一生当中不断放弃的事情\n\n1. 首先要放弃「无需对外界要求作出回应」的婴儿状态。\n2. 三四岁的时候有「无所不能的幻觉」,这个要放弃掉。(为何小孩子特别喜欢绿巨人、钢铁侠、金刚狼这样的超级英雄?因为每个人在三四岁的时候都曾经幻想过自己是无所不能的超人。所以这种童话永远有市场。)\n3. 放弃完全占有父亲或者母亲的欲望。放弃童年的依赖感。\n4. 放弃心中被扭曲了的父母形象。(我们曾经以为父母是完美的)放弃。\n5. 青春期的自以为拥有「无穷潜力」的感觉。放弃! I am the King of the World!\n6. 无拘无束的自由\n7. 青年时期的灵巧与活力\n8. 青春时期的性吸引力;长生不老的空想。\n9. 对子女的权威(在子女面前总是说了算的)\n10. 各种各样「暂时性」的权力——退休了,社会给你的权力也没有了。\n11. 身体永远健康——放弃\n12. 最后,自我以及生命本身也要放弃。\n
\n\n### 爱\n\n**【爱】**[](def_爱) :为了促进自己和他人心智成熟,而不断拓展自我界限,实现自我完善的一种意愿。\n> 核心观点就是「要看重心智成熟这件事」。心智成熟是发生在你和被爱的那个人之间的,两个人都需要达成心智成熟。\n> _不要以为一昧的付出就是爱。爱的要求很高。要达成两个的`共同成熟`_\n\n一个人懂得什么是真正的爱,才能够是一个真正成熟的人。否则你会看到很多人以「爱」的名义在伤害、控制、占有对方。「爱」有以下四个误区:过度关注、坠入情网、精神灌注、自我牺牲。\n\n#### 过度关注\n* 实际上是一种「依赖」\n例子,一个妈妈,孩子都上高中了,还每天开车接送孩子上学。说孩子一个上学走太让人担心了。「过度关注」实际上是一种「依赖」。(`妈妈在“依赖”这个孩子`)这种类型的人经常说的话是“没有你我活不下去”。这个小孩之所以出现在书中,是因为孩子长大后来做了心理咨询。他在人生当中做任何事情都不成功。他的能力非常的欠缺。为什么?因为他从小到大完全被母爱这样束缚着。他妈妈根本不去管孩子能否「成熟」。他妈妈根本不去管这样做对孩子的心智健康、发展有没有好处。唯一的就是「你别出事,我必须盯着你」!`她不是为对方在做这样的事,她是在为自己做这样的事情。如果发展到极致,变得很严重的话,会变成一种疾病,叫「**消极性依赖人格失调症**」。—— 他必须依赖某一个外在的东西,他才能够觉得自己是存在的。如果有这么一个人,就是死死的缠住他,就是不离开他。有一个人作为对象,他才能找到自己的位置。如果找不到这样的人,就很可能会沉迷于毒品和酒精。\n\n* 对「爱」无度的索求\n对别人的爱根本与对方无关,他只是希望找到一个人,能够投射自己在上面,能够找到自己——「因为有人爱我,我就存在」。(例子,有个人离婚了,生活很痛苦,用酒精麻醉自己。咨询的第二天来跟医生说,我好了,我现在很幸福。因为昨晚在酒吧认识一个女人,她说她爱我。我现在很好。)总是苦思如何获得别人的爱,却没有精力去爱别人。就像饥肠辘辘的人,总想着向别人讨要食物,却拿不出食物来帮助别人。`他们永远孤独寂寞,永远无法体会到满足感。`尤其可怕的是,他们不知道自己患上了「消极性依赖人格失调症」。其造成原因多是童年缺乏爱,然后总觉的自己「没资格被爱」。人要感觉自己是被爱的,才有资格跟别人平起平坐,独立地生活和对话。患有这种心理疾病的人,他根本没有感觉到自己的资格,永远都在怀疑别人不爱他。所以只要别人拒绝他,就会感到无比的痛苦和伤心。而他永远需要找到一个紧紧拉住的,依赖的对象。这不是爱,这是占有。\n\n#### 坠入情网\n**坠入情网是欲望**。是你体内的激素分泌。因为我们的基因要求我们要生殖,见到异性感觉自己爱上他了。实际上是自己的一种欲望。一段时间后当你的欲望被释放掉了,体内的激素的大潮开始退去的时候,会发现这个人看起啦那么讨厌。坠入情网实际上是``「自我界限的短暂崩溃」``。除了自我界限的理论,还有以下几个点:\n* 不是出于主管意愿,它不是一个有计划有意识的选择。(很多人只把它看成一个感觉,而不是一个「动作」,爱是一个动词,不是感觉)\n* 不是自我界限的扩展,而是自我界限的部分的暂时性的崩溃。扩展自我界限需要付出足够的努力,坠入情网却无需努力。\n* 坠入情网唯一的作用是消除寂寞。而不是有目的的促进心灵的成长。\n* 简单来说贪恋爱可能是「爱」的发端,可能能培养出来爱,但它不是「爱」本身。\n\n#### 精神贯注\n`爱宠物、爱好这些也不是爱`,而是「精神贯注」。就是当你把自己的精神贯注在一个事物上的时候,你以为这只狗“懂你”,其实上是“你投射在了它身上”,你在猜想它的想法。跟真正的爱不一样。为什么呢:\n* 首先,我们跟宠物的沟通非常有限。我们不知道他们每天在想什么,却一厢情愿的把自己的想法和感受投射在它们身上。实际上这只是我们的主观愿望罢了。\n* 其次,我们喜欢宠物的原因是因为它们表现乖巧,任凭摆弄。如果宠物不听话,破坏家具,随意大小便,甚至咬上我们几口。我们就可能把它赶出家门。如果要改变宠物的心智,我们只能把它送到宠物学校。如果与某个人相处,局面就完全不同了。\n\n有一种精神贯注叫「婴儿之爱」。 很多妈妈只喜欢婴儿期的孩子。等孩子三四岁以后妈妈开始烦了。赶紧推给爷爷奶奶带。反过来呢,母爱很充沛,喜欢别人家的孩子,刚生的小婴儿。 这种不是爱,而是``「唯命是从的追求」``。 比如二战后美国的「战争新娘」。一开始新娘对丈夫唯命是从,当她们懂得英语,开始融入美国社会以后,矛盾就渐渐开始产生,离婚率开始上升。\n\n以上几种感情我们误以为是爱,其实不是。它们都有共同的特征,就是以「爱」作为幌子,``只想满足自己的需要``。却从来不把对方的心智成熟当一回事。\n\n\n#### 自我牺牲\n甚至还有人人会发展出来「**自我牺牲式的爱**」。有个妻子,她老公总是欺骗她,总是有外遇。每次闹完,老公回来道歉,她又开始接受他。五六次以后,妻子去找心理医生谈。心理医生告诉她要想清楚,不能老是这样接受他。有一次这个妻子说,我又原谅他了,这次他是真的改好了。他特别怎么怎么样。结果医生发现这个妻子有“受虐倾向”。有受虐倾向的人,会把「自我牺牲」当作是「爱」。他们觉得只要我能够牺牲、奉献就好。\n\n这些东西也是来自童年的经历,就是他童年当中如果有一个这样的“楷模”,总是以自我牺牲为标榜,总是以为我为别人牺牲了那么多,所以 “你看我多好,多高尚”,他在潜意识当中就会慢慢接受“自我牺牲就是爱”这种想法。\n\n
\n **自我界限**:\n小孩子刚出生的时候是没有自我界限的。他在挥动胳膊的时候,觉得整个房间都在动,他与这个世界没有是分割的。到了两三岁发现自己挥动胳膊的时候,房间没有动,甚至他发现自己哭的时候,别人并不饿。 才能慢慢感受到原来自己跟他人是不一样的。到青春期这个人的自我界限已经开始完全封闭起来了。原来这个世界只有我自己,连我的父母都不了解我,我的喜怒哀乐他们根本不知道。所以人们开始陷入深深的孤独。青春期的孩子觉得自己最“孤独”,他觉得没人理解他,我是一个完全独一无二的个体,谁跟我都不一样,他的自我界限完全封闭起来。\n到了谈恋爱。谈恋爱是需要冒风险的,你是需要有勇气打开自我的界限,和另外一个人融为一体的。所以初恋的时候,很多人会有「**圣洁**」的感觉。就是“我打开了”,有一个人竟然“完全懂我”。有一个人可以跟我融为一体,那种水乳交融的感觉,他以为自己找到了「真爱」。因为他的边界在短期的崩溃。当他的自我边界崩溃以后,他感受到了生命的狂喜,那个就是短暂的获得了「爱」的感觉。但是那是假象。`因为那个并不建立在令我和对方人格不断成熟的一个过程当中。他并不是希望达成心智的成熟,他只是自我边界的短暂崩溃`。所以过了一两个月以后,这个自我界限慢慢弥合起来,他发现说“这个人怎么跟我也不一样”?“这个人的想法跟我也不同”。 现在的孩子谈恋爱特别快,有感觉就谈,没感觉了就分。把「感觉」当成了「爱」,事实上感觉只是欲望,是性欲。\n 但不要觉得欲望不是一件好事,无论是欲望,还是依赖,或者过度关注这样的东西,都是`培养爱的基础`。\n正是因为两个人打破了边界,走到一起,双方有可能为对方作出了承诺。接下来为了完成自己的承诺,需要不断的努力,需要有自律性。当你的自律性跟承诺相结合在起来的时候,你的这个短暂的恋爱的感觉爱,会慢慢滋生出真正的爱。 能够带来对方和自己心智共同的成熟。\n
\n
\n\n``真正的「爱」`` :爱是实际行动,是真正的付出。\n\n爱的感觉与精神贯注密不可分。后者是把情感与兴趣贯注在对外的对象上,将其当作属于自己的一部分。精神贯注虽然跟真正的爱容易混淆,但是依然有显著的区别。首先,精神贯注的对象不一定是有生命的事物。因此就不见得会有心灵的感受。其次,对某种事物产生精神贯注的人,未必会重视其心智的成熟。(比如无原则溺爱孩子的父母)第三,精神贯注可能与智慧和责任无关。(酒吧认识一个人,立刻就情有所钟。但没有任何计划性,没有后续责任)。最后,精神贯注随时都有可能消失。今晚还很开心,明天不开心就分手啰。\n\n真正的爱需要投入和奉献,需要付出全部的智慧与力量。要使爱的对象得到成长,就必须付出足够多的努力,不然爱的愿望就会落空。 唯有真正的投入与奉献,才是实现爱的有效方式。真正的爱是自主的选择,无论「爱」的「感觉」是否存在, 都要奉献出情感和智慧。\n\n
\n\n**「爱」的表现**\n\n1. 倾听。我们真的能够拿出时间来,认真倾听对方的说话。最起码的尊重是通过倾听来展开的,我们要做一个良好的「倾听者」。\n2. 要有心里准备,接受爱的时候,就要准备承担风险。(有人经历过丧失亲人,之后就特别怕建立亲密关系。因为怕失去,「失去」的痛苦吓坏了他。)(爱还要面临冲突的风险。)\n3. 需要尊重对方的独立性。否则就是占有,就是依赖。\n\n### 信仰\n\n#### 科学也是信仰\n科学也是一种信仰。这个世界上上信科学的人比信宗教的人多。人不是生活在一个真实的世界当中的,人是生活在思想家为我们所设定的思想通道当中的。科学家在不断的拓宽我们人类的视线,建立了科学的信仰。 作者认为宗教的信仰在某种程度上可能会导致人的某些情况下的精神分裂。但是在某些情况下也会带来信念,帮助人们解决心理的问题。比喻:倒洗澡水的时候,千万不要把婴儿也倒出去。对待信仰的时候,不能过于简单化。\n\n#### 原罪\n作者认为人类的`「原罪」`就是`「懒惰」`。\n\n自律需要用力,爱需要用力,这个世界天然的方向是「熵增」,屋子一定会变乱。我花力气把屋子整理干净十个「逆熵」的过程,逆熵是需要话费气力的。 人天生喜欢熵增,喜欢懒惰。在伊甸园,其实上帝经常在园子里散步。这两孩子如果能去问一下,这玩意儿能吃吗?人类的命运就改变了。这两个人为什么不去问 一下上帝呢?因为这两孩子「懒惰」,而「懒惰」的背后是「恐惧」。他们担心问了上帝以后受到上帝的责罚。\n>(天涯:我认为这个解释不对。那个时候的亚当和夏娃没有罪恶感,也从来没有受过责罚,怎么会有这个恐惧呢?而恐惧则是被赶出伊甸园以后人类才有的心智。)\n\n有人不好好学习,是因为就算好好学习了也未必学得好啊。如果好好学了而没有学好,就会面对失去「我不是没能力,只是不愿学而已」这块遮羞布的恐惧。\n\n尽量要做到潜意识和意识「合一」。因为潜意识里面有很多的能量,而我们由于“懒惰”以及“恐惧”不愿意去开发的,不愿意去面对的。\n\n这本书为什么叫【少有人走的路】呢?因为人人都喜欢熵增的方向,都喜欢轻松的方向,人人都喜欢懒惰的方向。喜欢部分什么劲,就得到一切的这种感觉。如果你想要变得成熟,就要费力去做一些逆熵的行为,自律的事,延迟满足的事,用行动表达「爱」的 过程。\n\n#### 两种力量\n这个世界始终是由两种力量来统治的,分别是「政治的力量」和「心灵的力量」。\n\n【政治的力量】[](def_政治的力量):以公开或者隐秘的方式,去强迫别人遵循自己的意愿。这种力量既存在于权力之中,也存在于金钱之中。然而他并不属于拥有权力或者金钱的人。归根到底,政治的力量和德行以及智慧无关,最愚蠢最邪恶的人也可能成为地球的统治者。\n【心灵的力量】[](def_心灵的力量):则完全存在于人类的心中,它和强迫、控制别人的力量没有关系。它是在意识基础上作出决定的力量。也就是「意识的力量」。\n\n如果我们的心理能够得到力量,我们就会感到舒适和愉快,在人生的旅途上稳扎稳打,循序渐进。 进步带给我们的愉悦感难以言喻。没有什么比成为人生的专家,熟知自己所做的事情,更让人感觉到幸福。我们的心灵越是成熟,就越有可能成为人生的专家。当我们的心智成熟到一定的阶段,我们就会更加谦逊而快乐。\n\n---\n\n","slug":"读书笔记/《少有人走的路》笔记","published":1,"updated":"2019-08-01T04:04:18.000Z","_id":"cka1y597q00134huu98tdadd8","comments":1,"layout":"post","photos":[],"link":"","content":"

成熟 = 自律 +

\n\n

自律

\n

【自律】 : 主动要求自己以积极的态度去承受痛苦,解决问题。

\n

自律的四个原则:延迟满足感、承担责任、忠于事实、保持平衡。:smile:

\n

1 延迟满足感

\n
\n\n人生当中总是绕着困难走。一个揍孩子和对孩子大喊大叫的父母就是不懂得延迟满足感的父母。 应该陪着孩子一起经历困难和痛苦。而父母试图通过家庭暴力的方式,试图将父母本身的责任区隔开。父母没有学会延迟满足感,这个孩子将来长大了也不会。很多人延迟满足感的能力非常糟糕,来自于父母的不自律。当父母不自律的时候,孩子就没法获得足够的爱和照顾。—— 所以这个孩子会忽略自我的价值。有的人喜欢浪费时间,而浪费时间的意思就是,_「我这个人的时间没什么价值」_。\n不会延迟满足感的人,在长大后看到问题会假装没看到,以为等着问题慢慢就会过去,期待问题自行消失。\n
\n
\n\n
\n

2 承担责任

\n
    \n
  1. 神经官能症: 把一切东西都认为是自己的问题。
  2. \n
\n
\n

我如果怎么样就好了。我要是不怎么样就好了。总是充满后悔和内疚。祥林嫂

\n
\n
    \n
  1. 人格失调症:他认为这一切都不是我的问题。他能找到任何一个理由,是因为外在的东西,他就不会责怪自己,他认为都是你们的问题。
  2. \n
\n
\n

「神经官能症」自己活得很痛苦,「人格失调症」让别人活得很痛苦。

\n
\n
\n\n作者提供在冲绳岛上的一个案例,一个军官的妻子,宁愿自杀也不愿意去学自动挡开车的事。\n从某种意义上说,所有的孩子都患有人格失调症,都会本能的逃避责罚。 同时又患有某种神经官能症,把自己承受的痛苦看成是罪有应得。缺少关心的孩子会自惭形秽,认为自己不够可爱,缺点大于优点等等。\n
\n

如果你不能解决问题,那么你自己就会成为问题。我们需要合理的承担责任,既不把责任全部推卸到外部,也不把责任全部揽到自己身上。保持一个合理的平衡。

\n
\n

如果你不能让自己成为人格更加健全,更加成熟的人。你就会把问题带给你的孩子,带给你的家庭。

\n
\n

3 忠于事实

\n

大量的人是生活在自己的幻想当中的。这叫人生地图。他给自己绘制一张人生地图,他认为人生就这样,他已经认定了。这就叫做“不忠于事实”,他只 忠于自己的幻想

\n
\n\n案例:有个人小时候被父母欺骗过,就是父母说话经常不算数。导致他潜意识积累了一个信念:“父母是不可信”的。当他的人生地图绘制出来这么一个坐标,认为父母不可信了自后,他几乎就推论到“人人都不可信”。所以在他一生的成长过程当中,他跟警察发生矛盾,跟领导发生矛盾,跟顾客发生矛盾,跟妻子发生矛盾。案例中最后他唯一信任的是他的两个孩子。妻子把两个孩子带走,所以他人生也崩溃了。他跟作者约定时间不来,然后他说能不能星期六,作者说我的时间是跟别人约过的,不能随便调整。他说:“你不是心理医生吗?为什么不能多关心我一点呢”?他认为作者(心理医生)也是不可信任的人,直接拉黑。\n
\n这种人你很难跟他解释,很难让他面对真正的世界。因为在他心目当中完全是用自己的一套逻辑在解决问题。\n

所以所谓的「心理治疗」,就是鼓励「说真话」的游戏。鼓励大家能够面对事实,能够把自己看到的真相,感受到的真实的感觉,说出来的一个过程。所以没有经过这样的调试,有大量的人是天天活在「幻觉」当中的,就是沉浸在自己的人生地图当中。根本不去看一看,别人的地图是什么样。也根本不去看一看实际的生活当中,事实是什么样的。

\n

移情:人们会把对一个人的感情和经验移植在别人身上。会认为别人也这样。

\n
\n

应该说移情、或者忽略史实,也是一种懒惰的表现。因为去更新地图是件很费力的事情。

\n
\n

4 保持平衡

\n

既要承担责任,也要拒绝承担不该承担的责任。差不多又回到了「中庸」之道。「延迟满足」也不能延迟到无限, 从来不过好日子。既要延迟满足,也要过好当下的生活。要有一个富于弹性的约束机制。好像骑自行车下坡一样,既要享受速度,也要注意刹车。为了待会安全的拐弯,也要捏一捏车闸。
\n生活就是一个不断放弃的过程。必须能够学会放弃一件又一件的事情。包括接受心理治疗就是「放弃」—— 放弃了一个「自己是正常人」 的想法。

\n
\n埃里克 埃里克森列举的人一生当中不断放弃的事情\n
    \n
  1. 首先要放弃「无需对外界要求作出回应」的婴儿状态。
  2. \n
  3. 三四岁的时候有「无所不能的幻觉」,这个要放弃掉。(为何小孩子特别喜欢绿巨人、钢铁侠、金刚狼这样的超级英雄?因为每个人在三四岁的时候都曾经幻想过自己是无所不能的超人。所以这种童话永远有市场。)
  4. \n
  5. 放弃完全占有父亲或者母亲的欲望。放弃童年的依赖感。
  6. \n
  7. 放弃心中被扭曲了的父母形象。(我们曾经以为父母是完美的)放弃。
  8. \n
  9. 青春期的自以为拥有「无穷潜力」的感觉。放弃! I am the King of the World!
  10. \n
  11. 无拘无束的自由
  12. \n
  13. 青年时期的灵巧与活力
  14. \n
  15. 青春时期的性吸引力;长生不老的空想。
  16. \n
  17. 对子女的权威(在子女面前总是说了算的)
  18. \n
  19. 各种各样「暂时性」的权力——退休了,社会给你的权力也没有了。
  20. \n
  21. 身体永远健康——放弃
  22. \n
  23. 最后,自我以及生命本身也要放弃。
  24. \n
\n
\n

\n

【爱】 :为了促进自己和他人心智成熟,而不断拓展自我界限,实现自我完善的一种意愿。

\n
\n

核心观点就是「要看重心智成熟这件事」。心智成熟是发生在你和被爱的那个人之间的,两个人都需要达成心智成熟。
\n不要以为一昧的付出就是爱。爱的要求很高。要达成两个的共同成熟

\n
\n

一个人懂得什么是真正的爱,才能够是一个真正成熟的人。否则你会看到很多人以「爱」的名义在伤害、控制、占有对方。「爱」有以下四个误区:过度关注、坠入情网、精神灌注、自我牺牲。

\n

过度关注

\n\n

坠入情网

\n

坠入情网是欲望。是你体内的激素分泌。因为我们的基因要求我们要生殖,见到异性感觉自己爱上他了。实际上是自己的一种欲望。一段时间后当你的欲望被释放掉了,体内的激素的大潮开始退去的时候,会发现这个人看起啦那么讨厌。坠入情网实际上是「自我界限的短暂崩溃」。除了自我界限的理论,还有以下几个点:

\n\n

精神贯注

\n

爱宠物、爱好这些也不是爱,而是「精神贯注」。就是当你把自己的精神贯注在一个事物上的时候,你以为这只狗“懂你”,其实上是“你投射在了它身上”,你在猜想它的想法。跟真正的爱不一样。为什么呢:

\n\n

有一种精神贯注叫「婴儿之爱」。 很多妈妈只喜欢婴儿期的孩子。等孩子三四岁以后妈妈开始烦了。赶紧推给爷爷奶奶带。反过来呢,母爱很充沛,喜欢别人家的孩子,刚生的小婴儿。 这种不是爱,而是「唯命是从的追求」。 比如二战后美国的「战争新娘」。一开始新娘对丈夫唯命是从,当她们懂得英语,开始融入美国社会以后,矛盾就渐渐开始产生,离婚率开始上升。

\n

以上几种感情我们误以为是爱,其实不是。它们都有共同的特征,就是以「爱」作为幌子,只想满足自己的需要。却从来不把对方的心智成熟当一回事。

\n

自我牺牲

\n

甚至还有人人会发展出来「自我牺牲式的爱」。有个妻子,她老公总是欺骗她,总是有外遇。每次闹完,老公回来道歉,她又开始接受他。五六次以后,妻子去找心理医生谈。心理医生告诉她要想清楚,不能老是这样接受他。有一次这个妻子说,我又原谅他了,这次他是真的改好了。他特别怎么怎么样。结果医生发现这个妻子有“受虐倾向”。有受虐倾向的人,会把「自我牺牲」当作是「爱」。他们觉得只要我能够牺牲、奉献就好。

\n

这些东西也是来自童年的经历,就是他童年当中如果有一个这样的“楷模”,总是以自我牺牲为标榜,总是以为我为别人牺牲了那么多,所以 “你看我多好,多高尚”,他在潜意识当中就会慢慢接受“自我牺牲就是爱”这种想法。

\n
\n **自我界限**:\n小孩子刚出生的时候是没有自我界限的。他在挥动胳膊的时候,觉得整个房间都在动,他与这个世界没有是分割的。到了两三岁发现自己挥动胳膊的时候,房间没有动,甚至他发现自己哭的时候,别人并不饿。 才能慢慢感受到原来自己跟他人是不一样的。到青春期这个人的自我界限已经开始完全封闭起来了。原来这个世界只有我自己,连我的父母都不了解我,我的喜怒哀乐他们根本不知道。所以人们开始陷入深深的孤独。青春期的孩子觉得自己最“孤独”,他觉得没人理解他,我是一个完全独一无二的个体,谁跟我都不一样,他的自我界限完全封闭起来。\n到了谈恋爱。谈恋爱是需要冒风险的,你是需要有勇气打开自我的界限,和另外一个人融为一体的。所以初恋的时候,很多人会有「**圣洁**」的感觉。就是“我打开了”,有一个人竟然“完全懂我”。有一个人可以跟我融为一体,那种水乳交融的感觉,他以为自己找到了「真爱」。因为他的边界在短期的崩溃。当他的自我边界崩溃以后,他感受到了生命的狂喜,那个就是短暂的获得了「爱」的感觉。但是那是假象。`因为那个并不建立在令我和对方人格不断成熟的一个过程当中。他并不是希望达成心智的成熟,他只是自我边界的短暂崩溃`。所以过了一两个月以后,这个自我界限慢慢弥合起来,他发现说“这个人怎么跟我也不一样”?“这个人的想法跟我也不同”。 现在的孩子谈恋爱特别快,有感觉就谈,没感觉了就分。把「感觉」当成了「爱」,事实上感觉只是欲望,是性欲。\n 但不要觉得欲望不是一件好事,无论是欲望,还是依赖,或者过度关注这样的东西,都是`培养爱的基础`。\n正是因为两个人打破了边界,走到一起,双方有可能为对方作出了承诺。接下来为了完成自己的承诺,需要不断的努力,需要有自律性。当你的自律性跟承诺相结合在起来的时候,你的这个短暂的恋爱的感觉爱,会慢慢滋生出真正的爱。 能够带来对方和自己心智共同的成熟。\n
\n
\n

真正的「爱」 :爱是实际行动,是真正的付出。

\n

爱的感觉与精神贯注密不可分。后者是把情感与兴趣贯注在对外的对象上,将其当作属于自己的一部分。精神贯注虽然跟真正的爱容易混淆,但是依然有显著的区别。首先,精神贯注的对象不一定是有生命的事物。因此就不见得会有心灵的感受。其次,对某种事物产生精神贯注的人,未必会重视其心智的成熟。(比如无原则溺爱孩子的父母)第三,精神贯注可能与智慧和责任无关。(酒吧认识一个人,立刻就情有所钟。但没有任何计划性,没有后续责任)。最后,精神贯注随时都有可能消失。今晚还很开心,明天不开心就分手啰。

\n

真正的爱需要投入和奉献,需要付出全部的智慧与力量。要使爱的对象得到成长,就必须付出足够多的努力,不然爱的愿望就会落空。 唯有真正的投入与奉献,才是实现爱的有效方式。真正的爱是自主的选择,无论「爱」的「感觉」是否存在, 都要奉献出情感和智慧。

\n
\n

「爱」的表现

\n
    \n
  1. 倾听。我们真的能够拿出时间来,认真倾听对方的说话。最起码的尊重是通过倾听来展开的,我们要做一个良好的「倾听者」。
  2. \n
  3. 要有心里准备,接受爱的时候,就要准备承担风险。(有人经历过丧失亲人,之后就特别怕建立亲密关系。因为怕失去,「失去」的痛苦吓坏了他。)(爱还要面临冲突的风险。)
  4. \n
  5. 需要尊重对方的独立性。否则就是占有,就是依赖。
  6. \n
\n

信仰

\n

科学也是信仰

\n

科学也是一种信仰。这个世界上上信科学的人比信宗教的人多。人不是生活在一个真实的世界当中的,人是生活在思想家为我们所设定的思想通道当中的。科学家在不断的拓宽我们人类的视线,建立了科学的信仰。 作者认为宗教的信仰在某种程度上可能会导致人的某些情况下的精神分裂。但是在某些情况下也会带来信念,帮助人们解决心理的问题。比喻:倒洗澡水的时候,千万不要把婴儿也倒出去。对待信仰的时候,不能过于简单化。

\n

原罪

\n

作者认为人类的「原罪」就是「懒惰」

\n

自律需要用力,爱需要用力,这个世界天然的方向是「熵增」,屋子一定会变乱。我花力气把屋子整理干净十个「逆熵」的过程,逆熵是需要话费气力的。 人天生喜欢熵增,喜欢懒惰。在伊甸园,其实上帝经常在园子里散步。这两孩子如果能去问一下,这玩意儿能吃吗?人类的命运就改变了。这两个人为什么不去问 一下上帝呢?因为这两孩子「懒惰」,而「懒惰」的背后是「恐惧」。他们担心问了上帝以后受到上帝的责罚。

\n
\n

(天涯:我认为这个解释不对。那个时候的亚当和夏娃没有罪恶感,也从来没有受过责罚,怎么会有这个恐惧呢?而恐惧则是被赶出伊甸园以后人类才有的心智。)

\n
\n

有人不好好学习,是因为就算好好学习了也未必学得好啊。如果好好学了而没有学好,就会面对失去「我不是没能力,只是不愿学而已」这块遮羞布的恐惧。

\n

尽量要做到潜意识和意识「合一」。因为潜意识里面有很多的能量,而我们由于“懒惰”以及“恐惧”不愿意去开发的,不愿意去面对的。

\n

这本书为什么叫【少有人走的路】呢?因为人人都喜欢熵增的方向,都喜欢轻松的方向,人人都喜欢懒惰的方向。喜欢部分什么劲,就得到一切的这种感觉。如果你想要变得成熟,就要费力去做一些逆熵的行为,自律的事,延迟满足的事,用行动表达「爱」的 过程。

\n

两种力量

\n

这个世界始终是由两种力量来统治的,分别是「政治的力量」和「心灵的力量」。

\n

【政治的力量】:以公开或者隐秘的方式,去强迫别人遵循自己的意愿。这种力量既存在于权力之中,也存在于金钱之中。然而他并不属于拥有权力或者金钱的人。归根到底,政治的力量和德行以及智慧无关,最愚蠢最邪恶的人也可能成为地球的统治者。
\n【心灵的力量】:则完全存在于人类的心中,它和强迫、控制别人的力量没有关系。它是在意识基础上作出决定的力量。也就是「意识的力量」。

\n

如果我们的心理能够得到力量,我们就会感到舒适和愉快,在人生的旅途上稳扎稳打,循序渐进。 进步带给我们的愉悦感难以言喻。没有什么比成为人生的专家,熟知自己所做的事情,更让人感觉到幸福。我们的心灵越是成熟,就越有可能成为人生的专家。当我们的心智成熟到一定的阶段,我们就会更加谦逊而快乐。

\n
\n","site":{"data":{}},"excerpt":"

成熟 = 自律 +

","more":"

自律

\n

【自律】 : 主动要求自己以积极的态度去承受痛苦,解决问题。

\n

自律的四个原则:延迟满足感、承担责任、忠于事实、保持平衡。:smile:

\n

1 延迟满足感

\n
\n\n人生当中总是绕着困难走。一个揍孩子和对孩子大喊大叫的父母就是不懂得延迟满足感的父母。 应该陪着孩子一起经历困难和痛苦。而父母试图通过家庭暴力的方式,试图将父母本身的责任区隔开。父母没有学会延迟满足感,这个孩子将来长大了也不会。很多人延迟满足感的能力非常糟糕,来自于父母的不自律。当父母不自律的时候,孩子就没法获得足够的爱和照顾。—— 所以这个孩子会忽略自我的价值。有的人喜欢浪费时间,而浪费时间的意思就是,_「我这个人的时间没什么价值」_。\n不会延迟满足感的人,在长大后看到问题会假装没看到,以为等着问题慢慢就会过去,期待问题自行消失。\n
\n
\n\n
\n

2 承担责任

\n
    \n
  1. 神经官能症: 把一切东西都认为是自己的问题。
  2. \n
\n
\n

我如果怎么样就好了。我要是不怎么样就好了。总是充满后悔和内疚。祥林嫂

\n
\n
    \n
  1. 人格失调症:他认为这一切都不是我的问题。他能找到任何一个理由,是因为外在的东西,他就不会责怪自己,他认为都是你们的问题。
  2. \n
\n
\n

「神经官能症」自己活得很痛苦,「人格失调症」让别人活得很痛苦。

\n
\n
\n\n作者提供在冲绳岛上的一个案例,一个军官的妻子,宁愿自杀也不愿意去学自动挡开车的事。\n从某种意义上说,所有的孩子都患有人格失调症,都会本能的逃避责罚。 同时又患有某种神经官能症,把自己承受的痛苦看成是罪有应得。缺少关心的孩子会自惭形秽,认为自己不够可爱,缺点大于优点等等。\n
\n

如果你不能解决问题,那么你自己就会成为问题。我们需要合理的承担责任,既不把责任全部推卸到外部,也不把责任全部揽到自己身上。保持一个合理的平衡。

\n
\n

如果你不能让自己成为人格更加健全,更加成熟的人。你就会把问题带给你的孩子,带给你的家庭。

\n
\n

3 忠于事实

\n

大量的人是生活在自己的幻想当中的。这叫人生地图。他给自己绘制一张人生地图,他认为人生就这样,他已经认定了。这就叫做“不忠于事实”,他只 忠于自己的幻想

\n
\n\n案例:有个人小时候被父母欺骗过,就是父母说话经常不算数。导致他潜意识积累了一个信念:“父母是不可信”的。当他的人生地图绘制出来这么一个坐标,认为父母不可信了自后,他几乎就推论到“人人都不可信”。所以在他一生的成长过程当中,他跟警察发生矛盾,跟领导发生矛盾,跟顾客发生矛盾,跟妻子发生矛盾。案例中最后他唯一信任的是他的两个孩子。妻子把两个孩子带走,所以他人生也崩溃了。他跟作者约定时间不来,然后他说能不能星期六,作者说我的时间是跟别人约过的,不能随便调整。他说:“你不是心理医生吗?为什么不能多关心我一点呢”?他认为作者(心理医生)也是不可信任的人,直接拉黑。\n
\n这种人你很难跟他解释,很难让他面对真正的世界。因为在他心目当中完全是用自己的一套逻辑在解决问题。\n

所以所谓的「心理治疗」,就是鼓励「说真话」的游戏。鼓励大家能够面对事实,能够把自己看到的真相,感受到的真实的感觉,说出来的一个过程。所以没有经过这样的调试,有大量的人是天天活在「幻觉」当中的,就是沉浸在自己的人生地图当中。根本不去看一看,别人的地图是什么样。也根本不去看一看实际的生活当中,事实是什么样的。

\n

移情:人们会把对一个人的感情和经验移植在别人身上。会认为别人也这样。

\n
\n

应该说移情、或者忽略史实,也是一种懒惰的表现。因为去更新地图是件很费力的事情。

\n
\n

4 保持平衡

\n

既要承担责任,也要拒绝承担不该承担的责任。差不多又回到了「中庸」之道。「延迟满足」也不能延迟到无限, 从来不过好日子。既要延迟满足,也要过好当下的生活。要有一个富于弹性的约束机制。好像骑自行车下坡一样,既要享受速度,也要注意刹车。为了待会安全的拐弯,也要捏一捏车闸。
\n生活就是一个不断放弃的过程。必须能够学会放弃一件又一件的事情。包括接受心理治疗就是「放弃」—— 放弃了一个「自己是正常人」 的想法。

\n
\n埃里克 埃里克森列举的人一生当中不断放弃的事情\n
    \n
  1. 首先要放弃「无需对外界要求作出回应」的婴儿状态。
  2. \n
  3. 三四岁的时候有「无所不能的幻觉」,这个要放弃掉。(为何小孩子特别喜欢绿巨人、钢铁侠、金刚狼这样的超级英雄?因为每个人在三四岁的时候都曾经幻想过自己是无所不能的超人。所以这种童话永远有市场。)
  4. \n
  5. 放弃完全占有父亲或者母亲的欲望。放弃童年的依赖感。
  6. \n
  7. 放弃心中被扭曲了的父母形象。(我们曾经以为父母是完美的)放弃。
  8. \n
  9. 青春期的自以为拥有「无穷潜力」的感觉。放弃! I am the King of the World!
  10. \n
  11. 无拘无束的自由
  12. \n
  13. 青年时期的灵巧与活力
  14. \n
  15. 青春时期的性吸引力;长生不老的空想。
  16. \n
  17. 对子女的权威(在子女面前总是说了算的)
  18. \n
  19. 各种各样「暂时性」的权力——退休了,社会给你的权力也没有了。
  20. \n
  21. 身体永远健康——放弃
  22. \n
  23. 最后,自我以及生命本身也要放弃。
  24. \n
\n
\n

\n

【爱】 :为了促进自己和他人心智成熟,而不断拓展自我界限,实现自我完善的一种意愿。

\n
\n

核心观点就是「要看重心智成熟这件事」。心智成熟是发生在你和被爱的那个人之间的,两个人都需要达成心智成熟。
\n不要以为一昧的付出就是爱。爱的要求很高。要达成两个的共同成熟

\n
\n

一个人懂得什么是真正的爱,才能够是一个真正成熟的人。否则你会看到很多人以「爱」的名义在伤害、控制、占有对方。「爱」有以下四个误区:过度关注、坠入情网、精神灌注、自我牺牲。

\n

过度关注

\n\n

坠入情网

\n

坠入情网是欲望。是你体内的激素分泌。因为我们的基因要求我们要生殖,见到异性感觉自己爱上他了。实际上是自己的一种欲望。一段时间后当你的欲望被释放掉了,体内的激素的大潮开始退去的时候,会发现这个人看起啦那么讨厌。坠入情网实际上是「自我界限的短暂崩溃」。除了自我界限的理论,还有以下几个点:

\n\n

精神贯注

\n

爱宠物、爱好这些也不是爱,而是「精神贯注」。就是当你把自己的精神贯注在一个事物上的时候,你以为这只狗“懂你”,其实上是“你投射在了它身上”,你在猜想它的想法。跟真正的爱不一样。为什么呢:

\n\n

有一种精神贯注叫「婴儿之爱」。 很多妈妈只喜欢婴儿期的孩子。等孩子三四岁以后妈妈开始烦了。赶紧推给爷爷奶奶带。反过来呢,母爱很充沛,喜欢别人家的孩子,刚生的小婴儿。 这种不是爱,而是「唯命是从的追求」。 比如二战后美国的「战争新娘」。一开始新娘对丈夫唯命是从,当她们懂得英语,开始融入美国社会以后,矛盾就渐渐开始产生,离婚率开始上升。

\n

以上几种感情我们误以为是爱,其实不是。它们都有共同的特征,就是以「爱」作为幌子,只想满足自己的需要。却从来不把对方的心智成熟当一回事。

\n

自我牺牲

\n

甚至还有人人会发展出来「自我牺牲式的爱」。有个妻子,她老公总是欺骗她,总是有外遇。每次闹完,老公回来道歉,她又开始接受他。五六次以后,妻子去找心理医生谈。心理医生告诉她要想清楚,不能老是这样接受他。有一次这个妻子说,我又原谅他了,这次他是真的改好了。他特别怎么怎么样。结果医生发现这个妻子有“受虐倾向”。有受虐倾向的人,会把「自我牺牲」当作是「爱」。他们觉得只要我能够牺牲、奉献就好。

\n

这些东西也是来自童年的经历,就是他童年当中如果有一个这样的“楷模”,总是以自我牺牲为标榜,总是以为我为别人牺牲了那么多,所以 “你看我多好,多高尚”,他在潜意识当中就会慢慢接受“自我牺牲就是爱”这种想法。

\n
\n **自我界限**:\n小孩子刚出生的时候是没有自我界限的。他在挥动胳膊的时候,觉得整个房间都在动,他与这个世界没有是分割的。到了两三岁发现自己挥动胳膊的时候,房间没有动,甚至他发现自己哭的时候,别人并不饿。 才能慢慢感受到原来自己跟他人是不一样的。到青春期这个人的自我界限已经开始完全封闭起来了。原来这个世界只有我自己,连我的父母都不了解我,我的喜怒哀乐他们根本不知道。所以人们开始陷入深深的孤独。青春期的孩子觉得自己最“孤独”,他觉得没人理解他,我是一个完全独一无二的个体,谁跟我都不一样,他的自我界限完全封闭起来。\n到了谈恋爱。谈恋爱是需要冒风险的,你是需要有勇气打开自我的界限,和另外一个人融为一体的。所以初恋的时候,很多人会有「**圣洁**」的感觉。就是“我打开了”,有一个人竟然“完全懂我”。有一个人可以跟我融为一体,那种水乳交融的感觉,他以为自己找到了「真爱」。因为他的边界在短期的崩溃。当他的自我边界崩溃以后,他感受到了生命的狂喜,那个就是短暂的获得了「爱」的感觉。但是那是假象。`因为那个并不建立在令我和对方人格不断成熟的一个过程当中。他并不是希望达成心智的成熟,他只是自我边界的短暂崩溃`。所以过了一两个月以后,这个自我界限慢慢弥合起来,他发现说“这个人怎么跟我也不一样”?“这个人的想法跟我也不同”。 现在的孩子谈恋爱特别快,有感觉就谈,没感觉了就分。把「感觉」当成了「爱」,事实上感觉只是欲望,是性欲。\n 但不要觉得欲望不是一件好事,无论是欲望,还是依赖,或者过度关注这样的东西,都是`培养爱的基础`。\n正是因为两个人打破了边界,走到一起,双方有可能为对方作出了承诺。接下来为了完成自己的承诺,需要不断的努力,需要有自律性。当你的自律性跟承诺相结合在起来的时候,你的这个短暂的恋爱的感觉爱,会慢慢滋生出真正的爱。 能够带来对方和自己心智共同的成熟。\n
\n
\n

真正的「爱」 :爱是实际行动,是真正的付出。

\n

爱的感觉与精神贯注密不可分。后者是把情感与兴趣贯注在对外的对象上,将其当作属于自己的一部分。精神贯注虽然跟真正的爱容易混淆,但是依然有显著的区别。首先,精神贯注的对象不一定是有生命的事物。因此就不见得会有心灵的感受。其次,对某种事物产生精神贯注的人,未必会重视其心智的成熟。(比如无原则溺爱孩子的父母)第三,精神贯注可能与智慧和责任无关。(酒吧认识一个人,立刻就情有所钟。但没有任何计划性,没有后续责任)。最后,精神贯注随时都有可能消失。今晚还很开心,明天不开心就分手啰。

\n

真正的爱需要投入和奉献,需要付出全部的智慧与力量。要使爱的对象得到成长,就必须付出足够多的努力,不然爱的愿望就会落空。 唯有真正的投入与奉献,才是实现爱的有效方式。真正的爱是自主的选择,无论「爱」的「感觉」是否存在, 都要奉献出情感和智慧。

\n
\n

「爱」的表现

\n
    \n
  1. 倾听。我们真的能够拿出时间来,认真倾听对方的说话。最起码的尊重是通过倾听来展开的,我们要做一个良好的「倾听者」。
  2. \n
  3. 要有心里准备,接受爱的时候,就要准备承担风险。(有人经历过丧失亲人,之后就特别怕建立亲密关系。因为怕失去,「失去」的痛苦吓坏了他。)(爱还要面临冲突的风险。)
  4. \n
  5. 需要尊重对方的独立性。否则就是占有,就是依赖。
  6. \n
\n

信仰

\n

科学也是信仰

\n

科学也是一种信仰。这个世界上上信科学的人比信宗教的人多。人不是生活在一个真实的世界当中的,人是生活在思想家为我们所设定的思想通道当中的。科学家在不断的拓宽我们人类的视线,建立了科学的信仰。 作者认为宗教的信仰在某种程度上可能会导致人的某些情况下的精神分裂。但是在某些情况下也会带来信念,帮助人们解决心理的问题。比喻:倒洗澡水的时候,千万不要把婴儿也倒出去。对待信仰的时候,不能过于简单化。

\n

原罪

\n

作者认为人类的「原罪」就是「懒惰」

\n

自律需要用力,爱需要用力,这个世界天然的方向是「熵增」,屋子一定会变乱。我花力气把屋子整理干净十个「逆熵」的过程,逆熵是需要话费气力的。 人天生喜欢熵增,喜欢懒惰。在伊甸园,其实上帝经常在园子里散步。这两孩子如果能去问一下,这玩意儿能吃吗?人类的命运就改变了。这两个人为什么不去问 一下上帝呢?因为这两孩子「懒惰」,而「懒惰」的背后是「恐惧」。他们担心问了上帝以后受到上帝的责罚。

\n
\n

(天涯:我认为这个解释不对。那个时候的亚当和夏娃没有罪恶感,也从来没有受过责罚,怎么会有这个恐惧呢?而恐惧则是被赶出伊甸园以后人类才有的心智。)

\n
\n

有人不好好学习,是因为就算好好学习了也未必学得好啊。如果好好学了而没有学好,就会面对失去「我不是没能力,只是不愿学而已」这块遮羞布的恐惧。

\n

尽量要做到潜意识和意识「合一」。因为潜意识里面有很多的能量,而我们由于“懒惰”以及“恐惧”不愿意去开发的,不愿意去面对的。

\n

这本书为什么叫【少有人走的路】呢?因为人人都喜欢熵增的方向,都喜欢轻松的方向,人人都喜欢懒惰的方向。喜欢部分什么劲,就得到一切的这种感觉。如果你想要变得成熟,就要费力去做一些逆熵的行为,自律的事,延迟满足的事,用行动表达「爱」的 过程。

\n

两种力量

\n

这个世界始终是由两种力量来统治的,分别是「政治的力量」和「心灵的力量」。

\n

【政治的力量】:以公开或者隐秘的方式,去强迫别人遵循自己的意愿。这种力量既存在于权力之中,也存在于金钱之中。然而他并不属于拥有权力或者金钱的人。归根到底,政治的力量和德行以及智慧无关,最愚蠢最邪恶的人也可能成为地球的统治者。
\n【心灵的力量】:则完全存在于人类的心中,它和强迫、控制别人的力量没有关系。它是在意识基础上作出决定的力量。也就是「意识的力量」。

\n

如果我们的心理能够得到力量,我们就会感到舒适和愉快,在人生的旅途上稳扎稳打,循序渐进。 进步带给我们的愉悦感难以言喻。没有什么比成为人生的专家,熟知自己所做的事情,更让人感觉到幸福。我们的心灵越是成熟,就越有可能成为人生的专家。当我们的心智成熟到一定的阶段,我们就会更加谦逊而快乐。

\n
"},{"title":"JavaScript & Typescript技术摘要","date":"2019-09-14T07:32:15.000Z","urlname":"javascript-typescript-skills","toc":true,"notshow":false,"_content":"\nJavasript 和 Typescript 的重要技巧。\n\n\n\n\n### 零散知识点\n\n- 列举 [Enum](https://www.typescriptlang.org/docs/handbook/enums.html) \n\n### Promise\n\n##### 输出链条\n\n文档 [Promises chaning](https://javascript.info/promise-chaining) \n\n:pencil2: 可以在 `then` 函数里面跑出 结果 `或者` 第二个 `Promise` \n\n##### 等待多个 Promise\n\n```javascript\nlet p1 = promise1\nlet p2 = promise2\nconst promises = Promise.all([p1, p2])\nreturn promises\n```\n\n### 声明以及定义扩展\n\n在 `*.d.ts` 文件中声明类型 \n\n```javascript\ndeclare type Book = {\n\ttitle: string,\n\tcomment?: string\n}\n```\n\n 对 JavaScript 的原型进行扩展, 在一个 TS 文件进行定义和实现\n\n```typescript\n// ...path/common.ts\nexport {} // this will make it module\ndeclare global {\n interface String {\n IsNullOrEmpty():boolean;\n Latex(color?:string):string;\n }\n}\n\nString.prototype.IsNullOrEmpty = function(){\n return this == undefined || this == null || this == \"\"\n}\n```\n\n在需要的地方引用\n\n```typescript\nimport '..path/common';\n\nlet str = \"\"\nconst is_it_empty = str.IsNullOrEmpty()\n```\n\n\n\n### 读取文本\n\n###### Html5 标准按钮\n\n```html\n
\n```\n\nJavascript 读取文本内容并转为数据库 (*使用 sql.js*)\n\n```javascript\nLoadLocalFile(file) {\n const fileurl: File = file.target.files[0];\n const reader = new FileReader();\n reader.onload = () => {\n console.log('read file:', reader.result);\n const buffer = reader.result;\n const Uints = new Uint8Array(buffer as ArrayBuffer);\n const db = new SQL.Database(Uints);\n const nodes = db.exec('SELECT * From node');\n console.log(nodes);\n };\n\n reader.readAsArrayBuffer(fileurl);\n }\n```\n\n###### 使用nix-file-helpers 插件\n\n[文档地址](https://www.npmjs.com/package/ngx-file-helpers)\n\n[演示地址](https://www.npmjs.com/package/ngx-file-helpers)\n\nHtml\n\n```html\n导入案例\n```\n\n代码,读取文件\n\n```javascript\nonFilePicked(file: ReadFile) {\n const Uints = new Uint8Array(file.content as ArrayBuffer);\n const db = new SQL.Database(Uints);\n const nodes = db.exec('SELECT * From node');\n console.log(nodes);\n }\n```\n\n\n\n\n\n### 测试\n\n###### 引用第三方js文件\n\n在 **angular.json** 文件的 `test-->scripts` 中添加需要引用的文件。","source":"_posts/IT/Code/Javascript技术摘要.md","raw":"---\ntitle: JavaScript & Typescript技术摘要\ndate: 2019-09-14 09:32:15\nurlname: javascript-typescript-skills\ntoc: true\ntags: [Hexo]\ncategories: [IT, Code]\nnotshow: false\n---\n\nJavasript 和 Typescript 的重要技巧。\n\n\n\n\n### 零散知识点\n\n- 列举 [Enum](https://www.typescriptlang.org/docs/handbook/enums.html) \n\n### Promise\n\n##### 输出链条\n\n文档 [Promises chaning](https://javascript.info/promise-chaining) \n\n:pencil2: 可以在 `then` 函数里面跑出 结果 `或者` 第二个 `Promise` \n\n##### 等待多个 Promise\n\n```javascript\nlet p1 = promise1\nlet p2 = promise2\nconst promises = Promise.all([p1, p2])\nreturn promises\n```\n\n### 声明以及定义扩展\n\n在 `*.d.ts` 文件中声明类型 \n\n```javascript\ndeclare type Book = {\n\ttitle: string,\n\tcomment?: string\n}\n```\n\n 对 JavaScript 的原型进行扩展, 在一个 TS 文件进行定义和实现\n\n```typescript\n// ...path/common.ts\nexport {} // this will make it module\ndeclare global {\n interface String {\n IsNullOrEmpty():boolean;\n Latex(color?:string):string;\n }\n}\n\nString.prototype.IsNullOrEmpty = function(){\n return this == undefined || this == null || this == \"\"\n}\n```\n\n在需要的地方引用\n\n```typescript\nimport '..path/common';\n\nlet str = \"\"\nconst is_it_empty = str.IsNullOrEmpty()\n```\n\n\n\n### 读取文本\n\n###### Html5 标准按钮\n\n```html\n
\n```\n\nJavascript 读取文本内容并转为数据库 (*使用 sql.js*)\n\n```javascript\nLoadLocalFile(file) {\n const fileurl: File = file.target.files[0];\n const reader = new FileReader();\n reader.onload = () => {\n console.log('read file:', reader.result);\n const buffer = reader.result;\n const Uints = new Uint8Array(buffer as ArrayBuffer);\n const db = new SQL.Database(Uints);\n const nodes = db.exec('SELECT * From node');\n console.log(nodes);\n };\n\n reader.readAsArrayBuffer(fileurl);\n }\n```\n\n###### 使用nix-file-helpers 插件\n\n[文档地址](https://www.npmjs.com/package/ngx-file-helpers)\n\n[演示地址](https://www.npmjs.com/package/ngx-file-helpers)\n\nHtml\n\n```html\n导入案例\n```\n\n代码,读取文件\n\n```javascript\nonFilePicked(file: ReadFile) {\n const Uints = new Uint8Array(file.content as ArrayBuffer);\n const db = new SQL.Database(Uints);\n const nodes = db.exec('SELECT * From node');\n console.log(nodes);\n }\n```\n\n\n\n\n\n### 测试\n\n###### 引用第三方js文件\n\n在 **angular.json** 文件的 `test-->scripts` 中添加需要引用的文件。","slug":"IT/Code/Javascript技术摘要","published":1,"updated":"2020-05-11T03:54:03.957Z","_id":"cka1y597r00154huu5w41rgul","comments":1,"layout":"post","photos":[],"link":"","content":"

Javasript 和 Typescript 的重要技巧。

\n\n

零散知识点

\n\n

Promise

\n
输出链条
\n

文档 Promises chaning

\n

:pencil2: 可以在 then 函数里面跑出 结果 或者 第二个 Promise

\n
等待多个 Promise
\n
1
2
3
4
let p1 = promise1
let p2 = promise2
const promises = Promise.all([p1, p2])
return promises
\n

声明以及定义扩展

\n

*.d.ts 文件中声明类型

\n
1
2
3
4
declare type Book = {
\ttitle: string,
\tcomment?: string
}
\n

对 JavaScript 的原型进行扩展, 在一个 TS 文件进行定义和实现

\n
1
2
3
4
5
6
7
8
9
10
11
12
// ...path/common.ts
export {} // this will make it module
declare global {
interface String {
IsNullOrEmpty():boolean;
Latex(color?:string):string;
}
}

String.prototype.IsNullOrEmpty = function(){
return this == undefined || this == null || this == \"\"
}
\n

在需要的地方引用

\n
1
2
3
4
import '..path/common';

let str = \"\"
const is_it_empty = str.IsNullOrEmpty()
\n

读取文本

\n
Html5 标准按钮
\n
1
<div type='file' (change)='LoadLocalFile($event)'></div>
\n

Javascript 读取文本内容并转为数据库 (使用 sql.js)

\n
1
2
3
4
5
6
7
8
9
10
11
12
13
14
LoadLocalFile(file) {
const fileurl: File = file.target.files[0];
const reader = new FileReader();
reader.onload = () => {
console.log('read file:', reader.result);
const buffer = reader.result;
const Uints = new Uint8Array(buffer as ArrayBuffer);
const db = new SQL.Database(Uints);
const nodes = db.exec('SELECT * From node');
console.log(nodes);
};

reader.readAsArrayBuffer(fileurl);
}
\n
使用nix-file-helpers 插件
\n

文档地址

\n

演示地址

\n

Html

\n
1
2
3
4
5
<ion-button   ngxFilePicker #filePicker=\"ngxFilePicker\" 
[readMode]=\"readMode\"
(readStart)=\"onReadStart($event)\"
(filePick)=\"onFilePicked($event)\"
(readEnd)=\"onReadEnd($event)\">导入案例</ion-button>
\n

代码,读取文件

\n
1
2
3
4
5
6
onFilePicked(file: ReadFile) {
const Uints = new Uint8Array(file.content as ArrayBuffer);
const db = new SQL.Database(Uints);
const nodes = db.exec('SELECT * From node');
console.log(nodes);
}
\n

测试

\n
引用第三方js文件
\n

angular.json 文件的 test-->scripts 中添加需要引用的文件。

\n","site":{"data":{}},"excerpt":"

Javasript 和 Typescript 的重要技巧。

","more":"

零散知识点

\n\n

Promise

\n
输出链条
\n

文档 Promises chaning

\n

:pencil2: 可以在 then 函数里面跑出 结果 或者 第二个 Promise

\n
等待多个 Promise
\n\n

声明以及定义扩展

\n

*.d.ts 文件中声明类型

\n\n

对 JavaScript 的原型进行扩展, 在一个 TS 文件进行定义和实现

\n\n

在需要的地方引用

\n\n

读取文本

\n
Html5 标准按钮
\n\n

Javascript 读取文本内容并转为数据库 (使用 sql.js)

\n\n
使用nix-file-helpers 插件
\n

文档地址

\n

演示地址

\n

Html

\n\n

代码,读取文件

\n\n

测试

\n
引用第三方js文件
\n

angular.json 文件的 test-->scripts 中添加需要引用的文件。

"},{"title":"Mac使用标签","date":"2019-07-22T16:58:50.000Z","urlname":"mac-using-tags","toc":true,"notshow":true,"_content":"## 使用标签\n在 Mac 上,执行以下任一项操作:\n\n- 给打开的文件添加标签:将鼠标指针悬停在文稿标题右侧,点按箭头,在“标签”栏中点按,然后输入新标签,或者从列表中选取一个标签。\n- 存储新文件时添加标签:点按“文件”>“存储”。在“存储”对话框中,在“标签”栏中点按,然后输入新标签,或者从列表中选取一个标签。\n- 给桌面上或“访达”中的文件添加标签:选择项目,然后打开“文件”菜单。也可以按住 Control 键点按该项目,或用双指轻点它。在“标签”下方选取颜色![img](https://www.macdaxue.com/wp-content/uploads/2018/10/icon_blue_circle.png),或点按“标签”以从更多标签中进行选择或输入新标签。在“访达”窗口中,也可以选择该项目,点按“标签”按钮 ![img](https://www.macdaxue.com/wp-content/uploads/2018/10/icon_tag.png),然后输入新标签,或从列表中选取一个标签。\n\n## 查找含有标签的项目\n\n1. 在 Mac 上,点按程序坞中的“访达”图标 ![img](https://www.macdaxue.com/wp-content/uploads/2018/10/icon_finder.png)以打开“访达”窗口。\n2. 请执行以下一项操作:\n - 搜索标签:在搜索栏中输入标签颜色或名称,然后从建议中选择该标签。\n - 在边栏中选择标签:若要查看带有某个标签的所有项目,请在“访达”边栏中点按标签![img](https://www.macdaxue.com/wp-content/uploads/2018/10/icon_blue_circle.png)。若要更改在边栏中看到的项目,请选取“访达”>“偏好设置”,点按“标签”,然后选择想要查看的标签。\n - 按标签将项目分组: 点按“分组”按钮![img](https://www.macdaxue.com/wp-content/uploads/2018/10/icon_group.png),然后选取“标签”。\n - 按标签排序项目:在任何显示方式下,选取“显示”>“查看显示选项”,点按“排序方式”弹出式菜单,然后选取“标签”。在“列表显示”下,选择“标签”复选框以显示分栏,将指针移到“标签”分栏上方,然后点按。再次点按分栏名称来倒序排列。\n\n## 移除标签\n\n在 Mac 上,请执行以下一项操作:\n\n- 从项目中移除标签:按住 Control 键点按项目或使用双指轻点项目,然后点按“标签”。选择您想要移除的标签,然后按下 Delete 键。\n- 从 Mac 中移除标签:在“访达”中,选取“访达”>“偏好设置”,然后点按“标签”。选择您想要移除的标签,然后点按移除按钮——。\n\n## 编辑标签\n\n1. 在 Mac 上的“访达”![img](https://www.macdaxue.com/wp-content/uploads/2018/10/icon_finder.png)中,选取“访达”>“偏好设置”,然后点按“标签”。\n2. 请执行以下一项操作:\n - 在“访达”边栏中查看标签:选择标签右侧的蓝色复选框。\n - 更改标签颜色:点按标签![img](https://www.macdaxue.com/wp-content/uploads/2018/10/icon_blue_circle.png)\n - 旁边的颜色,然后选取新的颜色。\n - 更改标签名称:点按标签,点按标签名称,然后输入新名称。\n - 创建新标签:点按添加按钮 ![img](https://www.macdaxue.com/wp-content/uploads/2018/06/IL_AddiOS.png)。\n - 删除标签:选择标签,然后点按移除按钮 ——。\n - 将标签添加到[快捷键](https://www.macdaxue.com/os-x-key/)菜单中:在列表中选择标签,然后将它拖到您想要在窗口底部的个人收藏部分中替换的标签上方。当您按下 Control 键点按文件时,在出现的[快捷键](https://www.macdaxue.com/os-x-key/)菜单中可至多有七个标签。\n - 从快捷键菜单中移除标签:将标签拖出“个人收藏标签”部分,直到看到移除符号![img](https://www.macdaxue.com/wp-content/uploads/2018/10/icon_x.png)。","source":"_posts/IT/Mac/Mac使用标签.md","raw":"---\ntitle: Mac使用标签\ndate: 2019-07-22 18:58:50\nurlname: mac-using-tags\ntoc: true\ntags: [Mac]\ncategories: [IT, Mac]\nnotshow: true\n\n---\n## 使用标签\n在 Mac 上,执行以下任一项操作:\n\n- 给打开的文件添加标签:将鼠标指针悬停在文稿标题右侧,点按箭头,在“标签”栏中点按,然后输入新标签,或者从列表中选取一个标签。\n- 存储新文件时添加标签:点按“文件”>“存储”。在“存储”对话框中,在“标签”栏中点按,然后输入新标签,或者从列表中选取一个标签。\n- 给桌面上或“访达”中的文件添加标签:选择项目,然后打开“文件”菜单。也可以按住 Control 键点按该项目,或用双指轻点它。在“标签”下方选取颜色![img](https://www.macdaxue.com/wp-content/uploads/2018/10/icon_blue_circle.png),或点按“标签”以从更多标签中进行选择或输入新标签。在“访达”窗口中,也可以选择该项目,点按“标签”按钮 ![img](https://www.macdaxue.com/wp-content/uploads/2018/10/icon_tag.png),然后输入新标签,或从列表中选取一个标签。\n\n## 查找含有标签的项目\n\n1. 在 Mac 上,点按程序坞中的“访达”图标 ![img](https://www.macdaxue.com/wp-content/uploads/2018/10/icon_finder.png)以打开“访达”窗口。\n2. 请执行以下一项操作:\n - 搜索标签:在搜索栏中输入标签颜色或名称,然后从建议中选择该标签。\n - 在边栏中选择标签:若要查看带有某个标签的所有项目,请在“访达”边栏中点按标签![img](https://www.macdaxue.com/wp-content/uploads/2018/10/icon_blue_circle.png)。若要更改在边栏中看到的项目,请选取“访达”>“偏好设置”,点按“标签”,然后选择想要查看的标签。\n - 按标签将项目分组: 点按“分组”按钮![img](https://www.macdaxue.com/wp-content/uploads/2018/10/icon_group.png),然后选取“标签”。\n - 按标签排序项目:在任何显示方式下,选取“显示”>“查看显示选项”,点按“排序方式”弹出式菜单,然后选取“标签”。在“列表显示”下,选择“标签”复选框以显示分栏,将指针移到“标签”分栏上方,然后点按。再次点按分栏名称来倒序排列。\n\n## 移除标签\n\n在 Mac 上,请执行以下一项操作:\n\n- 从项目中移除标签:按住 Control 键点按项目或使用双指轻点项目,然后点按“标签”。选择您想要移除的标签,然后按下 Delete 键。\n- 从 Mac 中移除标签:在“访达”中,选取“访达”>“偏好设置”,然后点按“标签”。选择您想要移除的标签,然后点按移除按钮——。\n\n## 编辑标签\n\n1. 在 Mac 上的“访达”![img](https://www.macdaxue.com/wp-content/uploads/2018/10/icon_finder.png)中,选取“访达”>“偏好设置”,然后点按“标签”。\n2. 请执行以下一项操作:\n - 在“访达”边栏中查看标签:选择标签右侧的蓝色复选框。\n - 更改标签颜色:点按标签![img](https://www.macdaxue.com/wp-content/uploads/2018/10/icon_blue_circle.png)\n - 旁边的颜色,然后选取新的颜色。\n - 更改标签名称:点按标签,点按标签名称,然后输入新名称。\n - 创建新标签:点按添加按钮 ![img](https://www.macdaxue.com/wp-content/uploads/2018/06/IL_AddiOS.png)。\n - 删除标签:选择标签,然后点按移除按钮 ——。\n - 将标签添加到[快捷键](https://www.macdaxue.com/os-x-key/)菜单中:在列表中选择标签,然后将它拖到您想要在窗口底部的个人收藏部分中替换的标签上方。当您按下 Control 键点按文件时,在出现的[快捷键](https://www.macdaxue.com/os-x-key/)菜单中可至多有七个标签。\n - 从快捷键菜单中移除标签:将标签拖出“个人收藏标签”部分,直到看到移除符号![img](https://www.macdaxue.com/wp-content/uploads/2018/10/icon_x.png)。","slug":"IT/Mac/Mac使用标签","published":1,"updated":"2019-07-31T03:51:34.000Z","_id":"cka1y597t00164huuyti606sh","comments":1,"layout":"post","photos":[],"link":"","content":"

使用标签

\n

在 Mac 上,执行以下任一项操作:

\n\n

查找含有标签的项目

\n
    \n
  1. 在 Mac 上,点按程序坞中的“访达”图标 \"img\"以打开“访达”窗口。
  2. \n
  3. 请执行以下一项操作:\n\n
  4. \n
\n

移除标签

\n

在 Mac 上,请执行以下一项操作:

\n\n

编辑标签

\n
    \n
  1. 在 Mac 上的“访达”\"img\"中,选取“访达”>“偏好设置”,然后点按“标签”。
  2. \n
  3. 请执行以下一项操作:\n\n
  4. \n
\n","site":{"data":{}},"excerpt":"","more":"

使用标签

\n

在 Mac 上,执行以下任一项操作:

\n\n

查找含有标签的项目

\n
    \n
  1. 在 Mac 上,点按程序坞中的“访达”图标 \"img\"以打开“访达”窗口。
  2. \n
  3. 请执行以下一项操作:\n\n
  4. \n
\n

移除标签

\n

在 Mac 上,请执行以下一项操作:

\n\n

编辑标签

\n
    \n
  1. 在 Mac 上的“访达”\"img\"中,选取“访达”>“偏好设置”,然后点按“标签”。
  2. \n
  3. 请执行以下一项操作:\n\n
  4. \n
\n"},{"title":"Gitbook攻略","date":"2019-08-14T21:02:14.000Z","urlname":"gitbook_with_typora_gh-pages","toc":true,"_content":"\n本文为你介绍如何使用利用 **Typora + gitbook-cli + Github Pages** 书写Gitbook. 在本地用 Typora 书写 md 文件, 用 gitbook-cli 编译, 最后发布到 Github Pages 上.\n\n\n\n\n\n# 安装\n\n前提是已经安装了Node, 直接用npm包管理工具安装:\n\n```sh\nsudo npm install -g gitbook-cli\ngitbook -V # 注意是大写V\n```\n\n> CLI version: 2.3.2\n> GitBook version: 3.2.3\n\n# 新建书籍\n\n1. 为新书建立一个根目录 `mkdir pytho_finance`\n\n2. 在该目录下执行(命令行下):`gitbook init`,之后会在该目录下产生2个文件,分别是README.md(书籍的介绍)和SUMMARY.md(书籍的目录结构)。\n\n![gitbook目录的写法](https://github.com/maiernte/img/raw/master/Tech/gitbook目录的写法.png)\n\n3. 按照上图格式填写目录和文件, 然后再次执行 `gitbook init` , GitBook 会查找 SUMMARY.md 文件中描述的目录和文件,如果没有则会将其创建. \n\n4. 然后就可以预览书籍了 `gitbook serve`. 执行命令后会对 Markdown 格式的文档进行转换,默认转换为 html 格式,提示Serving book on http://localhost:4000,打开网址即可查看.\n5. 构建书籍\n\n```sh\ngitbook build\n```\n\n默认将生成的静态网站输出到 _book 目录。实际上,这一步也包含在 gitbook serve 里面,因为它们是 HTML,所以 GitBook 通过 Node.js 给你提供服务了。\n\nbuild 命令可以指定路径, 或者指定端口, 或者生产 pdf , epub, mobi 等格式. [具体参考文章](https://www.cnblogs.com/eveblog/p/10003217.html). \n\n# 发布到Github Pages\n\n```sh\ngit init\ngit remote add origin https://github.com/maiernte/gitbook_python_finance.git\ngit add .\ngit commit -m \"new book\"\ngit push -u origin master # 将源代码推送到master\n```\n\n在GitHub的仓库中新添一个 **gh-pages** 的Branch. \n\n```sh\nmkdir new_fold\ncd new_fold\nrm -rf . # 删除这个目录下所有文件, 注意那 .git 文件夹不能删除\n\n# 在源代码目录中,也就是md文件的目录\ngitbook build \n\n# 将会产生一个 _book 目录\n# 添加忽略, 以免下次推送的时候 _book 目录被推送.\necho \"*~\" > .gitignore\necho \"_book\" >> .gitignore\necho \"/node_modules\" >> .gitignore\n\ncp -r _book/* path_to/new_fold\n```\n\n:pen: 忽略文件夹,windows下的测试是 `/node_modules`, 不加双引号。\n\n进入新目录, 推送编译后的html 和 js 文件到 gh-pages 的分支中去.\n\n```sh\ncd path_to/new_fold\ngit add .\ngit commit -m \"to gh-pages\"\ngit push -u origin gh-pages\n```\n\n如此实现了将源代码保存到master, 将静态网站推送到gh-pages, 一个仓库搞定! 在浏览器输入仓库地址, 就可以看到自己的Gitbook. 比如我新书地址\n\n> https://maiernte.github.io/gitbook_python_finance/\n\n\n\n## 更新和维护\n\n因为master 和 gh-pages 上存放的是不同的文档,所以拉取的时候也有指定 branch\n\n```sh\n# 拉取源代码\ngit clone https://github.com/maiernte/gitbook_python_finance.git --branch master new_fold\n\n# 拉取静态网站\ngit clone https://github.com/maiernte/gitbook_python_finance.git --branch gh-pages new_fold\n```\n\n\n\n# 个性化配置\n\n在项目的根目录上添加一个 `book.json` 文件, 用来更全面的配置项目. 比如头文件, 插件等等.\n\n```json\n{\n \"title\": \"使用Python处理金融数据\",\n \"author\": \"鎏金天涯 \",\n \"description\": \"使用Python处理金融数据的各种技术\",\n \"generator\": \"site\",\n \"plugins\": [\"mathjax\"],\n \"links\": {\n \"sidebar\": {\n \"鎏金天涯个人博客\": \"http://goldentianya.pub\"\n }\n }\n}\n```\n\n## 数学插件\n\n在上述文件添加了 `\"plugins\": [\"mathjax\"]`, 并执行命令\n\n```sh\ngitbook install ./ # 会添加一堆 node_modules 包\n```\n\n更详细的配置请参阅[官方文档](https://chrisniael.gitbooks.io/gitbook-documentation/content/).\n\n## 目录插件\n\n[项目地址和文档](https://www.npmjs.com/package/gitbook-plugin-page-toc)\n\n将 ***book.json*** 文件修改为 `\"plugins\": [\"mathjax\", \"page-toc\" ], ​` 每一页的目录就会出现在右上角。\n\n\n\n# 编译错误列表\n\n版本\n\n```\nCLI version: 2.3.2\nGitBook version: 3.2.3\n```\n\n## sharing 插件出错\n\n添加了 `page-toc` 插件后,`gitbook serve` 的时候总是出现错误。就算把文章改回原来的样子也无补于事。\n\n> info: 7 plugins are installed\n> info: loading plugin \"livereload\"... OK\n> info: loading plugin \"highlight\"... OK\n> info: loading plugin \"search\"... OK\n> info: loading plugin \"lunr\"... OK\n> info: loading plugin \"sharing\"... OK\n> info: loading plugin \"fontsettings\"... OK\n> info: loading plugin \"theme-default\"... OK\n> info: found 1 pages\n> info: found 0 asset files\n>\n> Error: ENOENT: no such file or directory, stat 'D:\\f040371\\git_book\\plattform_finance\\_book\\gitbook\\gitbook-plugin-sharing\\buttons.js'\n\n### 解决方法\n\n修改 `C:\\Users\\f040371\\.gitbook\\versions\\3.2.3\\lib\\output\\website\\copyPluginAssets.js` 文件中的 112 行\n\n![copyPluginAssets.js](https://images2018.cnblogs.com/blog/623717/201808/623717-20180815170921683-2030924288.png)\n\n将 `confirm: true` 改为 `confirm: false`\n\n\n\n参考文章:\n\n---\n\n[使用GitBook和Typora写知识库](https://beihaionline.com/11523.html)\n\n[gitbook+git+typora 的使用过程](https://www.cnblogs.com/eveblog/p/10003217.html)\n\n[GitBook + Typora + Git 编写电子文档](https://www.jianshu.com/p/02caaaaa97ef)\n\n[Gitbook 发布到 Github Pages](http://www.chengweiyang.cn/gitbook/github-pages/README.html)\n\n","source":"_posts/IT/Tools/Gitbook攻略.md","raw":"---\ntitle: Gitbook攻略\ndate: 2019-08-14 23:02:14\nurlname: gitbook_with_typora_gh-pages\ntoc: true\ntags: [工具]\ncategories: [IT, Tools]\n\n---\n\n本文为你介绍如何使用利用 **Typora + gitbook-cli + Github Pages** 书写Gitbook. 在本地用 Typora 书写 md 文件, 用 gitbook-cli 编译, 最后发布到 Github Pages 上.\n\n\n\n\n\n# 安装\n\n前提是已经安装了Node, 直接用npm包管理工具安装:\n\n```sh\nsudo npm install -g gitbook-cli\ngitbook -V # 注意是大写V\n```\n\n> CLI version: 2.3.2\n> GitBook version: 3.2.3\n\n# 新建书籍\n\n1. 为新书建立一个根目录 `mkdir pytho_finance`\n\n2. 在该目录下执行(命令行下):`gitbook init`,之后会在该目录下产生2个文件,分别是README.md(书籍的介绍)和SUMMARY.md(书籍的目录结构)。\n\n![gitbook目录的写法](https://github.com/maiernte/img/raw/master/Tech/gitbook目录的写法.png)\n\n3. 按照上图格式填写目录和文件, 然后再次执行 `gitbook init` , GitBook 会查找 SUMMARY.md 文件中描述的目录和文件,如果没有则会将其创建. \n\n4. 然后就可以预览书籍了 `gitbook serve`. 执行命令后会对 Markdown 格式的文档进行转换,默认转换为 html 格式,提示Serving book on http://localhost:4000,打开网址即可查看.\n5. 构建书籍\n\n```sh\ngitbook build\n```\n\n默认将生成的静态网站输出到 _book 目录。实际上,这一步也包含在 gitbook serve 里面,因为它们是 HTML,所以 GitBook 通过 Node.js 给你提供服务了。\n\nbuild 命令可以指定路径, 或者指定端口, 或者生产 pdf , epub, mobi 等格式. [具体参考文章](https://www.cnblogs.com/eveblog/p/10003217.html). \n\n# 发布到Github Pages\n\n```sh\ngit init\ngit remote add origin https://github.com/maiernte/gitbook_python_finance.git\ngit add .\ngit commit -m \"new book\"\ngit push -u origin master # 将源代码推送到master\n```\n\n在GitHub的仓库中新添一个 **gh-pages** 的Branch. \n\n```sh\nmkdir new_fold\ncd new_fold\nrm -rf . # 删除这个目录下所有文件, 注意那 .git 文件夹不能删除\n\n# 在源代码目录中,也就是md文件的目录\ngitbook build \n\n# 将会产生一个 _book 目录\n# 添加忽略, 以免下次推送的时候 _book 目录被推送.\necho \"*~\" > .gitignore\necho \"_book\" >> .gitignore\necho \"/node_modules\" >> .gitignore\n\ncp -r _book/* path_to/new_fold\n```\n\n:pen: 忽略文件夹,windows下的测试是 `/node_modules`, 不加双引号。\n\n进入新目录, 推送编译后的html 和 js 文件到 gh-pages 的分支中去.\n\n```sh\ncd path_to/new_fold\ngit add .\ngit commit -m \"to gh-pages\"\ngit push -u origin gh-pages\n```\n\n如此实现了将源代码保存到master, 将静态网站推送到gh-pages, 一个仓库搞定! 在浏览器输入仓库地址, 就可以看到自己的Gitbook. 比如我新书地址\n\n> https://maiernte.github.io/gitbook_python_finance/\n\n\n\n## 更新和维护\n\n因为master 和 gh-pages 上存放的是不同的文档,所以拉取的时候也有指定 branch\n\n```sh\n# 拉取源代码\ngit clone https://github.com/maiernte/gitbook_python_finance.git --branch master new_fold\n\n# 拉取静态网站\ngit clone https://github.com/maiernte/gitbook_python_finance.git --branch gh-pages new_fold\n```\n\n\n\n# 个性化配置\n\n在项目的根目录上添加一个 `book.json` 文件, 用来更全面的配置项目. 比如头文件, 插件等等.\n\n```json\n{\n \"title\": \"使用Python处理金融数据\",\n \"author\": \"鎏金天涯 \",\n \"description\": \"使用Python处理金融数据的各种技术\",\n \"generator\": \"site\",\n \"plugins\": [\"mathjax\"],\n \"links\": {\n \"sidebar\": {\n \"鎏金天涯个人博客\": \"http://goldentianya.pub\"\n }\n }\n}\n```\n\n## 数学插件\n\n在上述文件添加了 `\"plugins\": [\"mathjax\"]`, 并执行命令\n\n```sh\ngitbook install ./ # 会添加一堆 node_modules 包\n```\n\n更详细的配置请参阅[官方文档](https://chrisniael.gitbooks.io/gitbook-documentation/content/).\n\n## 目录插件\n\n[项目地址和文档](https://www.npmjs.com/package/gitbook-plugin-page-toc)\n\n将 ***book.json*** 文件修改为 `\"plugins\": [\"mathjax\", \"page-toc\" ], ​` 每一页的目录就会出现在右上角。\n\n\n\n# 编译错误列表\n\n版本\n\n```\nCLI version: 2.3.2\nGitBook version: 3.2.3\n```\n\n## sharing 插件出错\n\n添加了 `page-toc` 插件后,`gitbook serve` 的时候总是出现错误。就算把文章改回原来的样子也无补于事。\n\n> info: 7 plugins are installed\n> info: loading plugin \"livereload\"... OK\n> info: loading plugin \"highlight\"... OK\n> info: loading plugin \"search\"... OK\n> info: loading plugin \"lunr\"... OK\n> info: loading plugin \"sharing\"... OK\n> info: loading plugin \"fontsettings\"... OK\n> info: loading plugin \"theme-default\"... OK\n> info: found 1 pages\n> info: found 0 asset files\n>\n> Error: ENOENT: no such file or directory, stat 'D:\\f040371\\git_book\\plattform_finance\\_book\\gitbook\\gitbook-plugin-sharing\\buttons.js'\n\n### 解决方法\n\n修改 `C:\\Users\\f040371\\.gitbook\\versions\\3.2.3\\lib\\output\\website\\copyPluginAssets.js` 文件中的 112 行\n\n![copyPluginAssets.js](https://images2018.cnblogs.com/blog/623717/201808/623717-20180815170921683-2030924288.png)\n\n将 `confirm: true` 改为 `confirm: false`\n\n\n\n参考文章:\n\n---\n\n[使用GitBook和Typora写知识库](https://beihaionline.com/11523.html)\n\n[gitbook+git+typora 的使用过程](https://www.cnblogs.com/eveblog/p/10003217.html)\n\n[GitBook + Typora + Git 编写电子文档](https://www.jianshu.com/p/02caaaaa97ef)\n\n[Gitbook 发布到 Github Pages](http://www.chengweiyang.cn/gitbook/github-pages/README.html)\n\n","slug":"IT/Tools/Gitbook攻略","published":1,"updated":"2019-08-15T09:46:18.000Z","_id":"cka1y597u001a4huuspnhsflr","comments":1,"layout":"post","photos":[],"link":"","content":"

本文为你介绍如何使用利用 Typora + gitbook-cli + Github Pages 书写Gitbook. 在本地用 Typora 书写 md 文件, 用 gitbook-cli 编译, 最后发布到 Github Pages 上.

\n\n

安装

\n

前提是已经安装了Node, 直接用npm包管理工具安装:

\n
1
2
sudo npm install -g gitbook-cli
gitbook -V # 注意是大写V
\n
\n

CLI version: 2.3.2
\nGitBook version: 3.2.3

\n
\n

新建书籍

\n
    \n
  1. \n

    为新书建立一个根目录 mkdir pytho_finance

    \n
  2. \n
  3. \n

    在该目录下执行(命令行下):gitbook init,之后会在该目录下产生2个文件,分别是README.md(书籍的介绍)和SUMMARY.md(书籍的目录结构)。

    \n
  4. \n
\n

\"gitbook目录的写法\"

\n
    \n
  1. \n

    按照上图格式填写目录和文件, 然后再次执行 gitbook init , GitBook 会查找 SUMMARY.md 文件中描述的目录和文件,如果没有则会将其创建.

    \n
  2. \n
  3. \n

    然后就可以预览书籍了 gitbook serve. 执行命令后会对 Markdown 格式的文档进行转换,默认转换为 html 格式,提示Serving book on http://localhost:4000,打开网址即可查看.

    \n
  4. \n
  5. \n

    构建书籍

    \n
  6. \n
\n
1
gitbook build
\n

默认将生成的静态网站输出到 _book 目录。实际上,这一步也包含在 gitbook serve 里面,因为它们是 HTML,所以 GitBook 通过 Node.js 给你提供服务了。

\n

build 命令可以指定路径, 或者指定端口, 或者生产 pdf , epub, mobi 等格式. 具体参考文章.

\n

发布到Github Pages

\n
1
2
3
4
5
git init
git remote add origin https://github.com/maiernte/gitbook_python_finance.git
git add .
git commit -m \"new book\"
git push -u origin master # 将源代码推送到master
\n

在GitHub的仓库中新添一个 gh-pages 的Branch.

\n
1
2
3
4
5
6
7
8
9
10
11
12
13
14
mkdir new_fold
cd new_fold
rm -rf . # 删除这个目录下所有文件, 注意那 .git 文件夹不能删除

# 在源代码目录中,也就是md文件的目录
gitbook build

# 将会产生一个 _book 目录
# 添加忽略, 以免下次推送的时候 _book 目录被推送.
echo \"*~\" > .gitignore
echo \"_book\" >> .gitignore
echo \"/node_modules\" >> .gitignore

cp -r _book/* path_to/new_fold
\n

:pen: 忽略文件夹,windows下的测试是 /node_modules, 不加双引号。

\n

进入新目录, 推送编译后的html 和 js 文件到 gh-pages 的分支中去.

\n
1
2
3
4
cd path_to/new_fold
git add .
git commit -m \"to gh-pages\"
git push -u origin gh-pages
\n

如此实现了将源代码保存到master, 将静态网站推送到gh-pages, 一个仓库搞定! 在浏览器输入仓库地址, 就可以看到自己的Gitbook. 比如我新书地址

\n
\n

https://maiernte.github.io/gitbook_python_finance/

\n
\n

更新和维护

\n

因为master 和 gh-pages 上存放的是不同的文档,所以拉取的时候也有指定 branch

\n
1
2
3
4
5
# 拉取源代码
git clone https://github.com/maiernte/gitbook_python_finance.git --branch master new_fold

# 拉取静态网站
git clone https://github.com/maiernte/gitbook_python_finance.git --branch gh-pages new_fold
\n

个性化配置

\n

在项目的根目录上添加一个 book.json 文件, 用来更全面的配置项目. 比如头文件, 插件等等.

\n
1
2
3
4
5
6
7
8
9
10
11
12
{
\"title\": \"使用Python处理金融数据\",
\"author\": \"鎏金天涯 <mai.yongfeng@gmail.com>\",
\"description\": \"使用Python处理金融数据的各种技术\",
\"generator\": \"site\",
\"plugins\": [\"mathjax\"],
\"links\": {
\"sidebar\": {
\"鎏金天涯个人博客\": \"http://goldentianya.pub\"
}
}
}
\n

数学插件

\n

在上述文件添加了 "plugins": ["mathjax"], 并执行命令

\n
1
gitbook install ./ # 会添加一堆 node_modules 包
\n

更详细的配置请参阅官方文档.

\n

目录插件

\n

项目地址和文档

\n

book.json 文件修改为 "plugins": ["mathjax", "page-toc" ], ​ 每一页的目录就会出现在右上角。

\n

编译错误列表

\n

版本

\n
1
2
CLI version: 2.3.2
GitBook version: 3.2.3
\n

sharing 插件出错

\n

添加了 page-toc 插件后,gitbook serve 的时候总是出现错误。就算把文章改回原来的样子也无补于事。

\n
\n

info: 7 plugins are installed
\ninfo: loading plugin “livereload”… OK
\ninfo: loading plugin “highlight”… OK
\ninfo: loading plugin “search”… OK
\ninfo: loading plugin “lunr”… OK
\ninfo: loading plugin “sharing”… OK
\ninfo: loading plugin “fontsettings”… OK
\ninfo: loading plugin “theme-default”… OK
\ninfo: found 1 pages
\ninfo: found 0 asset files

\n

Error: ENOENT: no such file or directory, stat ‘D:\\f040371\\git_book\\plattform_finance_book\\gitbook\\gitbook-plugin-sharing\\buttons.js’

\n
\n

解决方法

\n

修改 C:\\Users\\f040371\\.gitbook\\versions\\3.2.3\\lib\\output\\website\\copyPluginAssets.js 文件中的 112 行

\n

\"copyPluginAssets.js\"

\n

confirm: true 改为 confirm: false

\n

参考文章:

\n
\n

使用GitBook和Typora写知识库

\n

gitbook+git+typora 的使用过程

\n

GitBook + Typora + Git 编写电子文档

\n

Gitbook 发布到 Github Pages

\n","site":{"data":{}},"excerpt":"

本文为你介绍如何使用利用 Typora + gitbook-cli + Github Pages 书写Gitbook. 在本地用 Typora 书写 md 文件, 用 gitbook-cli 编译, 最后发布到 Github Pages 上.

","more":"

安装

\n

前提是已经安装了Node, 直接用npm包管理工具安装:

\n\n
\n

CLI version: 2.3.2
\nGitBook version: 3.2.3

\n
\n

新建书籍

\n
    \n
  1. \n

    为新书建立一个根目录 mkdir pytho_finance

    \n
  2. \n
  3. \n

    在该目录下执行(命令行下):gitbook init,之后会在该目录下产生2个文件,分别是README.md(书籍的介绍)和SUMMARY.md(书籍的目录结构)。

    \n
  4. \n
\n

\"gitbook目录的写法\"

\n
    \n
  1. \n

    按照上图格式填写目录和文件, 然后再次执行 gitbook init , GitBook 会查找 SUMMARY.md 文件中描述的目录和文件,如果没有则会将其创建.

    \n
  2. \n
  3. \n

    然后就可以预览书籍了 gitbook serve. 执行命令后会对 Markdown 格式的文档进行转换,默认转换为 html 格式,提示Serving book on http://localhost:4000,打开网址即可查看.

    \n
  4. \n
  5. \n

    构建书籍

    \n
  6. \n
\n\n

默认将生成的静态网站输出到 _book 目录。实际上,这一步也包含在 gitbook serve 里面,因为它们是 HTML,所以 GitBook 通过 Node.js 给你提供服务了。

\n

build 命令可以指定路径, 或者指定端口, 或者生产 pdf , epub, mobi 等格式. 具体参考文章.

\n

发布到Github Pages

\n\n

在GitHub的仓库中新添一个 gh-pages 的Branch.

\n\n

:pen: 忽略文件夹,windows下的测试是 /node_modules, 不加双引号。

\n

进入新目录, 推送编译后的html 和 js 文件到 gh-pages 的分支中去.

\n\n

如此实现了将源代码保存到master, 将静态网站推送到gh-pages, 一个仓库搞定! 在浏览器输入仓库地址, 就可以看到自己的Gitbook. 比如我新书地址

\n
\n

https://maiernte.github.io/gitbook_python_finance/

\n
\n

更新和维护

\n

因为master 和 gh-pages 上存放的是不同的文档,所以拉取的时候也有指定 branch

\n\n

个性化配置

\n

在项目的根目录上添加一个 book.json 文件, 用来更全面的配置项目. 比如头文件, 插件等等.

\n\n

数学插件

\n

在上述文件添加了 "plugins": ["mathjax"], 并执行命令

\n\n

更详细的配置请参阅官方文档.

\n

目录插件

\n

项目地址和文档

\n

book.json 文件修改为 "plugins": ["mathjax", "page-toc" ], ​ 每一页的目录就会出现在右上角。

\n

编译错误列表

\n

版本

\n\n

sharing 插件出错

\n

添加了 page-toc 插件后,gitbook serve 的时候总是出现错误。就算把文章改回原来的样子也无补于事。

\n
\n

info: 7 plugins are installed
\ninfo: loading plugin “livereload”… OK
\ninfo: loading plugin “highlight”… OK
\ninfo: loading plugin “search”… OK
\ninfo: loading plugin “lunr”… OK
\ninfo: loading plugin “sharing”… OK
\ninfo: loading plugin “fontsettings”… OK
\ninfo: loading plugin “theme-default”… OK
\ninfo: found 1 pages
\ninfo: found 0 asset files

\n

Error: ENOENT: no such file or directory, stat ‘D:\\f040371\\git_book\\plattform_finance_book\\gitbook\\gitbook-plugin-sharing\\buttons.js’

\n
\n

解决方法

\n

修改 C:\\Users\\f040371\\.gitbook\\versions\\3.2.3\\lib\\output\\website\\copyPluginAssets.js 文件中的 112 行

\n

\"copyPluginAssets.js\"

\n

confirm: true 改为 confirm: false

\n

参考文章:

\n
\n

使用GitBook和Typora写知识库

\n

gitbook+git+typora 的使用过程

\n

GitBook + Typora + Git 编写电子文档

\n

Gitbook 发布到 Github Pages

"},{"title":"Mac备忘录","date":"2019-07-22T16:47:47.000Z","urlname":"mac-memo","toc":true,"notshow":true,"_content":"\n# 指令和任务\n\n## 隐藏文件夹\n\nTerminal 命令\n\n```bash\n//显示隐藏文件\ndefaults write com.apple.finder AppleShowAllFiles -bool true\n//不显示隐藏文件\ndefaults write com.apple.finder AppleShowAllFiles -bool false\n```\n\n快速命令,打开访达窗口,然后 ⌘ + ⇧ + . 就可以隐藏/显示。\n\n\n\n需要重启Finder使设置生效 :\n\n> 重启Finder:窗口左上角的苹果标志-->强制退出-->Finder-->重新启动\n\n## 允许任何来源软件\n\n系统默认在 **安全与隐私** 里只显示 “App Store” 和 “App Store 和被认可的开发者”,没有 “任何来源”。开启的话需要在终端输入\n\n`sudo spctl --master-disable` \n\n并输入开机密码。\n\n\n\n## 任务控制\n\n- 将任务放在后台运行:`command + &` \n\n- 将任务丢到后台暂停:`ctrl-z` \n\n- 查看后台所有任务状态:`jobs -l` (会列出 1、2、3序列号)\n\n- 将后台的任务拿到前台处理:`fg %jobnumber` (指序列号,而不是任务id)\n\n- 将后台的任务变成运行中:`bg %jobnumber` \n\n- 管理后台当中的任务:`kill -signal %jobnumber`\n\n# 文件管理\n\n## 标签的使用\n\n参看 [mac 标签的使用](mac-using-tags.html)\n\n# 通用技巧\n\n## 输入法\n\n### 查看按键字符\n\n1. 偏好设置 → 键盘 → 输入法,窗口右面会显示键盘⌨️图案,按住shift⇧键或者option⌥,会显示在不同功能键下面的字符。\n\n\n\n## 通过Automator添加快捷键\n\n[文章来源](https://zhidao.baidu.com/question/1514898183998822540.html)\n\n1. 一次打开 ***Finder —> 应用程序 —> automator***\n2. 选取 ***服务***\n3. 从左边的双栏选取 ***使用工具—>运行AppleScript***, 并双击运行。\n4. 出现文本框后选定(右栏最上边)***没有输入***\n\n```objective-c\non run {input, parameters}\n (* Your script goes here *)\n tell application \"Safari\"\n reopen\n activate\n end tell\nend run\n```\n\n5. ⌘+S 保存,命名为 *Open Safari*。关闭automator\n6. 转到 ***系统偏好设置—>键盘—>快捷键—>服务—>通用—>open safari*** ,然后设定快捷键就好了。\n\n\n\n## 电源管理\n\n`pmset`是**macOS**下用来操作、电源管理的工具,可设定休眠模式、时间和唤醒时间或显示电源信息,不过因为它是一个命令列的指令,因此得透过终端机察看或修改设定。当你开启「终端机」输入p`mset -g` 会看到具体设置。\n\n- `Standbydelay 28800` :将系统储存于內存中休眠,会消耗一些电力。\n- `Autopowerofdelay 28800` : 把系统写入SSD硬盘中,将內存暂存关闭,依照这篇文章的说法,两者延迟时间28800秒(约八小时)会让电脑多维持內存八小时左右的电力。\n- `tcpkeepalive` :设定睡眠后是否还保持网络连接, 以便可以透过TCP唤醒系统\n- `hibernatemode` :睡眠模式。数字越小,耗电越高。可以设置为 25\n\n```sh\nsudo pmset -b autopoweroffdelay 300 # 将睡眠时间缩短为300秒(五分钟)\nsudo pmset -b standbydelay 300 # 然后将系统储存到SSD硬盘\nsudo pmset -b tcpkeepalive 0 # 将透过TCP唤醒系统的功能关闭\nsudo pmset -a hibernatemode 25 \n```\n\n> 中间的参数-b是使用电池下的参数,-c为外接电源下的参数设定, -a 为所有情况下的设定。\n\n\n\n## 升级到Mojave后鼠标发飘\n\n前往***偏好设置-->网络-->设定服务顺序(左下角齿轮)***,然后将***蓝牙PAN***拖到最上面。\n\n\n\n# 网络资源\n\n## 应用软件\n\n1. 大量破解资源分享的网站 [MacEnjoy](https://www.macenjoy.co/)\n\n## 在线文档\n\n[iMac 2012 规格](https://support.apple.com/kb/SP665?locale=zh_CN&viewlocale=zh_CN)\n\n### 升级SSD固态硬盘\n\n[iMac 2012 21.5吋 拆卸指南](https://zh.ifixit.com/Teardown/iMac+Intel+21.5-Inch+EMC+2544+Teardown/11936)\n\n[Mac升级外挂SSD硬盘](https://luolei.org/imac-5k-external-usb-ssd-update/)\n\n[如何选择另一个启动磁盘](https://support.apple.com/zh-cn/HT202796) :pen: 官方说明\n\n[更换SSD固态硬盘攻略](http://www.mac52ipod.cn/post/apple-mac-macbook-pro-change-ssd-hardisk-tutorial.php)\n\n1. 固态硬盘通过USB 3连接到电脑,并格式化成 **Mac OS 扩展** 格式。\n\n ![](http://www.mac52ipod.cn/attachment.php?fid=5823)\n\n2. 用 Carbon Copy Cloner([官网下载](https://bombich.com/))把原硬盘的数据镜像到 SSD。完成后要制作恢复分区「Recovery HD」[破解版下载地址](https://www.macenjoy.co/blog/carbon-copy-cloner-for-mac-v5-1-9)\n\n 或者 [SuperDuper](https://www.shirt-pocket.com/SuperDuper/SuperDuperDescription.html) :pen: 免费版可以全盘备份,而不支持增量操作。\n\n ![](http://www.mac52ipod.cn/attachment.php?fid=5824)\n\n3. 重启,听到 「当 」一声后按住 `Option` 键(windows 键盘上的 Alt)。然后选择SSD作为启动硬盘。\n\n4. 开机后用 **Trim Enabler**([官网下载](http://www.cindori.org/software/trimenabler/))开启 **Trim** 读写加速。:+1:","source":"_posts/IT/Mac/Mac备忘录.md","raw":"---\ntitle: Mac备忘录\ndate: 2019-07-22 18:47:47\nurlname: mac-memo\ntoc: true\ntags: [Mac]\ncategories: [IT, Mac]\nnotshow: true\n\n---\n\n# 指令和任务\n\n## 隐藏文件夹\n\nTerminal 命令\n\n```bash\n//显示隐藏文件\ndefaults write com.apple.finder AppleShowAllFiles -bool true\n//不显示隐藏文件\ndefaults write com.apple.finder AppleShowAllFiles -bool false\n```\n\n快速命令,打开访达窗口,然后 ⌘ + ⇧ + . 就可以隐藏/显示。\n\n\n\n需要重启Finder使设置生效 :\n\n> 重启Finder:窗口左上角的苹果标志-->强制退出-->Finder-->重新启动\n\n## 允许任何来源软件\n\n系统默认在 **安全与隐私** 里只显示 “App Store” 和 “App Store 和被认可的开发者”,没有 “任何来源”。开启的话需要在终端输入\n\n`sudo spctl --master-disable` \n\n并输入开机密码。\n\n\n\n## 任务控制\n\n- 将任务放在后台运行:`command + &` \n\n- 将任务丢到后台暂停:`ctrl-z` \n\n- 查看后台所有任务状态:`jobs -l` (会列出 1、2、3序列号)\n\n- 将后台的任务拿到前台处理:`fg %jobnumber` (指序列号,而不是任务id)\n\n- 将后台的任务变成运行中:`bg %jobnumber` \n\n- 管理后台当中的任务:`kill -signal %jobnumber`\n\n# 文件管理\n\n## 标签的使用\n\n参看 [mac 标签的使用](mac-using-tags.html)\n\n# 通用技巧\n\n## 输入法\n\n### 查看按键字符\n\n1. 偏好设置 → 键盘 → 输入法,窗口右面会显示键盘⌨️图案,按住shift⇧键或者option⌥,会显示在不同功能键下面的字符。\n\n\n\n## 通过Automator添加快捷键\n\n[文章来源](https://zhidao.baidu.com/question/1514898183998822540.html)\n\n1. 一次打开 ***Finder —> 应用程序 —> automator***\n2. 选取 ***服务***\n3. 从左边的双栏选取 ***使用工具—>运行AppleScript***, 并双击运行。\n4. 出现文本框后选定(右栏最上边)***没有输入***\n\n```objective-c\non run {input, parameters}\n (* Your script goes here *)\n tell application \"Safari\"\n reopen\n activate\n end tell\nend run\n```\n\n5. ⌘+S 保存,命名为 *Open Safari*。关闭automator\n6. 转到 ***系统偏好设置—>键盘—>快捷键—>服务—>通用—>open safari*** ,然后设定快捷键就好了。\n\n\n\n## 电源管理\n\n`pmset`是**macOS**下用来操作、电源管理的工具,可设定休眠模式、时间和唤醒时间或显示电源信息,不过因为它是一个命令列的指令,因此得透过终端机察看或修改设定。当你开启「终端机」输入p`mset -g` 会看到具体设置。\n\n- `Standbydelay 28800` :将系统储存于內存中休眠,会消耗一些电力。\n- `Autopowerofdelay 28800` : 把系统写入SSD硬盘中,将內存暂存关闭,依照这篇文章的说法,两者延迟时间28800秒(约八小时)会让电脑多维持內存八小时左右的电力。\n- `tcpkeepalive` :设定睡眠后是否还保持网络连接, 以便可以透过TCP唤醒系统\n- `hibernatemode` :睡眠模式。数字越小,耗电越高。可以设置为 25\n\n```sh\nsudo pmset -b autopoweroffdelay 300 # 将睡眠时间缩短为300秒(五分钟)\nsudo pmset -b standbydelay 300 # 然后将系统储存到SSD硬盘\nsudo pmset -b tcpkeepalive 0 # 将透过TCP唤醒系统的功能关闭\nsudo pmset -a hibernatemode 25 \n```\n\n> 中间的参数-b是使用电池下的参数,-c为外接电源下的参数设定, -a 为所有情况下的设定。\n\n\n\n## 升级到Mojave后鼠标发飘\n\n前往***偏好设置-->网络-->设定服务顺序(左下角齿轮)***,然后将***蓝牙PAN***拖到最上面。\n\n\n\n# 网络资源\n\n## 应用软件\n\n1. 大量破解资源分享的网站 [MacEnjoy](https://www.macenjoy.co/)\n\n## 在线文档\n\n[iMac 2012 规格](https://support.apple.com/kb/SP665?locale=zh_CN&viewlocale=zh_CN)\n\n### 升级SSD固态硬盘\n\n[iMac 2012 21.5吋 拆卸指南](https://zh.ifixit.com/Teardown/iMac+Intel+21.5-Inch+EMC+2544+Teardown/11936)\n\n[Mac升级外挂SSD硬盘](https://luolei.org/imac-5k-external-usb-ssd-update/)\n\n[如何选择另一个启动磁盘](https://support.apple.com/zh-cn/HT202796) :pen: 官方说明\n\n[更换SSD固态硬盘攻略](http://www.mac52ipod.cn/post/apple-mac-macbook-pro-change-ssd-hardisk-tutorial.php)\n\n1. 固态硬盘通过USB 3连接到电脑,并格式化成 **Mac OS 扩展** 格式。\n\n ![](http://www.mac52ipod.cn/attachment.php?fid=5823)\n\n2. 用 Carbon Copy Cloner([官网下载](https://bombich.com/))把原硬盘的数据镜像到 SSD。完成后要制作恢复分区「Recovery HD」[破解版下载地址](https://www.macenjoy.co/blog/carbon-copy-cloner-for-mac-v5-1-9)\n\n 或者 [SuperDuper](https://www.shirt-pocket.com/SuperDuper/SuperDuperDescription.html) :pen: 免费版可以全盘备份,而不支持增量操作。\n\n ![](http://www.mac52ipod.cn/attachment.php?fid=5824)\n\n3. 重启,听到 「当 」一声后按住 `Option` 键(windows 键盘上的 Alt)。然后选择SSD作为启动硬盘。\n\n4. 开机后用 **Trim Enabler**([官网下载](http://www.cindori.org/software/trimenabler/))开启 **Trim** 读写加速。:+1:","slug":"IT/Mac/Mac备忘录","published":1,"updated":"2020-05-07T07:28:37.649Z","_id":"cka1y597w001d4huu070sswhu","comments":1,"layout":"post","photos":[],"link":"","content":"

指令和任务

\n

隐藏文件夹

\n

Terminal 命令

\n
1
2
3
4
//显示隐藏文件
defaults write com.apple.finder AppleShowAllFiles -bool true
//不显示隐藏文件
defaults write com.apple.finder AppleShowAllFiles -bool false
\n

快速命令,打开访达窗口,然后 ⌘ + ⇧ + . 就可以隐藏/显示。

\n

需要重启Finder使设置生效 :

\n
\n

重启Finder:窗口左上角的苹果标志–>强制退出–>Finder–>重新启动

\n
\n

允许任何来源软件

\n

系统默认在 安全与隐私 里只显示 “App Store” 和 “App Store 和被认可的开发者”,没有 “任何来源”。开启的话需要在终端输入

\n

sudo spctl --master-disable

\n

并输入开机密码。

\n

任务控制

\n\n

文件管理

\n

标签的使用

\n

参看 mac 标签的使用

\n

通用技巧

\n

输入法

\n

查看按键字符

\n
    \n
  1. 偏好设置 → 键盘 → 输入法,窗口右面会显示键盘⌨️图案,按住shift⇧键或者option⌥,会显示在不同功能键下面的字符。
  2. \n
\n

通过Automator添加快捷键

\n

文章来源

\n
    \n
  1. 一次打开 Finder —> 应用程序 —> automator
  2. \n
  3. 选取 服务
  4. \n
  5. 从左边的双栏选取 使用工具—>运行AppleScript, 并双击运行。
  6. \n
  7. 出现文本框后选定(右栏最上边)没有输入
  8. \n
\n
1
2
3
4
5
6
7
on run {input, parameters}
(* Your script goes here *)
tell application "Safari"
reopen
activate
end tell
end run
\n
    \n
  1. ⌘+S 保存,命名为 Open Safari。关闭automator
  2. \n
  3. 转到 系统偏好设置—>键盘—>快捷键—>服务—>通用—>open safari ,然后设定快捷键就好了。
  4. \n
\n

电源管理

\n

pmsetmacOS下用来操作、电源管理的工具,可设定休眠模式、时间和唤醒时间或显示电源信息,不过因为它是一个命令列的指令,因此得透过终端机察看或修改设定。当你开启「终端机」输入pmset -g 会看到具体设置。

\n\n
1
2
3
4
sudo pmset -b autopoweroffdelay 300 # 将睡眠时间缩短为300秒(五分钟)
sudo pmset -b standbydelay 300 # 然后将系统储存到SSD硬盘
sudo pmset -b tcpkeepalive 0 # 将透过TCP唤醒系统的功能关闭
sudo pmset -a hibernatemode 25
\n
\n

中间的参数-b是使用电池下的参数,-c为外接电源下的参数设定, -a 为所有情况下的设定。

\n
\n

升级到Mojave后鼠标发飘

\n

前往偏好设置–>网络–>设定服务顺序(左下角齿轮),然后将蓝牙PAN拖到最上面。

\n

网络资源

\n

应用软件

\n
    \n
  1. 大量破解资源分享的网站 MacEnjoy
  2. \n
\n

在线文档

\n

iMac 2012 规格

\n

升级SSD固态硬盘

\n

iMac 2012 21.5吋 拆卸指南

\n

Mac升级外挂SSD硬盘

\n

如何选择另一个启动磁盘 :pen: 官方说明

\n

更换SSD固态硬盘攻略

\n
    \n
  1. \n

    固态硬盘通过USB 3连接到电脑,并格式化成 Mac OS 扩展 格式。

    \n

    \n
  2. \n
  3. \n

    用 Carbon Copy Cloner(官网下载)把原硬盘的数据镜像到 SSD。完成后要制作恢复分区「Recovery HD」破解版下载地址

    \n

    或者 SuperDuper :pen: 免费版可以全盘备份,而不支持增量操作。

    \n

    \n
  4. \n
  5. \n

    重启,听到 「当 」一声后按住 Option 键(windows 键盘上的 Alt)。然后选择SSD作为启动硬盘。

    \n
  6. \n
  7. \n

    开机后用 Trim Enabler官网下载)开启 Trim 读写加速。:+1:

    \n
  8. \n
\n","site":{"data":{}},"excerpt":"","more":"

指令和任务

\n

隐藏文件夹

\n

Terminal 命令

\n\n

快速命令,打开访达窗口,然后 ⌘ + ⇧ + . 就可以隐藏/显示。

\n

需要重启Finder使设置生效 :

\n
\n

重启Finder:窗口左上角的苹果标志–>强制退出–>Finder–>重新启动

\n
\n

允许任何来源软件

\n

系统默认在 安全与隐私 里只显示 “App Store” 和 “App Store 和被认可的开发者”,没有 “任何来源”。开启的话需要在终端输入

\n

sudo spctl --master-disable

\n

并输入开机密码。

\n

任务控制

\n\n

文件管理

\n

标签的使用

\n

参看 mac 标签的使用

\n

通用技巧

\n

输入法

\n

查看按键字符

\n
    \n
  1. 偏好设置 → 键盘 → 输入法,窗口右面会显示键盘⌨️图案,按住shift⇧键或者option⌥,会显示在不同功能键下面的字符。
  2. \n
\n

通过Automator添加快捷键

\n

文章来源

\n
    \n
  1. 一次打开 Finder —> 应用程序 —> automator
  2. \n
  3. 选取 服务
  4. \n
  5. 从左边的双栏选取 使用工具—>运行AppleScript, 并双击运行。
  6. \n
  7. 出现文本框后选定(右栏最上边)没有输入
  8. \n
\n\n
    \n
  1. ⌘+S 保存,命名为 Open Safari。关闭automator
  2. \n
  3. 转到 系统偏好设置—>键盘—>快捷键—>服务—>通用—>open safari ,然后设定快捷键就好了。
  4. \n
\n

电源管理

\n

pmsetmacOS下用来操作、电源管理的工具,可设定休眠模式、时间和唤醒时间或显示电源信息,不过因为它是一个命令列的指令,因此得透过终端机察看或修改设定。当你开启「终端机」输入pmset -g 会看到具体设置。

\n\n\n
\n

中间的参数-b是使用电池下的参数,-c为外接电源下的参数设定, -a 为所有情况下的设定。

\n
\n

升级到Mojave后鼠标发飘

\n

前往偏好设置–>网络–>设定服务顺序(左下角齿轮),然后将蓝牙PAN拖到最上面。

\n

网络资源

\n

应用软件

\n
    \n
  1. 大量破解资源分享的网站 MacEnjoy
  2. \n
\n

在线文档

\n

iMac 2012 规格

\n

升级SSD固态硬盘

\n

iMac 2012 21.5吋 拆卸指南

\n

Mac升级外挂SSD硬盘

\n

如何选择另一个启动磁盘 :pen: 官方说明

\n

更换SSD固态硬盘攻略

\n
    \n
  1. \n

    固态硬盘通过USB 3连接到电脑,并格式化成 Mac OS 扩展 格式。

    \n

    \n
  2. \n
  3. \n

    用 Carbon Copy Cloner(官网下载)把原硬盘的数据镜像到 SSD。完成后要制作恢复分区「Recovery HD」破解版下载地址

    \n

    或者 SuperDuper :pen: 免费版可以全盘备份,而不支持增量操作。

    \n

    \n
  4. \n
  5. \n

    重启,听到 「当 」一声后按住 Option 键(windows 键盘上的 Alt)。然后选择SSD作为启动硬盘。

    \n
  6. \n
  7. \n

    开机后用 Trim Enabler官网下载)开启 Trim 读写加速。:+1:

    \n
  8. \n
\n"},{"title":"Ubuntu重设root用户密码","date":"2019-07-26T15:51:03.000Z","urlname":"ubuntu-reset-root-pw","toc":true,"notshow":true,"_content":"\n# 重设密码\n\n原理上参考这份[中文指引][Chinese]就好。由于我的服务器是IONOS公司的,这里主要记录[IONOS][IONOS]的官方指引。(严格按照步骤)\n\n```sh\n网址 www.ionos.de/hilfe\n# 选择 Server & Cloud Infrastructure\n```\n\n\n\n1. 打开 KVM-Konsole\n2. 在用户管理平台软重启系统 Soft-Restart\n3. 在 KVM-Konsole 这边按 ``ESC`` 键\n4. 当出现类似一下界面,按 ``E`` 键\n\n![](https://github.com/maiernte/img/raw/master/Tech/ubuntu-reset-root-1.png)\n\n5. 然后会来到这个界面。\n6. ![](https://github.com/maiernte/img/raw/master/Tech/ubuntu-reset-root-2.png)\n\n7. 用上下键移动到“linux。。。”开始的那一行,并左右键移动到这行的末尾,空格,输入 `init=/bin/bash`\n\n![](https://github.com/maiernte/img/raw/master/Tech/ubuntu-reset-root-3.png)\n\n8. 按 `F10` 开始重启。等完成,进入命令模式后,输入以下命令。\n\n ```sh\n mount -o remount,rw /\n passwd\n Enter new UNIX password:\n Retype new UNIX password:\n passwd: password updated successfull\n ```\n\n \n\n9. 最后输入命令重启系统!\n\n ```sh\n reboot -f \n ```\n\n# 设置公共SSH\n\n在配置 github 的时候已经生成了 ssh-key ,可以用以下方法。\n\n```sh\ncd ~/.ssh\ncp id_rsa.pub authorized_keys\nssh-copy-id -i ~/.ssh/id_rsa.pub root@217.160.61.19 # 我的用户名和服务器地址,默认端口 22\n# 指定端口号为2212:ssh-copy-id -i ~/.ssh/id_rsa.pub -p 2212 user@ip\n\nssh root@217.160.61.19 # 登录并输入密码,第二次就不再需要密码了。\n\n```\n\n\n\n---\n\n[Chinese]: https://ifmx.cc/linux/398.html \"中文指引\"\n[IONOS]: https://www.ionos.de/hilfe/server-cloud-infrastructure/erste-schritte/root-passwort-zuruecksetzen/root-passwort-zuruecksetzen-ubuntu/ \"IONOS官方指引\"\n\n\n","source":"_posts/IT/Tools/Ubuntu重设root用户密码.md","raw":"---\n\ntitle: Ubuntu重设root用户密码\ndate: 2019-07-26 17:51:03\nurlname: ubuntu-reset-root-pw\ntoc: true\ntags: [工具]\ncategories: [IT, Tools]\nnotshow: true\n\n---\n\n# 重设密码\n\n原理上参考这份[中文指引][Chinese]就好。由于我的服务器是IONOS公司的,这里主要记录[IONOS][IONOS]的官方指引。(严格按照步骤)\n\n```sh\n网址 www.ionos.de/hilfe\n# 选择 Server & Cloud Infrastructure\n```\n\n\n\n1. 打开 KVM-Konsole\n2. 在用户管理平台软重启系统 Soft-Restart\n3. 在 KVM-Konsole 这边按 ``ESC`` 键\n4. 当出现类似一下界面,按 ``E`` 键\n\n![](https://github.com/maiernte/img/raw/master/Tech/ubuntu-reset-root-1.png)\n\n5. 然后会来到这个界面。\n6. ![](https://github.com/maiernte/img/raw/master/Tech/ubuntu-reset-root-2.png)\n\n7. 用上下键移动到“linux。。。”开始的那一行,并左右键移动到这行的末尾,空格,输入 `init=/bin/bash`\n\n![](https://github.com/maiernte/img/raw/master/Tech/ubuntu-reset-root-3.png)\n\n8. 按 `F10` 开始重启。等完成,进入命令模式后,输入以下命令。\n\n ```sh\n mount -o remount,rw /\n passwd\n Enter new UNIX password:\n Retype new UNIX password:\n passwd: password updated successfull\n ```\n\n \n\n9. 最后输入命令重启系统!\n\n ```sh\n reboot -f \n ```\n\n# 设置公共SSH\n\n在配置 github 的时候已经生成了 ssh-key ,可以用以下方法。\n\n```sh\ncd ~/.ssh\ncp id_rsa.pub authorized_keys\nssh-copy-id -i ~/.ssh/id_rsa.pub root@217.160.61.19 # 我的用户名和服务器地址,默认端口 22\n# 指定端口号为2212:ssh-copy-id -i ~/.ssh/id_rsa.pub -p 2212 user@ip\n\nssh root@217.160.61.19 # 登录并输入密码,第二次就不再需要密码了。\n\n```\n\n\n\n---\n\n[Chinese]: https://ifmx.cc/linux/398.html \"中文指引\"\n[IONOS]: https://www.ionos.de/hilfe/server-cloud-infrastructure/erste-schritte/root-passwort-zuruecksetzen/root-passwort-zuruecksetzen-ubuntu/ \"IONOS官方指引\"\n\n\n","slug":"IT/Tools/Ubuntu重设root用户密码","published":1,"updated":"2019-08-14T06:34:27.000Z","_id":"cka1y597x001e4huuv3ebsp4j","comments":1,"layout":"post","photos":[],"link":"","content":"

重设密码

\n

原理上参考这份中文指引就好。由于我的服务器是IONOS公司的,这里主要记录IONOS的官方指引。(严格按照步骤)

\n
1
2
网址 www.ionos.de/hilfe
# 选择 Server & Cloud Infrastructure
\n
    \n
  1. 打开 KVM-Konsole
  2. \n
  3. 在用户管理平台软重启系统 Soft-Restart
  4. \n
  5. 在 KVM-Konsole 这边按 ESC
  6. \n
  7. 当出现类似一下界面,按 E
  8. \n
\n

\n
    \n
  1. \n

    然后会来到这个界面。

    \n
  2. \n
  3. \n

    \n
  4. \n
  5. \n

    用上下键移动到“linux。。。”开始的那一行,并左右键移动到这行的末尾,空格,输入 init=/bin/bash

    \n
  6. \n
\n

\n
    \n
  1. \n

    F10 开始重启。等完成,进入命令模式后,输入以下命令。

    \n
    1
    2
    3
    4
    5
    mount -o remount,rw /
    passwd
    Enter new UNIX password:
    Retype new UNIX password:
    passwd: password updated successfull
    \n
  2. \n
  3. \n

    最后输入命令重启系统!

    \n
    1
    reboot -f
    \n
  4. \n
\n

设置公共SSH

\n

在配置 github 的时候已经生成了 ssh-key ,可以用以下方法。

\n
1
2
3
4
5
6
cd ~/.ssh
cp id_rsa.pub authorized_keys
ssh-copy-id -i ~/.ssh/id_rsa.pub root@217.160.61.19 # 我的用户名和服务器地址,默认端口 22
# 指定端口号为2212:ssh-copy-id -i ~/.ssh/id_rsa.pub -p 2212 user@ip

ssh root@217.160.61.19 # 登录并输入密码,第二次就不再需要密码了。
\n
\n","site":{"data":{}},"excerpt":"","more":"

重设密码

\n

原理上参考这份中文指引就好。由于我的服务器是IONOS公司的,这里主要记录IONOS的官方指引。(严格按照步骤)

\n\n
    \n
  1. 打开 KVM-Konsole
  2. \n
  3. 在用户管理平台软重启系统 Soft-Restart
  4. \n
  5. 在 KVM-Konsole 这边按 ESC
  6. \n
  7. 当出现类似一下界面,按 E
  8. \n
\n

\n
    \n
  1. \n

    然后会来到这个界面。

    \n
  2. \n
  3. \n

    \n
  4. \n
  5. \n

    用上下键移动到“linux。。。”开始的那一行,并左右键移动到这行的末尾,空格,输入 init=/bin/bash

    \n
  6. \n
\n

\n
    \n
  1. \n

    F10 开始重启。等完成,进入命令模式后,输入以下命令。

    \n\n
  2. \n
  3. \n

    最后输入命令重启系统!

    \n\n
  4. \n
\n

设置公共SSH

\n

在配置 github 的时候已经生成了 ssh-key ,可以用以下方法。

\n\n
\n"},{"title":"使用Github维护知识库","date":"2019-07-24T21:02:14.000Z","urlname":"use-github-in-wiki","toc":true,"notshow":true,"_content":"\n### 部署以及更新\n\n- **初建**:将文件夹设置为仓库。只是第一次需要,以后就基本不用。\n``git init``\n\n- **更新**:更新所有的文件。\n``git add .``\n\n- **描述**:更新描述(optional 不是必须的)\n``git commit -m \"my command...\"``\n\n- **推送**:上传到云仓库\n``git push -u origin master``\n\n\n\n#### 详细指令\n\n```bash\ngit remote add origin https://github.com/maiernte/NewAngular.git\n\ngit push -u origin master\n\n# For the next commit\n$ git add . # add to index only files created/modified and not those deleted\n$ git add -u # add to index only files deleted/modified and not those created\n$ git add -A # do both operation at once, add to index all files\n```\n下载及更新\n\n```bash\n#下载整个项目\ngit clone XXXXX\n#从服务器更新\ngit pull [xxxxxx]\n#Help\ngit hepl VERB\ngit VERB -h\n```\n\n克隆指定 Branch, 因为有时候 master 和 gh-pages 上存放的是不同的文档。\n\n```sh\ngit clone https://github.com/maiernte/gitbook_python_finance.git --branch master new_fold\n```\n\n设置忽略文件夹以及文件\n\n```sh\ntouch .gitignore\nvim .gitignore\n```\n\n并添加类似的行\n\n```\n# See https://help.github.com/ignore-files/ for more about ignoring files.\n# dependencies\n/node_modules\n\n# testing\n/coverage\n# production\n/build\n# misc\n.DS_Store\n.env.local\nnpm-debug.log*\nyarn-debug.log*\n```\n\n\n\n### 设置git身份信息\n\n```bash\ngit config --global user.name \"你的用户名\"\ngit config --global user.email \"你的邮箱\" \n```\n\n\n\n### 密码和凭证\n\n#### 保存 Github 用户名和密码\n\nMac 下面每次 `push` 都要询问用户名和密码,很麻烦。而且将来不利于用脚本控制部署。有个解决的办法:进入项目根目录,执行一下命令\n\n```sh\ngit config --global credential.helper store\n```\n\n然后推送一次,输入账号和密码后,第二次推送就不需要了!\n\n\n\n#### SSH Key 凭证\n\n```sh\n# 加入 SSH Agent\nssh-agent -s\n```\n\n如果出现类似`Agent pid XXXX`这样的字样,则跳过下一步,否则输入:\n\n```sh\neval `ssh-agent -s`\n```\n\n直到出现`Agent pid XXXX`这样的提示之后,输入:\n\n```sh\nssh-add ~/.ssh/id_rsa\n```\n\n这样,你成功的在本地生成了一个可用的SSH key。\n\n下面将这个key添加到github网站。 打开https://github.com/settings/ssh,点击`Add SSH Key`,复制`id_rsa.pub`中的所有内容到`Key`框中,在`Title`框中输入方便自己记忆的名字(建议输入能让自己明白是哪台电脑的名字,方便以后管理)。 当网页显示添加成功后,就已经完成了全部的操作。 下面进行一些测试,同样是打开Git Bash,输入:\n\n```\nssh -T git@github.com\n```\n\nbash中会显示如下字样:\n\n```\nThe authenticity of host 'github.com (207.97.227.239)' can't be established.\nRSA key fingerprint is 16:27:ac:a5:76:28:2d:36:63:1b:56:4d:eb:df:a6:48.\nAre you sure you want to continue connecting (yes/no)?\n```\n\n输入yes之后,计算机会自动将`github.com`列入已知的host,然后会出现如下提示:\n\n```\nHi username! You've successfully authenticated, but GitHub does not\nprovide shell access.\n```\n\n如果成功看见,说明你已经配置好了,快去享受爽快的hexo一键部署吧; 如果出现任何错误提示,请仔细检查自己的操作,或者将错误信息发给我。\n\n[参阅:十步轻松搞定Hexo]([https://gavinlee1.github.io/2017/02/25/%E5%8D%81%E6%AD%A5%E4%B9%8B%E5%86%85%E8%BD%BB%E6%9D%BE%E6%90%9E%E5%AE%9A-Hexo-GitHub%E6%90%AD%E5%BB%BA%E4%B8%AA%E4%BA%BA%E5%8D%9A%E5%AE%A2/](https://gavinlee1.github.io/2017/02/25/十步之内轻松搞定-Hexo-GitHub搭建个人博客/))\n\n如果要多台电脑共同使用同一个SSH-Key,先在第二台电脑上用这个key的相同邮件生成一个新的key\n```\nssh-keygen -t rsa -b 4096 -C \"username@gmail.com\"\n```\n用第一台电脑上的两个key文件 `id_rsa, id_rsa.pub` 覆盖第二台电脑的文件(*注意备份*)。确保NEW上的两个文件的权限是正确的,id_rsa是600,id_rsa.pub是644,比如:\n```sh\n-rw------- 1 fancy fancy 1675 2013-03-19 12:55 id_rsa\n-rw-r--r-- 1 fancy fancy 406 2013-03-19 12:55 id_rsa.pub\n# 查看权限命令是 \nls -l\n# 更改权限命令是\nchmod 600 ~/.ssh/id_rsa\nchmod 644 ~/.ssh/id_rsa.pub\n```\n\n\n### 删除仓库\n\n1. 点开仓库\n2. 点击右上角的 `Settings`\n3. 滚动到最下面 `Done Zone`, 选择 `Delete this repository`。\n\n### 恢复所有修改\n\n```sh\ngit checkout . #本地所有修改的。没有的提交的,都返回到原来的状态\ngit stash #把所有没有提交的修改暂存到stash里面。可用git stash pop回复。\ngit reset --hard HASH #返回到HASH点,不保留修改。\ngit reset --soft HASH #同上,保留修改。HASH 是节点号,z.B. 7d593c5\n\ngit clean -df #返回到某个节点\ngit clean 参数\n -n 显示 将要 删除的 文件 和 目录\n -f 删除 文件\n -df 删除 文件 和 目录\n--------------------- \ngit describe --always # 查看当前节点号\ngit log # 查看所有HEAD号和Commit描述\n```\n\n更加暴力的方式是\n\n```sh\nit checkout . && git clean -xdf\n```\n\n\n\n#### 清除历史记录\n\n{% fold 代码 %}\n```\n1. Checkout\n git checkout --orphan latest_branch\n\n2. Add all the files\n git add -A\n\n3. Commit the changes\n git commit -am \"commit message\"\n\n4. Delete the branch\n git branch -D master\n\n5. Rename the current branch to master\n git branch -m master\n\n6. Finally, force update your repository\n\n git push -f origin master\n```\n{% endfold %}\n\n### 私人仓库\n\n作为个人笔记,不应该设为public,这样别人可以浏览。==2019== 年Github更新了[新的政策](https://www.infoq.cn/article/aKm94Aw1RmDL_9Gysm8D\n):\n> GitHub Free:包含无限制的私人存储库。有了 GitHub Free,开发人员可以将 GitHub 用于私有项目,每个存储库最多可以有三个协作者。许多开发人员希望使用私人仓库申请工作,做一些 side project,或者在公开发布之前先私下尝试一些东西。从今天开始,这些场景在 GitHub 上可以免费实现(未来可能有更多场景)。 公共存储库仍然是免费的,并包括无限合作者。\n\n\n\n1. 点开仓库\n2. 点击右上角的 `Settings`\n3. 滚动到最下面 `Done Zone`, 选择 `Make this repository private`。\n\n## 文摘资源\n\n[Git submodule 子模块的管理和使用](https://www.jianshu.com/p/9000cd49822c)","source":"_posts/IT/Tools/使用Github维护知识库.md","raw":"---\ntitle: 使用Github维护知识库\ndate: 2019-07-24 23:02:14\nurlname: use-github-in-wiki\ntoc: true\ntags: [工具]\ncategories: [IT, Tools]\nnotshow: true\n\n---\n\n### 部署以及更新\n\n- **初建**:将文件夹设置为仓库。只是第一次需要,以后就基本不用。\n``git init``\n\n- **更新**:更新所有的文件。\n``git add .``\n\n- **描述**:更新描述(optional 不是必须的)\n``git commit -m \"my command...\"``\n\n- **推送**:上传到云仓库\n``git push -u origin master``\n\n\n\n#### 详细指令\n\n```bash\ngit remote add origin https://github.com/maiernte/NewAngular.git\n\ngit push -u origin master\n\n# For the next commit\n$ git add . # add to index only files created/modified and not those deleted\n$ git add -u # add to index only files deleted/modified and not those created\n$ git add -A # do both operation at once, add to index all files\n```\n下载及更新\n\n```bash\n#下载整个项目\ngit clone XXXXX\n#从服务器更新\ngit pull [xxxxxx]\n#Help\ngit hepl VERB\ngit VERB -h\n```\n\n克隆指定 Branch, 因为有时候 master 和 gh-pages 上存放的是不同的文档。\n\n```sh\ngit clone https://github.com/maiernte/gitbook_python_finance.git --branch master new_fold\n```\n\n设置忽略文件夹以及文件\n\n```sh\ntouch .gitignore\nvim .gitignore\n```\n\n并添加类似的行\n\n```\n# See https://help.github.com/ignore-files/ for more about ignoring files.\n# dependencies\n/node_modules\n\n# testing\n/coverage\n# production\n/build\n# misc\n.DS_Store\n.env.local\nnpm-debug.log*\nyarn-debug.log*\n```\n\n\n\n### 设置git身份信息\n\n```bash\ngit config --global user.name \"你的用户名\"\ngit config --global user.email \"你的邮箱\" \n```\n\n\n\n### 密码和凭证\n\n#### 保存 Github 用户名和密码\n\nMac 下面每次 `push` 都要询问用户名和密码,很麻烦。而且将来不利于用脚本控制部署。有个解决的办法:进入项目根目录,执行一下命令\n\n```sh\ngit config --global credential.helper store\n```\n\n然后推送一次,输入账号和密码后,第二次推送就不需要了!\n\n\n\n#### SSH Key 凭证\n\n```sh\n# 加入 SSH Agent\nssh-agent -s\n```\n\n如果出现类似`Agent pid XXXX`这样的字样,则跳过下一步,否则输入:\n\n```sh\neval `ssh-agent -s`\n```\n\n直到出现`Agent pid XXXX`这样的提示之后,输入:\n\n```sh\nssh-add ~/.ssh/id_rsa\n```\n\n这样,你成功的在本地生成了一个可用的SSH key。\n\n下面将这个key添加到github网站。 打开https://github.com/settings/ssh,点击`Add SSH Key`,复制`id_rsa.pub`中的所有内容到`Key`框中,在`Title`框中输入方便自己记忆的名字(建议输入能让自己明白是哪台电脑的名字,方便以后管理)。 当网页显示添加成功后,就已经完成了全部的操作。 下面进行一些测试,同样是打开Git Bash,输入:\n\n```\nssh -T git@github.com\n```\n\nbash中会显示如下字样:\n\n```\nThe authenticity of host 'github.com (207.97.227.239)' can't be established.\nRSA key fingerprint is 16:27:ac:a5:76:28:2d:36:63:1b:56:4d:eb:df:a6:48.\nAre you sure you want to continue connecting (yes/no)?\n```\n\n输入yes之后,计算机会自动将`github.com`列入已知的host,然后会出现如下提示:\n\n```\nHi username! You've successfully authenticated, but GitHub does not\nprovide shell access.\n```\n\n如果成功看见,说明你已经配置好了,快去享受爽快的hexo一键部署吧; 如果出现任何错误提示,请仔细检查自己的操作,或者将错误信息发给我。\n\n[参阅:十步轻松搞定Hexo]([https://gavinlee1.github.io/2017/02/25/%E5%8D%81%E6%AD%A5%E4%B9%8B%E5%86%85%E8%BD%BB%E6%9D%BE%E6%90%9E%E5%AE%9A-Hexo-GitHub%E6%90%AD%E5%BB%BA%E4%B8%AA%E4%BA%BA%E5%8D%9A%E5%AE%A2/](https://gavinlee1.github.io/2017/02/25/十步之内轻松搞定-Hexo-GitHub搭建个人博客/))\n\n如果要多台电脑共同使用同一个SSH-Key,先在第二台电脑上用这个key的相同邮件生成一个新的key\n```\nssh-keygen -t rsa -b 4096 -C \"username@gmail.com\"\n```\n用第一台电脑上的两个key文件 `id_rsa, id_rsa.pub` 覆盖第二台电脑的文件(*注意备份*)。确保NEW上的两个文件的权限是正确的,id_rsa是600,id_rsa.pub是644,比如:\n```sh\n-rw------- 1 fancy fancy 1675 2013-03-19 12:55 id_rsa\n-rw-r--r-- 1 fancy fancy 406 2013-03-19 12:55 id_rsa.pub\n# 查看权限命令是 \nls -l\n# 更改权限命令是\nchmod 600 ~/.ssh/id_rsa\nchmod 644 ~/.ssh/id_rsa.pub\n```\n\n\n### 删除仓库\n\n1. 点开仓库\n2. 点击右上角的 `Settings`\n3. 滚动到最下面 `Done Zone`, 选择 `Delete this repository`。\n\n### 恢复所有修改\n\n```sh\ngit checkout . #本地所有修改的。没有的提交的,都返回到原来的状态\ngit stash #把所有没有提交的修改暂存到stash里面。可用git stash pop回复。\ngit reset --hard HASH #返回到HASH点,不保留修改。\ngit reset --soft HASH #同上,保留修改。HASH 是节点号,z.B. 7d593c5\n\ngit clean -df #返回到某个节点\ngit clean 参数\n -n 显示 将要 删除的 文件 和 目录\n -f 删除 文件\n -df 删除 文件 和 目录\n--------------------- \ngit describe --always # 查看当前节点号\ngit log # 查看所有HEAD号和Commit描述\n```\n\n更加暴力的方式是\n\n```sh\nit checkout . && git clean -xdf\n```\n\n\n\n#### 清除历史记录\n\n{% fold 代码 %}\n```\n1. Checkout\n git checkout --orphan latest_branch\n\n2. Add all the files\n git add -A\n\n3. Commit the changes\n git commit -am \"commit message\"\n\n4. Delete the branch\n git branch -D master\n\n5. Rename the current branch to master\n git branch -m master\n\n6. Finally, force update your repository\n\n git push -f origin master\n```\n{% endfold %}\n\n### 私人仓库\n\n作为个人笔记,不应该设为public,这样别人可以浏览。==2019== 年Github更新了[新的政策](https://www.infoq.cn/article/aKm94Aw1RmDL_9Gysm8D\n):\n> GitHub Free:包含无限制的私人存储库。有了 GitHub Free,开发人员可以将 GitHub 用于私有项目,每个存储库最多可以有三个协作者。许多开发人员希望使用私人仓库申请工作,做一些 side project,或者在公开发布之前先私下尝试一些东西。从今天开始,这些场景在 GitHub 上可以免费实现(未来可能有更多场景)。 公共存储库仍然是免费的,并包括无限合作者。\n\n\n\n1. 点开仓库\n2. 点击右上角的 `Settings`\n3. 滚动到最下面 `Done Zone`, 选择 `Make this repository private`。\n\n## 文摘资源\n\n[Git submodule 子模块的管理和使用](https://www.jianshu.com/p/9000cd49822c)","slug":"IT/Tools/使用Github维护知识库","published":1,"updated":"2019-08-15T09:40:53.000Z","_id":"cka1y597z001h4huur126uc0a","comments":1,"layout":"post","photos":[],"link":"","content":"

部署以及更新

\n\n\n

详细指令

\n
1
2
3
4
5
6
7
8
git remote add origin https://github.com/maiernte/NewAngular.git

git push -u origin master

# For the next commit
$ git add . # add to index only files created/modified and not those deleted
$ git add -u # add to index only files deleted/modified and not those created
$ git add -A # do both operation at once, add to index all files
\n

下载及更新

\n
1
2
3
4
5
6
7
#下载整个项目
git clone XXXXX
#从服务器更新
git pull [xxxxxx]
#Help
git hepl VERB
git VERB -h
\n

克隆指定 Branch, 因为有时候 master 和 gh-pages 上存放的是不同的文档。

\n
1
git clone https://github.com/maiernte/gitbook_python_finance.git --branch master new_fold
\n

设置忽略文件夹以及文件

\n
1
2
touch .gitignore
vim .gitignore
\n

并添加类似的行

\n
1
2
3
4
5
6
7
8
9
10
11
12
13
# See https://help.github.com/ignore-files/ for more about ignoring files.
# dependencies
/node_modules

# testing
/coverage
# production
/build
# misc
.DS_Store
.env.local
npm-debug.log*
yarn-debug.log*
\n

设置git身份信息

\n
1
2
git config --global user.name \"你的用户名\"
git config --global user.email \"你的邮箱\"
\n

密码和凭证

\n

保存 Github 用户名和密码

\n

Mac 下面每次 push 都要询问用户名和密码,很麻烦。而且将来不利于用脚本控制部署。有个解决的办法:进入项目根目录,执行一下命令

\n
1
git config --global credential.helper store
\n

然后推送一次,输入账号和密码后,第二次推送就不需要了!

\n

SSH Key 凭证

\n
1
2
# 加入 SSH Agent
ssh-agent -s
\n

如果出现类似Agent pid XXXX这样的字样,则跳过下一步,否则输入:

\n
1
eval `ssh-agent -s`
\n

直到出现Agent pid XXXX这样的提示之后,输入:

\n
1
ssh-add ~/.ssh/id_rsa
\n

这样,你成功的在本地生成了一个可用的SSH key。

\n

下面将这个key添加到github网站。 打开https://github.com/settings/ssh,点击Add SSH Key,复制id_rsa.pub中的所有内容到Key框中,在Title框中输入方便自己记忆的名字(建议输入能让自己明白是哪台电脑的名字,方便以后管理)。 当网页显示添加成功后,就已经完成了全部的操作。 下面进行一些测试,同样是打开Git Bash,输入:

\n
1
ssh -T git@github.com
\n

bash中会显示如下字样:

\n
1
2
3
The authenticity of host 'github.com (207.97.227.239)' can't be established.
RSA key fingerprint is 16:27:ac:a5:76:28:2d:36:63:1b:56:4d:eb:df:a6:48.
Are you sure you want to continue connecting (yes/no)?
\n

输入yes之后,计算机会自动将github.com列入已知的host,然后会出现如下提示:

\n
1
2
Hi username! You've successfully authenticated, but GitHub does not
provide shell access.
\n

如果成功看见,说明你已经配置好了,快去享受爽快的hexo一键部署吧; 如果出现任何错误提示,请仔细检查自己的操作,或者将错误信息发给我。

\n

参阅:十步轻松搞定Hexo

\n

如果要多台电脑共同使用同一个SSH-Key,先在第二台电脑上用这个key的相同邮件生成一个新的key

\n
1
ssh-keygen -t rsa -b 4096 -C "username@gmail.com"
\n

用第一台电脑上的两个key文件 id_rsa, id_rsa.pub 覆盖第二台电脑的文件(注意备份)。确保NEW上的两个文件的权限是正确的,id_rsa是600,id_rsa.pub是644,比如:

\n
1
2
3
4
5
6
7
-rw------- 1 fancy fancy 1675 2013-03-19 12:55 id_rsa
-rw-r--r-- 1 fancy fancy 406 2013-03-19 12:55 id_rsa.pub
# 查看权限命令是
ls -l
# 更改权限命令是
chmod 600 ~/.ssh/id_rsa
chmod 644 ~/.ssh/id_rsa.pub
\n

删除仓库

\n
    \n
  1. 点开仓库
  2. \n
  3. 点击右上角的 Settings
  4. \n
  5. 滚动到最下面 Done Zone, 选择 Delete this repository
  6. \n
\n

恢复所有修改

\n
1
2
3
4
5
6
7
8
9
10
11
12
13
git checkout . #本地所有修改的。没有的提交的,都返回到原来的状态
git stash #把所有没有提交的修改暂存到stash里面。可用git stash pop回复。
git reset --hard HASH #返回到HASH点,不保留修改。
git reset --soft HASH #同上,保留修改。HASH 是节点号,z.B. 7d593c5

git clean -df #返回到某个节点
git clean 参数
-n 显示 将要 删除的 文件 和 目录
-f 删除 文件
-df 删除 文件 和 目录
---------------------
git describe --always # 查看当前节点号
git log # 查看所有HEAD号和Commit描述
\n

更加暴力的方式是

\n
1
it checkout . && git clean -xdf
\n

清除历史记录

\n
代码
\n
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
1. Checkout
git checkout --orphan latest_branch

2. Add all the files
git add -A

3. Commit the changes
git commit -am "commit message"

4. Delete the branch
git branch -D master

5. Rename the current branch to master
git branch -m master

6. Finally, force update your repository

git push -f origin master
\n\n
\n

私人仓库

\n

作为个人笔记,不应该设为public,这样别人可以浏览。==2019== 年Github更新了新的政策

\n
\n

GitHub Free:包含无限制的私人存储库。有了 GitHub Free,开发人员可以将 GitHub 用于私有项目,每个存储库最多可以有三个协作者。许多开发人员希望使用私人仓库申请工作,做一些 side project,或者在公开发布之前先私下尝试一些东西。从今天开始,这些场景在 GitHub 上可以免费实现(未来可能有更多场景)。 公共存储库仍然是免费的,并包括无限合作者。

\n
\n
    \n
  1. 点开仓库
  2. \n
  3. 点击右上角的 Settings
  4. \n
  5. 滚动到最下面 Done Zone, 选择 Make this repository private
  6. \n
\n

文摘资源

\n

Git submodule 子模块的管理和使用

\n","site":{"data":{}},"excerpt":"

部署以及更新

\n","more":"

详细指令

\n\n

下载及更新

\n\n

克隆指定 Branch, 因为有时候 master 和 gh-pages 上存放的是不同的文档。

\n\n

设置忽略文件夹以及文件

\n\n

并添加类似的行

\n\n

设置git身份信息

\n\n

密码和凭证

\n

保存 Github 用户名和密码

\n

Mac 下面每次 push 都要询问用户名和密码,很麻烦。而且将来不利于用脚本控制部署。有个解决的办法:进入项目根目录,执行一下命令

\n\n

然后推送一次,输入账号和密码后,第二次推送就不需要了!

\n

SSH Key 凭证

\n\n

如果出现类似Agent pid XXXX这样的字样,则跳过下一步,否则输入:

\n\n

直到出现Agent pid XXXX这样的提示之后,输入:

\n\n

这样,你成功的在本地生成了一个可用的SSH key。

\n

下面将这个key添加到github网站。 打开https://github.com/settings/ssh,点击Add SSH Key,复制id_rsa.pub中的所有内容到Key框中,在Title框中输入方便自己记忆的名字(建议输入能让自己明白是哪台电脑的名字,方便以后管理)。 当网页显示添加成功后,就已经完成了全部的操作。 下面进行一些测试,同样是打开Git Bash,输入:

\n\n

bash中会显示如下字样:

\n\n

输入yes之后,计算机会自动将github.com列入已知的host,然后会出现如下提示:

\n\n

如果成功看见,说明你已经配置好了,快去享受爽快的hexo一键部署吧; 如果出现任何错误提示,请仔细检查自己的操作,或者将错误信息发给我。

\n

参阅:十步轻松搞定Hexo

\n

如果要多台电脑共同使用同一个SSH-Key,先在第二台电脑上用这个key的相同邮件生成一个新的key

\n\n

用第一台电脑上的两个key文件 id_rsa, id_rsa.pub 覆盖第二台电脑的文件(注意备份)。确保NEW上的两个文件的权限是正确的,id_rsa是600,id_rsa.pub是644,比如:

\n\n

删除仓库

\n
    \n
  1. 点开仓库
  2. \n
  3. 点击右上角的 Settings
  4. \n
  5. 滚动到最下面 Done Zone, 选择 Delete this repository
  6. \n
\n

恢复所有修改

\n\n

更加暴力的方式是

\n\n

清除历史记录

\n
代码
\n\n\n
\n

私人仓库

\n

作为个人笔记,不应该设为public,这样别人可以浏览。==2019== 年Github更新了新的政策

\n
\n

GitHub Free:包含无限制的私人存储库。有了 GitHub Free,开发人员可以将 GitHub 用于私有项目,每个存储库最多可以有三个协作者。许多开发人员希望使用私人仓库申请工作,做一些 side project,或者在公开发布之前先私下尝试一些东西。从今天开始,这些场景在 GitHub 上可以免费实现(未来可能有更多场景)。 公共存储库仍然是免费的,并包括无限合作者。

\n
\n
    \n
  1. 点开仓库
  2. \n
  3. 点击右上角的 Settings
  4. \n
  5. 滚动到最下面 Done Zone, 选择 Make this repository private
  6. \n
\n

文摘资源

\n

Git submodule 子模块的管理和使用

"},{"title":"坚果云有关","date":"2019-07-25T03:41:28.000Z","urlname":"about-jianguoyu","toc":true,"notshow":true,"_content":"\n\n\n##### 忽略文件\n\n配置文件 `customExtRules.conf`。在 Window 版可以在软件直接打开,在 Mac App 里面没有这个选项,要自行查找这个配置文件。[官方说明](http://www.jianguoyun.com/s/content/2219.html)\n\n> 在 Windows 和 Mac 下面目录可能不一样。\n\n\n\nMac 系统或 Linux 系统这个文件通常位于\n\n```sh\nvim ~/.nutstore/db/customExtRules.conf\nfold/to/ignore # 文件夹的绝对路径\n```\n\n\n\n##### 安卓系统上同步文件夹\n\n安卓版的坚果云客户端只会打开临时指定的文件。如果希望跟在PC上一样的操作,将整个文件库都同步到指定的文件夹内,就要用[FolderSync](http://help.jianguoyun.com/?p=2887)软件。\n\n登陆坚果云官网,账户信息-->安全选项-->第三方应用管理,生成一个新的第三方应用 **androidSync**,密码为 `xxxxxxxxxxxxxxxx`,然后按照上述官网的指南一步一步配置 FolderSync 就可以了。回头还是用 「坚果云 Markdown」这款软件来阅读md文档。\n\n##### 托管密码\n\n设置为 SafeInClound 的托管云盘。用户名是坚果云的登陆账户,密码为专门为其开通的第三方应用 *mypass* 的专门密码。`Local Pfad` 填写云盘内存储数据库文件的文件夹。 \n\n![](https://github.com/maiernte/img/raw/master/Tech/safeInCloudToJianguo.png)","source":"_posts/IT/Tools/坚果云有关.md","raw":"---\ntitle: 坚果云有关\ndate: 2019-07-25 05:41:28\nurlname: about-jianguoyu\ntoc: true\ntags: [工具]\ncategories: [IT, Tools]\nnotshow: true\n\n---\n\n\n\n##### 忽略文件\n\n配置文件 `customExtRules.conf`。在 Window 版可以在软件直接打开,在 Mac App 里面没有这个选项,要自行查找这个配置文件。[官方说明](http://www.jianguoyun.com/s/content/2219.html)\n\n> 在 Windows 和 Mac 下面目录可能不一样。\n\n\n\nMac 系统或 Linux 系统这个文件通常位于\n\n```sh\nvim ~/.nutstore/db/customExtRules.conf\nfold/to/ignore # 文件夹的绝对路径\n```\n\n\n\n##### 安卓系统上同步文件夹\n\n安卓版的坚果云客户端只会打开临时指定的文件。如果希望跟在PC上一样的操作,将整个文件库都同步到指定的文件夹内,就要用[FolderSync](http://help.jianguoyun.com/?p=2887)软件。\n\n登陆坚果云官网,账户信息-->安全选项-->第三方应用管理,生成一个新的第三方应用 **androidSync**,密码为 `xxxxxxxxxxxxxxxx`,然后按照上述官网的指南一步一步配置 FolderSync 就可以了。回头还是用 「坚果云 Markdown」这款软件来阅读md文档。\n\n##### 托管密码\n\n设置为 SafeInClound 的托管云盘。用户名是坚果云的登陆账户,密码为专门为其开通的第三方应用 *mypass* 的专门密码。`Local Pfad` 填写云盘内存储数据库文件的文件夹。 \n\n![](https://github.com/maiernte/img/raw/master/Tech/safeInCloudToJianguo.png)","slug":"IT/Tools/坚果云有关","published":1,"updated":"2019-08-14T22:10:30.000Z","_id":"cka1y5981001j4huuk1yz6awj","comments":1,"layout":"post","photos":[],"link":"","content":"
忽略文件
\n

配置文件 customExtRules.conf。在 Window 版可以在软件直接打开,在 Mac App 里面没有这个选项,要自行查找这个配置文件。官方说明

\n
\n

在 Windows 和 Mac 下面目录可能不一样。

\n
\n\n

Mac 系统或 Linux 系统这个文件通常位于

\n
1
2
vim ~/.nutstore/db/customExtRules.conf
fold/to/ignore # 文件夹的绝对路径
\n
安卓系统上同步文件夹
\n

安卓版的坚果云客户端只会打开临时指定的文件。如果希望跟在PC上一样的操作,将整个文件库都同步到指定的文件夹内,就要用FolderSync软件。

\n

登陆坚果云官网,账户信息–>安全选项–>第三方应用管理,生成一个新的第三方应用 androidSync,密码为 xxxxxxxxxxxxxxxx,然后按照上述官网的指南一步一步配置 FolderSync 就可以了。回头还是用 「坚果云 Markdown」这款软件来阅读md文档。

\n
托管密码
\n

设置为 SafeInClound 的托管云盘。用户名是坚果云的登陆账户,密码为专门为其开通的第三方应用 mypass 的专门密码。Local Pfad 填写云盘内存储数据库文件的文件夹。

\n

\n","site":{"data":{}},"excerpt":"
忽略文件
\n

配置文件 customExtRules.conf。在 Window 版可以在软件直接打开,在 Mac App 里面没有这个选项,要自行查找这个配置文件。官方说明

\n
\n

在 Windows 和 Mac 下面目录可能不一样。

\n
","more":"

Mac 系统或 Linux 系统这个文件通常位于

\n\n
安卓系统上同步文件夹
\n

安卓版的坚果云客户端只会打开临时指定的文件。如果希望跟在PC上一样的操作,将整个文件库都同步到指定的文件夹内,就要用FolderSync软件。

\n

登陆坚果云官网,账户信息–>安全选项–>第三方应用管理,生成一个新的第三方应用 androidSync,密码为 xxxxxxxxxxxxxxxx,然后按照上述官网的指南一步一步配置 FolderSync 就可以了。回头还是用 「坚果云 Markdown」这款软件来阅读md文档。

\n
托管密码
\n

设置为 SafeInClound 的托管云盘。用户名是坚果云的登陆账户,密码为专门为其开通的第三方应用 mypass 的专门密码。Local Pfad 填写云盘内存储数据库文件的文件夹。

\n

"},{"title":"编辑器工具使用技巧汇总","date":"2019-07-27T06:24:33.000Z","urlname":"Editor-Skills-Summary","toc":true,"notshow":true,"_content":"\n# VSCode\n\n1. Wechseln zwischen Text-Editor und Terminal\n 1. `Command+K+S` oder in Menü `Code->Pereferenc->Hotky`, öffnet Hot-Key Editor Fenster.\n 2. Tip `terminal` in Suchfeld, findet die Binding `^\\``, löscht diese Einstellung.\n 3. Sucht den \"workbench.action.terminal.focus\", bindet es mit Key `⌃<`.\n 4. Sucht den \"workbench.action.focusActiveEditorGroup\", bindet es wiederum mit Schlüssel `⌃<`, und Wenn-Kondition \"terminalFocus\".\n\n\n\n# Typora\n\n更多更详细的内容请参阅 Typora Wiki\n\n[Typora Wiki](http://support.typora.io/) ([wiki-website Project](https://github.com/typora/wiki-website))\n\n\n\n## 个性化快捷键\n\n**Windows**\n\n*文件--->偏好设置--->往高级设置* ,点击看到两个`json`格式的文件,打开第二个(**conf.user.json**), 用记事本打开,第17行`keyBinding`,在大括号中写 `代码块`:“你要设置的快捷键”,比如我的是**代码块**:`Ctrl+Alt+P`,保存文件,重启`typora`即可生效。[更详细介绍](https://github.com/itcastWsy/typora_copy_images)\n\n\n```json\n// Custom key binding, which will override the default ones.\n \"keyBinding\": {\n // for example: \n // \"Always on Top\": \"Ctrl+Shift+P\"\n \"注释\":\"Ctrl+Alt+/\",\n \"代码块\":\"Ctrl+Alt+P\",\n \"打开文件夹…\":\"Ctrl+Alt+O\"\n },\n```\n\n**Mac**\n\n[官方说明](http://support.typora.io/Shortcut-Keys/#macos)\n\n需要到`系统偏好设置—>键盘-->快捷键-->应用快捷键`那边设置。找到 ***Typora.App***,菜单名称填 ***代码***,然后输入希望的快捷键。我的设置是***⌃+⌘+C***。\n\n\n\n## 更改风格\n\n[开发好的工具](https://github.com/typora/typora-theme-toolkit) [如何客制化格式](https://pjchender.github.io/2018/04/24/note-%E5%A6%82%E4%BD%95%E7%82%BA-typora-%E6%92%B0%E5%AF%AB%E5%AE%A2%E8%A3%BD%E5%8C%96%E6%A8%A3%E5%BC%8F/)\n\n简单使用:添加 `base.user.css` 文件,并改变行内代码的颜色,以及公式颜色\n\n```css\n# 行内代码\ncode {\n\tcolor: red\n}\n\n# 行内公式\n.MathJax_SVG{\n\tcolor: DarkBlue;\n}\n```\n\n \n\nTypora的代码使用 [CodeMirror](https://codemirror.net/) 项目,尝试了一下修改 `base.user.css` 文件确实可以改变代码段的高度,并带滚动。但同时也限定了进行代码编辑时的整个窗口高度。所以没有用\n\n```css\n# 缺点:打开源代码模式的时候,整个页面也被限制成了只有300px高\n.CodeMirror {\n max-height: 300px;\n}\n.CodeMirror-scroll {\n overflow-y: auto;\n \toverflow-x: auto;\n\tmax-height: 300px;\n}\n```\n\n注意到书写模式的时候,整个编辑器都被包裹在 `
` 里面。在源代码模式的时候,没有这个 `write` 元素的包裹,而整个源代码窗口都被作用为一个 `CodeMirror` 元素对待。因此,作一些改变就能满足要求\n\n```scss\n#write .CodeMirror {\n max-height: 350px;\n}\n# 设定上下 padding 会让滚动条在小代码区消失\n#write .CodeMirror-scroll {\n overflow-y: auto;\n \toverflow-x: auto;\n\tmax-height: 330px;\n\tpadding-top: 10px;\n\tpadding-bottom: 10px;\n}\n```\n\n```\n# 避免只有一行的代码区,因为会显示滚动条,不好看。一行代码就用行内代码好了。\n```\n\n如果要限制来自 `GistHub` 的代码高度,只能限定其父元素 `iframe`\n\n```css\niframe {\n\tmax-height: 500px;\n}\n```\n\nWindows版的 Typora 的数学模块保存在 `path/resource/app/lib.asar` 压缩文件中。需要用asar解压\n\n[如何查看 asar 内部结构](https://newsn.net/say/electron-asar-explorer.html)\n\n[asar 如何加密解密](https://newsn.net/say/electron-asar-explorer.html)\n\n```sh\nnpm install -g asar\nasar extract 压缩文件 解压文件夹\nasar pack 文件夹 压缩文件名\n```\n\n\n\n\n## 文本搜索\n\n打开的单篇文章内搜索:\n\n> Windows `Control + F`\n>\n> Mac `⌘+F`\n\n文件夹内的搜索\n\n> Windows `Control + Shift + F`\n>\n> Mac `⇧+⌘+F`","source":"_posts/IT/Tools/编辑器工具使用技巧汇总.md","raw":"---\ntitle: 编辑器工具使用技巧汇总\ndate: 2019-07-27 08:24:33\nurlname: Editor-Skills-Summary\ntoc: true\ntags: [工具]\ncategories: [IT, Tools]\nnotshow: true\n\n---\n\n# VSCode\n\n1. Wechseln zwischen Text-Editor und Terminal\n 1. `Command+K+S` oder in Menü `Code->Pereferenc->Hotky`, öffnet Hot-Key Editor Fenster.\n 2. Tip `terminal` in Suchfeld, findet die Binding `^\\``, löscht diese Einstellung.\n 3. Sucht den \"workbench.action.terminal.focus\", bindet es mit Key `⌃<`.\n 4. Sucht den \"workbench.action.focusActiveEditorGroup\", bindet es wiederum mit Schlüssel `⌃<`, und Wenn-Kondition \"terminalFocus\".\n\n\n\n# Typora\n\n更多更详细的内容请参阅 Typora Wiki\n\n[Typora Wiki](http://support.typora.io/) ([wiki-website Project](https://github.com/typora/wiki-website))\n\n\n\n## 个性化快捷键\n\n**Windows**\n\n*文件--->偏好设置--->往高级设置* ,点击看到两个`json`格式的文件,打开第二个(**conf.user.json**), 用记事本打开,第17行`keyBinding`,在大括号中写 `代码块`:“你要设置的快捷键”,比如我的是**代码块**:`Ctrl+Alt+P`,保存文件,重启`typora`即可生效。[更详细介绍](https://github.com/itcastWsy/typora_copy_images)\n\n\n```json\n// Custom key binding, which will override the default ones.\n \"keyBinding\": {\n // for example: \n // \"Always on Top\": \"Ctrl+Shift+P\"\n \"注释\":\"Ctrl+Alt+/\",\n \"代码块\":\"Ctrl+Alt+P\",\n \"打开文件夹…\":\"Ctrl+Alt+O\"\n },\n```\n\n**Mac**\n\n[官方说明](http://support.typora.io/Shortcut-Keys/#macos)\n\n需要到`系统偏好设置—>键盘-->快捷键-->应用快捷键`那边设置。找到 ***Typora.App***,菜单名称填 ***代码***,然后输入希望的快捷键。我的设置是***⌃+⌘+C***。\n\n\n\n## 更改风格\n\n[开发好的工具](https://github.com/typora/typora-theme-toolkit) [如何客制化格式](https://pjchender.github.io/2018/04/24/note-%E5%A6%82%E4%BD%95%E7%82%BA-typora-%E6%92%B0%E5%AF%AB%E5%AE%A2%E8%A3%BD%E5%8C%96%E6%A8%A3%E5%BC%8F/)\n\n简单使用:添加 `base.user.css` 文件,并改变行内代码的颜色,以及公式颜色\n\n```css\n# 行内代码\ncode {\n\tcolor: red\n}\n\n# 行内公式\n.MathJax_SVG{\n\tcolor: DarkBlue;\n}\n```\n\n \n\nTypora的代码使用 [CodeMirror](https://codemirror.net/) 项目,尝试了一下修改 `base.user.css` 文件确实可以改变代码段的高度,并带滚动。但同时也限定了进行代码编辑时的整个窗口高度。所以没有用\n\n```css\n# 缺点:打开源代码模式的时候,整个页面也被限制成了只有300px高\n.CodeMirror {\n max-height: 300px;\n}\n.CodeMirror-scroll {\n overflow-y: auto;\n \toverflow-x: auto;\n\tmax-height: 300px;\n}\n```\n\n注意到书写模式的时候,整个编辑器都被包裹在 `
` 里面。在源代码模式的时候,没有这个 `write` 元素的包裹,而整个源代码窗口都被作用为一个 `CodeMirror` 元素对待。因此,作一些改变就能满足要求\n\n```scss\n#write .CodeMirror {\n max-height: 350px;\n}\n# 设定上下 padding 会让滚动条在小代码区消失\n#write .CodeMirror-scroll {\n overflow-y: auto;\n \toverflow-x: auto;\n\tmax-height: 330px;\n\tpadding-top: 10px;\n\tpadding-bottom: 10px;\n}\n```\n\n```\n# 避免只有一行的代码区,因为会显示滚动条,不好看。一行代码就用行内代码好了。\n```\n\n如果要限制来自 `GistHub` 的代码高度,只能限定其父元素 `iframe`\n\n```css\niframe {\n\tmax-height: 500px;\n}\n```\n\nWindows版的 Typora 的数学模块保存在 `path/resource/app/lib.asar` 压缩文件中。需要用asar解压\n\n[如何查看 asar 内部结构](https://newsn.net/say/electron-asar-explorer.html)\n\n[asar 如何加密解密](https://newsn.net/say/electron-asar-explorer.html)\n\n```sh\nnpm install -g asar\nasar extract 压缩文件 解压文件夹\nasar pack 文件夹 压缩文件名\n```\n\n\n\n\n## 文本搜索\n\n打开的单篇文章内搜索:\n\n> Windows `Control + F`\n>\n> Mac `⌘+F`\n\n文件夹内的搜索\n\n> Windows `Control + Shift + F`\n>\n> Mac `⇧+⌘+F`","slug":"IT/Tools/编辑器工具使用技巧汇总","published":1,"updated":"2019-09-01T17:11:47.000Z","_id":"cka1y5983001n4huuemw79ybo","comments":1,"layout":"post","photos":[],"link":"","content":"

VSCode

\n
    \n
  1. Wechseln zwischen Text-Editor und Terminal\n
      \n
    1. Command+K+S oder in Menü Code->Pereferenc->Hotky, öffnet Hot-Key Editor Fenster.
    2. \n
    3. Tip terminal in Suchfeld, findet die Binding `^``, löscht diese Einstellung.
    4. \n
    5. Sucht den “workbench.action.terminal.focus”, bindet es mit Key ⌃<.
    6. \n
    7. Sucht den “workbench.action.focusActiveEditorGroup”, bindet es wiederum mit Schlüssel ⌃<, und Wenn-Kondition “terminalFocus”.
    8. \n
    \n
  2. \n
\n\n

Typora

\n

更多更详细的内容请参阅 Typora Wiki

\n

Typora Wiki (wiki-website Project)

\n

个性化快捷键

\n

Windows

\n

文件—>偏好设置—>往高级设置 ,点击看到两个json格式的文件,打开第二个(conf.user.json), 用记事本打开,第17行keyBinding,在大括号中写 代码块:“你要设置的快捷键”,比如我的是代码块:Ctrl+Alt+P,保存文件,重启typora即可生效。更详细介绍

\n
1
2
3
4
5
6
7
8
// Custom key binding, which will override the default ones.
\"keyBinding\": {
// for example:
// \"Always on Top\": \"Ctrl+Shift+P\"
\"注释\":\"Ctrl+Alt+/\",
\"代码块\":\"Ctrl+Alt+P\",
\"打开文件夹…\":\"Ctrl+Alt+O\"
},
\n

Mac

\n

官方说明

\n

需要到系统偏好设置—>键盘-->快捷键-->应用快捷键那边设置。找到 Typora.App,菜单名称填 代码,然后输入希望的快捷键。我的设置是⌃+⌘+C

\n

更改风格

\n

开发好的工具 如何客制化格式

\n

简单使用:添加 base.user.css 文件,并改变行内代码的颜色,以及公式颜色

\n
1
2
3
4
5
6
7
8
9
# 行内代码
code {
\tcolor: red
}

# 行内公式
.MathJax_SVG{
\tcolor: DarkBlue;
}
\n

Typora的代码使用 CodeMirror 项目,尝试了一下修改 base.user.css 文件确实可以改变代码段的高度,并带滚动。但同时也限定了进行代码编辑时的整个窗口高度。所以没有用

\n
1
2
3
4
5
6
7
8
9
# 缺点:打开源代码模式的时候,整个页面也被限制成了只有300px
.CodeMirror {
max-height: 300px;
}
.CodeMirror-scroll {
overflow-y: auto;
\toverflow-x: auto;
\tmax-height: 300px;
}
\n

注意到书写模式的时候,整个编辑器都被包裹在 <div id="write"> </div> 里面。在源代码模式的时候,没有这个 write 元素的包裹,而整个源代码窗口都被作用为一个 CodeMirror 元素对待。因此,作一些改变就能满足要求

\n
1
2
3
4
5
6
7
8
9
10
11
#write .CodeMirror {
max-height: 350px;
}
# 设定上下 padding 会让滚动条在小代码区消失
#write .CodeMirror-scroll {
overflow-y: auto;
\toverflow-x: auto;
\tmax-height: 330px;
\tpadding-top: 10px;
\tpadding-bottom: 10px;
}
\n
1
# 避免只有一行的代码区,因为会显示滚动条,不好看。一行代码就用行内代码好了。
\n

如果要限制来自 GistHub 的代码高度,只能限定其父元素 iframe

\n
1
2
3
iframe {
\tmax-height: 500px;
}
\n

Windows版的 Typora 的数学模块保存在 path/resource/app/lib.asar 压缩文件中。需要用asar解压

\n

如何查看 asar 内部结构

\n

asar 如何加密解密

\n
1
2
3
npm install -g asar
asar extract 压缩文件 解压文件夹
asar pack 文件夹 压缩文件名
\n

文本搜索

\n

打开的单篇文章内搜索:

\n
\n

Windows Control + F

\n

Mac ⌘+F

\n
\n

文件夹内的搜索

\n
\n

Windows Control + Shift + F

\n

Mac ⇧+⌘+F

\n
\n","site":{"data":{}},"excerpt":"

VSCode

\n
    \n
  1. Wechseln zwischen Text-Editor und Terminal\n
      \n
    1. Command+K+S oder in Menü Code->Pereferenc->Hotky, öffnet Hot-Key Editor Fenster.
    2. \n
    3. Tip terminal in Suchfeld, findet die Binding `^``, löscht diese Einstellung.
    4. \n
    5. Sucht den “workbench.action.terminal.focus”, bindet es mit Key ⌃<.
    6. \n
    7. Sucht den “workbench.action.focusActiveEditorGroup”, bindet es wiederum mit Schlüssel ⌃<, und Wenn-Kondition “terminalFocus”.
    8. \n
    \n
  2. \n
","more":"

Typora

\n

更多更详细的内容请参阅 Typora Wiki

\n

Typora Wiki (wiki-website Project)

\n

个性化快捷键

\n

Windows

\n

文件—>偏好设置—>往高级设置 ,点击看到两个json格式的文件,打开第二个(conf.user.json), 用记事本打开,第17行keyBinding,在大括号中写 代码块:“你要设置的快捷键”,比如我的是代码块:Ctrl+Alt+P,保存文件,重启typora即可生效。更详细介绍

\n\n

Mac

\n

官方说明

\n

需要到系统偏好设置—>键盘-->快捷键-->应用快捷键那边设置。找到 Typora.App,菜单名称填 代码,然后输入希望的快捷键。我的设置是⌃+⌘+C

\n

更改风格

\n

开发好的工具 如何客制化格式

\n

简单使用:添加 base.user.css 文件,并改变行内代码的颜色,以及公式颜色

\n\n

Typora的代码使用 CodeMirror 项目,尝试了一下修改 base.user.css 文件确实可以改变代码段的高度,并带滚动。但同时也限定了进行代码编辑时的整个窗口高度。所以没有用

\n\n

注意到书写模式的时候,整个编辑器都被包裹在 <div id="write"> </div> 里面。在源代码模式的时候,没有这个 write 元素的包裹,而整个源代码窗口都被作用为一个 CodeMirror 元素对待。因此,作一些改变就能满足要求

\n\n\n

如果要限制来自 GistHub 的代码高度,只能限定其父元素 iframe

\n\n

Windows版的 Typora 的数学模块保存在 path/resource/app/lib.asar 压缩文件中。需要用asar解压

\n

如何查看 asar 内部结构

\n

asar 如何加密解密

\n\n

文本搜索

\n

打开的单篇文章内搜索:

\n
\n

Windows Control + F

\n

Mac ⌘+F

\n
\n

文件夹内的搜索

\n
\n

Windows Control + Shift + F

\n

Mac ⇧+⌘+F

\n
"},{"title":"配置服务器端MySQL","date":"2019-08-06T15:26:28.000Z","urlname":"config-mysql-access-privileges-on-vps","toc":true,"notshow":true,"_content":"\n[文章](https://blog.csdn.net/bird3014/article/details/78481104)\n\n###### 问题一:端口状态\n\n1. 查看 3306 端口状态 `sudo netstat -an | grep 3306`\n\n> tcp 0 0 127.0.0.1:3306 0.0.0.0:* \n\n3306端口是默认绑定在本地IP 127.0.0.1上的,所以外网无法访问该主机的3306端口。 \n打开MySQL的配置文件:`sudo vim /etc/mysql/mysql.conf.d/mysqld.cnf`\n\n2. 找到如下内容的一行并注释掉:\n\n> bind-address = 127.0.0.1\n\n3. 重启MySQL服务\n\n> sudo systemctl restart mysql\n\n然后使用如下命令查看端口绑定状态\n\n> `sudo netstat -an | grep 3306`\n\n----\n\n###### 问题二:用户权限\n\n查看用户权限\n\n```mysql\nsudo mysql -uroot -p[你的密码]\nuse mysql\nselect user,host from user\n```\n\n当显示如下,表示用户root只允许内网访问\n\n> root localhost\n\n给用户授权\n\n```mysql\ngrant all privileges on *.* to 'root'@'[允许的ip]' identified by '[密码]' with grant option;\nflush privileges;\n```\n\n其中*`[允许的ip]`*如果设置为**%**的话则表示所有$ip$都可以访问,*`[密码]`*表示外网访问的密码是什么。比如我设置成所有$ip$都可访问,密码是$root$,则命令如下:\n\n```mysql\ngrant all privileges on *.* to 'root'@'%' identified by 'root' with grant option;\nflush privileges;\nselect user,host from user;\n```\n\n重新查看,会显示 \n\n> root %\n>\n> root localhost\n\n\n\n###### 安装 phpMyAdmin\n\n","source":"_posts/IT/Tools/配置服务器端MySQL.md","raw":"---\ntitle: 配置服务器端MySQL\ndate: 2019-08-06 17:26:28\nurlname: config-mysql-access-privileges-on-vps\ntoc: true\ntags: [工具]\ncategories: [IT, Tools]\nnotshow: true\n\n---\n\n[文章](https://blog.csdn.net/bird3014/article/details/78481104)\n\n###### 问题一:端口状态\n\n1. 查看 3306 端口状态 `sudo netstat -an | grep 3306`\n\n> tcp 0 0 127.0.0.1:3306 0.0.0.0:* \n\n3306端口是默认绑定在本地IP 127.0.0.1上的,所以外网无法访问该主机的3306端口。 \n打开MySQL的配置文件:`sudo vim /etc/mysql/mysql.conf.d/mysqld.cnf`\n\n2. 找到如下内容的一行并注释掉:\n\n> bind-address = 127.0.0.1\n\n3. 重启MySQL服务\n\n> sudo systemctl restart mysql\n\n然后使用如下命令查看端口绑定状态\n\n> `sudo netstat -an | grep 3306`\n\n----\n\n###### 问题二:用户权限\n\n查看用户权限\n\n```mysql\nsudo mysql -uroot -p[你的密码]\nuse mysql\nselect user,host from user\n```\n\n当显示如下,表示用户root只允许内网访问\n\n> root localhost\n\n给用户授权\n\n```mysql\ngrant all privileges on *.* to 'root'@'[允许的ip]' identified by '[密码]' with grant option;\nflush privileges;\n```\n\n其中*`[允许的ip]`*如果设置为**%**的话则表示所有$ip$都可以访问,*`[密码]`*表示外网访问的密码是什么。比如我设置成所有$ip$都可访问,密码是$root$,则命令如下:\n\n```mysql\ngrant all privileges on *.* to 'root'@'%' identified by 'root' with grant option;\nflush privileges;\nselect user,host from user;\n```\n\n重新查看,会显示 \n\n> root %\n>\n> root localhost\n\n\n\n###### 安装 phpMyAdmin\n\n","slug":"IT/Tools/配置服务器端MySQL","published":1,"updated":"2019-08-14T13:10:45.000Z","_id":"cka1y5986001p4huuxt1btjua","comments":1,"layout":"post","photos":[],"link":"","content":"

文章

\n
问题一:端口状态
\n
    \n
  1. 查看 3306 端口状态 sudo netstat -an | grep 3306
  2. \n
\n
\n

tcp 0 0 127.0.0.1:3306 0.0.0.0:*

\n
\n

3306端口是默认绑定在本地IP 127.0.0.1上的,所以外网无法访问该主机的3306端口。
\n打开MySQL的配置文件:sudo vim /etc/mysql/mysql.conf.d/mysqld.cnf

\n
    \n
  1. 找到如下内容的一行并注释掉:
  2. \n
\n
\n

bind-address = 127.0.0.1

\n
\n
    \n
  1. 重启MySQL服务
  2. \n
\n
\n

sudo systemctl restart mysql

\n
\n

然后使用如下命令查看端口绑定状态

\n
\n

sudo netstat -an | grep 3306

\n
\n
\n
问题二:用户权限
\n

查看用户权限

\n
1
2
3
sudo mysql -uroot -p[你的密码]
use mysql
select user,host from user
\n

当显示如下,表示用户root只允许内网访问

\n
\n

root localhost

\n
\n

给用户授权

\n
1
2
grant all privileges on *.* to 'root'@'[允许的ip]' identified by '[密码]' with grant option;
flush privileges;
\n

其中*[允许的ip]如果设置为*%**的话则表示所有$ip$都可以访问,*[密码]*表示外网访问的密码是什么。比如我设置成所有$ip$都可访问,密码是$root$,则命令如下:

\n
1
2
3
grant all privileges on *.* to 'root'@'%' identified by 'root' with grant option;
flush privileges;
select user,host from user;
\n

重新查看,会显示

\n
\n

root %

\n

root localhost

\n
\n
安装 phpMyAdmin
\n","site":{"data":{}},"excerpt":"","more":"

文章

\n
问题一:端口状态
\n
    \n
  1. 查看 3306 端口状态 sudo netstat -an | grep 3306
  2. \n
\n
\n

tcp 0 0 127.0.0.1:3306 0.0.0.0:*

\n
\n

3306端口是默认绑定在本地IP 127.0.0.1上的,所以外网无法访问该主机的3306端口。
\n打开MySQL的配置文件:sudo vim /etc/mysql/mysql.conf.d/mysqld.cnf

\n
    \n
  1. 找到如下内容的一行并注释掉:
  2. \n
\n
\n

bind-address = 127.0.0.1

\n
\n
    \n
  1. 重启MySQL服务
  2. \n
\n
\n

sudo systemctl restart mysql

\n
\n

然后使用如下命令查看端口绑定状态

\n
\n

sudo netstat -an | grep 3306

\n
\n
\n
问题二:用户权限
\n

查看用户权限

\n\n

当显示如下,表示用户root只允许内网访问

\n
\n

root localhost

\n
\n

给用户授权

\n\n

其中*[允许的ip]如果设置为*%**的话则表示所有$ip$都可以访问,*[密码]*表示外网访问的密码是什么。比如我设置成所有$ip$都可访问,密码是$root$,则命令如下:

\n\n

重新查看,会显示

\n
\n

root %

\n

root localhost

\n
\n
安装 phpMyAdmin
\n"},{"title":"Next以及wikitten主题添加内容折叠","date":"2019-07-23T18:29:33.000Z","urlname":"next-collapse-block","toc":true,"_content":"\n# 添加代码\n\n当有大段的代码直接展示在页面时,看起来臃肿且不便于观看,此时将代码折叠式最好的选择。下面是在Hexo的Next主题上添加折叠功能。\n\n\n\n## 在main.js中添加折叠js\n\nNext主题的主要js位于 `themes/next/source/js/src/post-details.js`,在下面添加一下代码段:\n\n```javascript\n$(document).ready(function(){\n $(document).on('click', '.fold_hider', function(){\n $('>.fold', this.parentNode).slideToggle();\n $('>:first', this).toggleClass('open');\n });\n //默认情况下折叠\n $(\"div.fold\").css(\"display\",\"none\");\n});\n```\n\nWikitten 主题添加到 `themes/wikitten/source/js/main.js` 后面。\n\n## 自定义内建标签\n\n在主题scripts下添加一个tags.js,位于`themes/next/scripts/tags.js`\n\n```javascript\n/*\n @haohuawu\n 修复 Nunjucks 的 tag 里写 ```代码块```,最终都会渲染成 undefined 的问题\n https://github.com/hexojs/hexo/issues/2400\n*/\nconst rEscapeContent = /]*)>([\\s\\S]*?)<\\/escape>/g;\nconst placeholder = '\\uFFFD';\nconst rPlaceholder = /(?:<|<)\\!--\\uFFFD(\\d+)--(?:>|>)/g;\nconst cache = [];\nfunction escapeContent(str) {\n return '';\n}\nhexo.extend.filter.register('before_post_render', function(data) {\n data.content = data.content.replace(rEscapeContent, function(match, content) {\n return escapeContent(content);\n });\n return data;\n});\nhexo.extend.filter.register('after_post_render', function(data) {\n data.content = data.content.replace(rPlaceholder, function() {\n return cache[arguments[1]];\n });\n return data;\n});\n```\n\n再继续添加一个fold.js,位于`themes/next/scripts/fold.js`\n\n\n\n```javascript\n/* global hexo */\n// Usage: {% fold ???? %} Something {% endfold %}\nfunction fold (args, content) {\n var text = args[0];\n if(!text) text = \"点击显/隐\";\n return '
' + text + '
\\n' + hexo.render.renderSync({text: content, engine: 'markdown'}) + '\\n
';\n}\nhexo.extend.tag.register('fold', fold, {ends: true});\n```\n\nwikitten主题将这两个文件复制到 `themes/wikitten/scripts` 目录下。\n\n## 添加自定义样式\n\n位于`themes/next/source/css/_custom/custom.styl`\n\n```css\n.hider_title{\n font-family: \"Microsoft Yahei\";\n cursor: pointer;\n color: red;\n}\n.close:after{\n content: \"▼\";\n}\n.open:after{\n content: \"▲\";\n}\n```\n\nwikitten 主题将此代码添加到 `themes/wikitten/source/css/_partial/article.styl` 文件下面。在`next` 主题必须将==color: red==去掉,否则会影响大纲栏的颜色。\n\n## 使用\n\n在我们需要折叠的地方前后添加便签,示例用法:\n\n```\n{% fold 点击显/隐内容 %}\n需要隐藏的内容。。。\n{% endfold %}\n```\n\n\n\n## 参考\n\n[Hexo next博客添加折叠块功能添加折叠代码块](https://blog.rmiao.top/hexo-fold-block/) \n[Next主题实现内容折叠](http://zlingfly.com/2018/09/05/fold-test/) \n[jQuery 实现内容折叠功能](https://www.oyohyee.com/post/Note/fold/)\n\n[Hexo 标签插件 官方](https://hexo.io/zh-cn/docs/tag-plugins.html)\n\n# 实例\n\n## 嵌套代码\n\nSome Content\n\n{% fold 点击显/隐内容 %}\n{% blockquote Mai, Düsseldorf link http://google.de %}\n\n\n\tpo_bfa_swbh_laufbahn\n\t\n\\\n\n{% endblockquote %}\n{% endfold %}\n\n## Hexo 代码方式\n\n{% blockquote David, Levithan %}\nLorem ipsum dolor sit amet, consectetur adipiscing elit. Pellentesque hendrerit lacus ut purus iaculis feugiat. Sed nec tempor elit, quis aliquam neque. Curabitur sed diam eget dolor fermentum semper at eu lorem.\n{% endblockquote %}\n\n{% codeblock KOS xsl http://google.de downloadcode %}\n1 code snippet\n{% endcodeblock %}\n\n## Gist\n\n### Hexo 方式\n\nGist (\"48edcb5cfd92937ae61360b74852d4e1\" 就是id。 而 \"xml\" 是我创建时的文件名)。地址是 git.github.com\n\n{% gist 48edcb5cfd92937ae61360b74852d4e1 xml %}\n\n
\n\n### Javascript 方式\n\n\n\n","source":"_posts/IT/Web/Next主题添加内容折叠.md","raw":"---\ntitle: Next以及wikitten主题添加内容折叠\ndate: 2019-07-23 20:29:33\nurlname: next-collapse-block\ntoc: true\ntags: [Hexo]\ncategories: [IT, Web]\n\n---\n\n# 添加代码\n\n当有大段的代码直接展示在页面时,看起来臃肿且不便于观看,此时将代码折叠式最好的选择。下面是在Hexo的Next主题上添加折叠功能。\n\n\n\n## 在main.js中添加折叠js\n\nNext主题的主要js位于 `themes/next/source/js/src/post-details.js`,在下面添加一下代码段:\n\n```javascript\n$(document).ready(function(){\n $(document).on('click', '.fold_hider', function(){\n $('>.fold', this.parentNode).slideToggle();\n $('>:first', this).toggleClass('open');\n });\n //默认情况下折叠\n $(\"div.fold\").css(\"display\",\"none\");\n});\n```\n\nWikitten 主题添加到 `themes/wikitten/source/js/main.js` 后面。\n\n## 自定义内建标签\n\n在主题scripts下添加一个tags.js,位于`themes/next/scripts/tags.js`\n\n```javascript\n/*\n @haohuawu\n 修复 Nunjucks 的 tag 里写 ```代码块```,最终都会渲染成 undefined 的问题\n https://github.com/hexojs/hexo/issues/2400\n*/\nconst rEscapeContent = /]*)>([\\s\\S]*?)<\\/escape>/g;\nconst placeholder = '\\uFFFD';\nconst rPlaceholder = /(?:<|<)\\!--\\uFFFD(\\d+)--(?:>|>)/g;\nconst cache = [];\nfunction escapeContent(str) {\n return '';\n}\nhexo.extend.filter.register('before_post_render', function(data) {\n data.content = data.content.replace(rEscapeContent, function(match, content) {\n return escapeContent(content);\n });\n return data;\n});\nhexo.extend.filter.register('after_post_render', function(data) {\n data.content = data.content.replace(rPlaceholder, function() {\n return cache[arguments[1]];\n });\n return data;\n});\n```\n\n再继续添加一个fold.js,位于`themes/next/scripts/fold.js`\n\n\n\n```javascript\n/* global hexo */\n// Usage: {% fold ???? %} Something {% endfold %}\nfunction fold (args, content) {\n var text = args[0];\n if(!text) text = \"点击显/隐\";\n return '
' + text + '
\\n' + hexo.render.renderSync({text: content, engine: 'markdown'}) + '\\n
';\n}\nhexo.extend.tag.register('fold', fold, {ends: true});\n```\n\nwikitten主题将这两个文件复制到 `themes/wikitten/scripts` 目录下。\n\n## 添加自定义样式\n\n位于`themes/next/source/css/_custom/custom.styl`\n\n```css\n.hider_title{\n font-family: \"Microsoft Yahei\";\n cursor: pointer;\n color: red;\n}\n.close:after{\n content: \"▼\";\n}\n.open:after{\n content: \"▲\";\n}\n```\n\nwikitten 主题将此代码添加到 `themes/wikitten/source/css/_partial/article.styl` 文件下面。在`next` 主题必须将==color: red==去掉,否则会影响大纲栏的颜色。\n\n## 使用\n\n在我们需要折叠的地方前后添加便签,示例用法:\n\n```\n{% fold 点击显/隐内容 %}\n需要隐藏的内容。。。\n{% endfold %}\n```\n\n\n\n## 参考\n\n[Hexo next博客添加折叠块功能添加折叠代码块](https://blog.rmiao.top/hexo-fold-block/) \n[Next主题实现内容折叠](http://zlingfly.com/2018/09/05/fold-test/) \n[jQuery 实现内容折叠功能](https://www.oyohyee.com/post/Note/fold/)\n\n[Hexo 标签插件 官方](https://hexo.io/zh-cn/docs/tag-plugins.html)\n\n# 实例\n\n## 嵌套代码\n\nSome Content\n\n{% fold 点击显/隐内容 %}\n{% blockquote Mai, Düsseldorf link http://google.de %}\n\n\n\tpo_bfa_swbh_laufbahn\n\t\n\\\n\n{% endblockquote %}\n{% endfold %}\n\n## Hexo 代码方式\n\n{% blockquote David, Levithan %}\nLorem ipsum dolor sit amet, consectetur adipiscing elit. Pellentesque hendrerit lacus ut purus iaculis feugiat. Sed nec tempor elit, quis aliquam neque. Curabitur sed diam eget dolor fermentum semper at eu lorem.\n{% endblockquote %}\n\n{% codeblock KOS xsl http://google.de downloadcode %}\n1 code snippet\n{% endcodeblock %}\n\n## Gist\n\n### Hexo 方式\n\nGist (\"48edcb5cfd92937ae61360b74852d4e1\" 就是id。 而 \"xml\" 是我创建时的文件名)。地址是 git.github.com\n\n{% gist 48edcb5cfd92937ae61360b74852d4e1 xml %}\n\n
\n\n### Javascript 方式\n\n\n\n","slug":"IT/Web/Next主题添加内容折叠","published":1,"updated":"2019-07-31T03:51:34.000Z","_id":"cka1y5988001t4huux85puqey","comments":1,"layout":"post","photos":[],"link":"","content":"

添加代码

\n

当有大段的代码直接展示在页面时,看起来臃肿且不便于观看,此时将代码折叠式最好的选择。下面是在Hexo的Next主题上添加折叠功能。

\n\n

在main.js中添加折叠js

\n

Next主题的主要js位于 themes/next/source/js/src/post-details.js,在下面添加一下代码段:

\n
1
2
3
4
5
6
7
8
$(document).ready(function(){
$(document).on('click', '.fold_hider', function(){
$('>.fold', this.parentNode).slideToggle();
$('>:first', this).toggleClass('open');
});
//默认情况下折叠
$(\"div.fold\").css(\"display\",\"none\");
});
\n

Wikitten 主题添加到 themes/wikitten/source/js/main.js 后面。

\n

自定义内建标签

\n

在主题scripts下添加一个tags.js,位于themes/next/scripts/tags.js

\n
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
/*
@haohuawu
修复 Nunjucks 的 tag 里写 ```代码块```,最终都会渲染成 undefined 的问题
https://github.com/hexojs/hexo/issues/2400
*/
const rEscapeContent = /<escape(?:[^>]*)>([\\s\\S]*?)<\\/escape>/g;
const placeholder = '\\uFFFD';
const rPlaceholder = /(?:<|&lt;)\\!--\\uFFFD(\\d+)--(?:>|&gt;)/g;
const cache = [];
function escapeContent(str) {
return '<!--' + placeholder + (cache.push(str) - 1) + '-->';
}
hexo.extend.filter.register('before_post_render', function(data) {
data.content = data.content.replace(rEscapeContent, function(match, content) {
return escapeContent(content);
});
return data;
});
hexo.extend.filter.register('after_post_render', function(data) {
data.content = data.content.replace(rPlaceholder, function() {
return cache[arguments[1]];
});
return data;
});
\n

再继续添加一个fold.js,位于themes/next/scripts/fold.js

\n
1
2
3
4
5
6
7
8
/* global hexo */
// Usage: {% fold ???? %} Something {% endfold %}
function fold (args, content) {
var text = args[0];
if(!text) text = \"点击显/隐\";
return '<div><div class=\"fold_hider\"><div class=\"close hider_title\">' + text + '</div></div><div class=\"fold\">\\n' + hexo.render.renderSync({text: content, engine: 'markdown'}) + '\\n</div></div>';
}
hexo.extend.tag.register('fold', fold, {ends: true});
\n

wikitten主题将这两个文件复制到 themes/wikitten/scripts 目录下。

\n

添加自定义样式

\n

位于themes/next/source/css/_custom/custom.styl

\n
1
2
3
4
5
6
7
8
9
10
11
.hider_title{
font-family: \"Microsoft Yahei\";
cursor: pointer;
color: red;
}
.close:after{
content: \"▼\";
}
.open:after{
content: \"▲\";
}
\n

wikitten 主题将此代码添加到 themes/wikitten/source/css/_partial/article.styl 文件下面。在next 主题必须将==color: red==去掉,否则会影响大纲栏的颜色。

\n

使用

\n

在我们需要折叠的地方前后添加便签,示例用法:

\n
1
2
3
{% fold 点击显/隐内容 %}
需要隐藏的内容。。。
{% endfold %}
\n

参考

\n

Hexo next博客添加折叠块功能添加折叠代码块
\nNext主题实现内容折叠
\njQuery 实现内容折叠功能

\n

Hexo 标签插件 官方

\n

实例

\n

嵌套代码

\n

Some Content

\n
点击显/隐内容
\n

<xsl:call-template name=“SetGlobaleVariable”>
\n<xsl:with-param name=“name-variable”>po_bfa_swbh_laufbahn</xsl:with-param>
\n<xsl:with-param name=“wert-variable” select="$bf_laufbahnzulage"/>
\n</xsl:call-template>

\n
\n
\n

Hexo 代码方式

\n

Lorem ipsum dolor sit amet, consectetur adipiscing elit. Pellentesque hendrerit lacus ut purus iaculis feugiat. Sed nec tempor elit, quis aliquam neque. Curabitur sed diam eget dolor fermentum semper at eu lorem.

\n
DavidLevithan
\n
KOS xsldownloadcode
1
1 code snippet
\n

Gist

\n

Hexo 方式

\n

Gist (“48edcb5cfd92937ae61360b74852d4e1” 就是id。 而 “xml” 是我创建时的文件名)。地址是 git.github.com

\n\n
\n

Javascript 方式

\n\n","site":{"data":{}},"excerpt":"

添加代码

\n

当有大段的代码直接展示在页面时,看起来臃肿且不便于观看,此时将代码折叠式最好的选择。下面是在Hexo的Next主题上添加折叠功能。

","more":"

在main.js中添加折叠js

\n

Next主题的主要js位于 themes/next/source/js/src/post-details.js,在下面添加一下代码段:

\n\n

Wikitten 主题添加到 themes/wikitten/source/js/main.js 后面。

\n

自定义内建标签

\n

在主题scripts下添加一个tags.js,位于themes/next/scripts/tags.js

\n\n

再继续添加一个fold.js,位于themes/next/scripts/fold.js

\n\n

wikitten主题将这两个文件复制到 themes/wikitten/scripts 目录下。

\n

添加自定义样式

\n

位于themes/next/source/css/_custom/custom.styl

\n\n

wikitten 主题将此代码添加到 themes/wikitten/source/css/_partial/article.styl 文件下面。在next 主题必须将==color: red==去掉,否则会影响大纲栏的颜色。

\n

使用

\n

在我们需要折叠的地方前后添加便签,示例用法:

\n\n

参考

\n

Hexo next博客添加折叠块功能添加折叠代码块
\nNext主题实现内容折叠
\njQuery 实现内容折叠功能

\n

Hexo 标签插件 官方

\n

实例

\n

嵌套代码

\n

Some Content

\n
点击显/隐内容
\n

<xsl:call-template name=“SetGlobaleVariable”>
\n<xsl:with-param name=“name-variable”>po_bfa_swbh_laufbahn</xsl:with-param>
\n<xsl:with-param name=“wert-variable” select="$bf_laufbahnzulage"/>
\n</xsl:call-template>

\n
\n
\n

Hexo 代码方式

\n

Lorem ipsum dolor sit amet, consectetur adipiscing elit. Pellentesque hendrerit lacus ut purus iaculis feugiat. Sed nec tempor elit, quis aliquam neque. Curabitur sed diam eget dolor fermentum semper at eu lorem.

\n
DavidLevithan
\n
KOS xsldownloadcode
1
1 code snippet
\n

Gist

\n

Hexo 方式

\n

Gist (“48edcb5cfd92937ae61360b74852d4e1” 就是id。 而 “xml” 是我创建时的文件名)。地址是 git.github.com

\n\n
\n

Javascript 方式

\n"},{"title":"同步Hexo文章与Mac上原笔记的分类和标签","date":"2019-08-01T15:30:00.000Z","urlname":"synchron-the-tag-and-categories-btw-pc-hexo","toc":true,"_content":"\n\n\n最近才搞明白,原来**Hexo**博客的`_post`文件夹里面的Markdown原文件是可以按照分级嵌套的目录结构摆放的。编译的时候才放到**public**这个单一目录下。如果能让文章在Hexo的==分类==严格跟md文件的存储目录一一对应,将来需要找原文件的时侯会方便很多。😄\n\n\n\n使用**Mac**系统的同学也知道,mac有个很风骚的操作,就是给文件分配不同颜色的标签,非常方便文件寻找。我也希望博客上的文章标签,能跟Mac系统里的标签统一起来。:smile: \n\n\n\n实现物理存储目录与`Hexo分类`统一很简单,将源md文件的相对存储路径写到文件meta元素的`categories`里面就行了。比如源文件放在`我的博客-->IT-->前端`,文章的头文件就写成这样:`categories:[IT, 前端]`。\n\n\n\n实现标签的统一稍微麻烦一点,需要先读取文件实际分配到的标签。网上已经有一个公开的项目, [tag](https://github.com/jdberry/tag) 。下载并安装,就可以通过 `tag` 命令读取文件和文件夹的标签。\n\n```sh\n# 安装\nbrew install tag\n# 查看版本\ntag --version\n# 读取文件标签\ntag --list fileUrl\n```\n\n\n\n我已经写好了相应的脚本文件,下载并执行脚本文件就好了。脚本文件里的`dirPath`变量是我的统一存放md源文件的文件夹,你需要改成自己的存放路径,那样就不用每次运行的时候输入一遍。\n\n> 我在Hexo项目的根目录新添一个文件夹专门存放管理的脚本文件,每次都在终端运行这个脚本,所以默认执行路径是 `./source/_post`。\n\n\n\n运行脚本的时候可以设定时间参数,过滤掉太久远的文件。默认情况不会更改文件内容,只查看文件的实际分类和标签是否与文内头文件相同。然后按照给出的列表手动更改。如果想让程序自动更改,按照提示输入`fix`参数就好。\n\n","source":"_posts/IT/Web/同步Hexo文章与Mac上原笔记的分类和标签.md","raw":"---\ntitle: 同步Hexo文章与Mac上原笔记的分类和标签\ndate: 2019-08-01 17:30:00\nurlname: synchron-the-tag-and-categories-btw-pc-hexo\ntoc: true\ntags: [Hexo, Mac]\ncategories: [IT, Web]\n---\n\n\n\n最近才搞明白,原来**Hexo**博客的`_post`文件夹里面的Markdown原文件是可以按照分级嵌套的目录结构摆放的。编译的时候才放到**public**这个单一目录下。如果能让文章在Hexo的==分类==严格跟md文件的存储目录一一对应,将来需要找原文件的时侯会方便很多。😄\n\n\n\n使用**Mac**系统的同学也知道,mac有个很风骚的操作,就是给文件分配不同颜色的标签,非常方便文件寻找。我也希望博客上的文章标签,能跟Mac系统里的标签统一起来。:smile: \n\n\n\n实现物理存储目录与`Hexo分类`统一很简单,将源md文件的相对存储路径写到文件meta元素的`categories`里面就行了。比如源文件放在`我的博客-->IT-->前端`,文章的头文件就写成这样:`categories:[IT, 前端]`。\n\n\n\n实现标签的统一稍微麻烦一点,需要先读取文件实际分配到的标签。网上已经有一个公开的项目, [tag](https://github.com/jdberry/tag) 。下载并安装,就可以通过 `tag` 命令读取文件和文件夹的标签。\n\n```sh\n# 安装\nbrew install tag\n# 查看版本\ntag --version\n# 读取文件标签\ntag --list fileUrl\n```\n\n\n\n我已经写好了相应的脚本文件,下载并执行脚本文件就好了。脚本文件里的`dirPath`变量是我的统一存放md源文件的文件夹,你需要改成自己的存放路径,那样就不用每次运行的时候输入一遍。\n\n> 我在Hexo项目的根目录新添一个文件夹专门存放管理的脚本文件,每次都在终端运行这个脚本,所以默认执行路径是 `./source/_post`。\n\n\n\n运行脚本的时候可以设定时间参数,过滤掉太久远的文件。默认情况不会更改文件内容,只查看文件的实际分类和标签是否与文内头文件相同。然后按照给出的列表手动更改。如果想让程序自动更改,按照提示输入`fix`参数就好。\n\n","slug":"IT/Web/同步Hexo文章与Mac上原笔记的分类和标签","published":1,"updated":"2019-08-03T12:58:26.000Z","_id":"cka1y598a001v4huunsgdb908","comments":1,"layout":"post","photos":[],"link":"","content":"

最近才搞明白,原来Hexo博客的_post文件夹里面的Markdown原文件是可以按照分级嵌套的目录结构摆放的。编译的时候才放到public这个单一目录下。如果能让文章在Hexo的==分类==严格跟md文件的存储目录一一对应,将来需要找原文件的时侯会方便很多。😄

\n

使用Mac系统的同学也知道,mac有个很风骚的操作,就是给文件分配不同颜色的标签,非常方便文件寻找。我也希望博客上的文章标签,能跟Mac系统里的标签统一起来。:smile:

\n

实现物理存储目录与Hexo分类统一很简单,将源md文件的相对存储路径写到文件meta元素的categories里面就行了。比如源文件放在我的博客-->IT-->前端,文章的头文件就写成这样:categories:[IT, 前端]

\n

实现标签的统一稍微麻烦一点,需要先读取文件实际分配到的标签。网上已经有一个公开的项目, tag 。下载并安装,就可以通过 tag 命令读取文件和文件夹的标签。

\n
1
2
3
4
5
6
# 安装
brew install tag
# 查看版本
tag --version
# 读取文件标签
tag --list fileUrl
\n

我已经写好了相应的脚本文件,下载并执行脚本文件就好了。脚本文件里的dirPath变量是我的统一存放md源文件的文件夹,你需要改成自己的存放路径,那样就不用每次运行的时候输入一遍。

\n
\n

我在Hexo项目的根目录新添一个文件夹专门存放管理的脚本文件,每次都在终端运行这个脚本,所以默认执行路径是 ./source/_post

\n
\n

运行脚本的时候可以设定时间参数,过滤掉太久远的文件。默认情况不会更改文件内容,只查看文件的实际分类和标签是否与文内头文件相同。然后按照给出的列表手动更改。如果想让程序自动更改,按照提示输入fix参数就好。

\n","site":{"data":{}},"excerpt":"","more":"

最近才搞明白,原来Hexo博客的_post文件夹里面的Markdown原文件是可以按照分级嵌套的目录结构摆放的。编译的时候才放到public这个单一目录下。如果能让文章在Hexo的==分类==严格跟md文件的存储目录一一对应,将来需要找原文件的时侯会方便很多。😄

\n

使用Mac系统的同学也知道,mac有个很风骚的操作,就是给文件分配不同颜色的标签,非常方便文件寻找。我也希望博客上的文章标签,能跟Mac系统里的标签统一起来。:smile:

\n

实现物理存储目录与Hexo分类统一很简单,将源md文件的相对存储路径写到文件meta元素的categories里面就行了。比如源文件放在我的博客-->IT-->前端,文章的头文件就写成这样:categories:[IT, 前端]

\n

实现标签的统一稍微麻烦一点,需要先读取文件实际分配到的标签。网上已经有一个公开的项目, tag 。下载并安装,就可以通过 tag 命令读取文件和文件夹的标签。

\n\n

我已经写好了相应的脚本文件,下载并执行脚本文件就好了。脚本文件里的dirPath变量是我的统一存放md源文件的文件夹,你需要改成自己的存放路径,那样就不用每次运行的时候输入一遍。

\n
\n

我在Hexo项目的根目录新添一个文件夹专门存放管理的脚本文件,每次都在终端运行这个脚本,所以默认执行路径是 ./source/_post

\n
\n

运行脚本的时候可以设定时间参数,过滤掉太久远的文件。默认情况不会更改文件内容,只查看文件的实际分类和标签是否与文内头文件相同。然后按照给出的列表手动更改。如果想让程序自动更改,按照提示输入fix参数就好。

\n"},{"title":"如何系统化管理Hexo博客","date":"2019-07-28T19:30:00.000Z","urlname":"how-to-manage-big-hexo-blog","toc":true,"contentpw":123456,"_content":"\n

管理?

\n\n![](https://github.com/maiernte/img/raw/master/fun/what.jpg)\n\n\n\n# 建立博客的初衷\n虽说这篇笔记的题目是「如何管理」,为了更好的回答这个问题,必须要回到最原始问题上来——我为何要建一个博客,而且是费那么大劲。而我的初衷是建立和维护一个属于自己的「知识库」。通常来说,为了达成这个目的,更好的选择是笔记APP,而不是博客。我确实也是这么做的。一开始用印象笔记,因为它死活不支持多级目录,我又转到国内的为知笔记,做了五年的VIP用户。但它五年来似乎从没改进过。随着近年来有道云异军突起,以及IOS生态圈中琳琅满目的APP,如熊掌记、Notion、谷歌的Keep、阿里的语雀。。。。。。各有各的惊艳,各有各的槽点。\n\n随着国外的Github和国内的Coding等公司,相继开放永久免费、不限流量的静态网页托管平台,如Github Pages。我走上了自建Bolg的不归路。当然不是说,搭博客这条路完全没有槽点。而是——自己造的孽,含着泪也会继续造下去。至少它满足了我以下几点「必不可少」的要求:\n\n- [x] 多级目录\n- [x] 支持Markdown文本\n- [x] 支持分类、标签、以及站内全文检索\n- [x] 没有IOS、Windows、Android等平台限制\n\n说白了,我是利用Github提供的免费平台,把Blog当笔记本来用。最后选了Hexo,简单易用、界面绚丽、插件丰富。除开自用的「知识平台」功能以外,偶尔还能发发博文装大尾巴狼,也是蛮不错的感觉。\n\n网上介绍怎么搭建Hexo以及添加绚丽功能的帖子海了去了,但我基本没有发现分享「如何管理」的。因为绝大多数这些博主,搭建Hexo只是用来玩一阵子。回头有更新更好玩的东西,就跑去玩别的了。极少数有博客,站内文章超过50篇的。所以,对他们来说,根本不存在——管理——这个议题。\n\n虽然Hexo在逻辑上支持`分类`和`标签`,但物理上它把所有的Post都放到一个单一的目录下面。而我是打算把它当作知识库,长期、密集使用的。可预见的将来,站内笔记会非常多。不但写新贴,还可能经常更改旧贴。那势必会带来一个问题:如何管理数量少日益膨胀的笔记?\n\n# 解决思路\n\n我能想到的办法很简单,也很传统。就是不但逻辑分类,而且也必须物理上分目录存放。理论上在自己的PC分目录保存就好了。但我有好几台电脑,单位一台、自己Windows一台、Mac一台,还有平板。为了让能在不同的电脑上能随时修改、添加笔记,必须放在托管在云端。\n\n## 硬件\n没有必要租用传统的VPS,太贵了,而且连10%的运算能力都用不上。用共享的Web Hosting就完全能解决需求。比如百度云,或者Azure的Web App。而我是租用 1&1 公司的Web Hosting,每个月 1€\n- 1 CPU\n- 500M 内存\n- 20G SSD\n\n就算那么低的运算能力,平时我的网站也用不到25%的运算能力。应付起啦,绰绰有余。\n\n## 软件\n我采用了`MM-Wiki` 管理平台(以下简称维基平台)。这是一个非常优秀的开源项目,具体请参看[作者的文档](https://github.com/phachon/mm-wiki)。部署超级简单,可以说一键部署,然后就可以用起啦了。简单来说这个平台有以下几个特点:\n- [x] 支持空间管理、空间内支持多级目录。\n- [x] 支持Markdown编辑。\n- [x] 支持附件。\n- [x] 有修改记录。\n- [ ] 不支持内容搜索,只支持笔记的题目搜索。\n- [ ] 标签只支持到空间级别,目录和笔记都没有标签。\n\n但它跟Hexo博客搭配使用,就完全满足我的需求了。其实Hexo博客中,有个仿维基的Wikitten主题,跟`MM-Wiki`项目非常像。但毕竟不是所有内容,都适合摆在公开的地方。以`MM-Wiki` 作为私用平台,增加了私隐保护。\n\n我的做法是,在维基平台中开辟一个独立的空间,用来存放博客上所有的源文件。而在Github Pages上托管的静态网站其实都是HTML文件。所有的改动,都必须在源Markdownn文件上修改,然后再推送到博客网站的。\n\n在维基平台修改、添加、删除笔记的源文件。然后复制到Hexo的项目目录,编译后推送到Github Pages站点。维基百科内置的在线版`Editor.md `编辑器,非常美观实用。基本上我都不太需要在自己的电脑上用Typora等编辑器写MD文本了。思路有了,实现起来还是有一点问题。\n\n# 难点的解决办法\n\n首先,在维基平台内,MD文件是分目录存储的。这个目录不能直接拷贝到Hexo的`_post`目录。懒得每修改一个,或者添加一个笔记,就立马拷贝到博客中去。解决笔记复制的问题。\n\n其次,笔记的物理保存目录,**必须**跟Hexo上的「分类」是一一对应的。否则,管理起来会很麻烦。在维基平台移动了笔记的保存目录后,在一一修改内容,也是很吃力的事情。\n\n## 笔记复制的解决办法\n\n说来也超级简单,一个脚本命令就够了。先用`find`命令在指定目录找出所有的MD文件,然后通过管道传给复制命令`cp`,搞定!\n```sh\nfind /root/bibliothek/markdowns/博客草稿/ -type f -name \"*.md\" -exec cp {} /home/_post/ \\;\n```\n然后`hexo d -g`编译、发布,结束!\n\n## 管理笔记的分类\n\n这个问题有一点麻烦。因为必须打开每一个文件,读取笔记的头文件描述,然后再比较跟文件的物理位置是否符合。我尝试用shell脚本解决这难题。无奈我的的shell脚本功底是在很差,搞半天未果就放弃了。用Java或者.NET Core啥的,正儿八经写一个Console程序,也不是不行。但有种杀鸡用牛刀的感觉。\n\n最后想到了用Javascript。因为编译Hexo是需要安装Node.js的,写一段JavaScript,让Node跑起来。通往罗马的道路千万条,选一条自己最熟悉的就完了。\n\n{% fold 点击查看代码 %}\n\n{% endfold %}\n\n> 上面这个脚本使用的都是我个人设置,你如果要用的话需要改成自己实际文件目录。\n\n![](https://github.com/maiernte/img/raw/master/fun/给力.jpg)","source":"_posts/IT/Web/如何系统化管理Hexo博客.md","raw":"---\ntitle: 如何系统化管理Hexo博客\ndate: 2019-07-28 21:30:00\nurlname: how-to-manage-big-hexo-blog\ntoc: true\ncontentpw: 123456\ntags: [Hexo]\ncategories: [IT, Web]\n\n---\n\n

管理?

\n\n![](https://github.com/maiernte/img/raw/master/fun/what.jpg)\n\n\n\n# 建立博客的初衷\n虽说这篇笔记的题目是「如何管理」,为了更好的回答这个问题,必须要回到最原始问题上来——我为何要建一个博客,而且是费那么大劲。而我的初衷是建立和维护一个属于自己的「知识库」。通常来说,为了达成这个目的,更好的选择是笔记APP,而不是博客。我确实也是这么做的。一开始用印象笔记,因为它死活不支持多级目录,我又转到国内的为知笔记,做了五年的VIP用户。但它五年来似乎从没改进过。随着近年来有道云异军突起,以及IOS生态圈中琳琅满目的APP,如熊掌记、Notion、谷歌的Keep、阿里的语雀。。。。。。各有各的惊艳,各有各的槽点。\n\n随着国外的Github和国内的Coding等公司,相继开放永久免费、不限流量的静态网页托管平台,如Github Pages。我走上了自建Bolg的不归路。当然不是说,搭博客这条路完全没有槽点。而是——自己造的孽,含着泪也会继续造下去。至少它满足了我以下几点「必不可少」的要求:\n\n- [x] 多级目录\n- [x] 支持Markdown文本\n- [x] 支持分类、标签、以及站内全文检索\n- [x] 没有IOS、Windows、Android等平台限制\n\n说白了,我是利用Github提供的免费平台,把Blog当笔记本来用。最后选了Hexo,简单易用、界面绚丽、插件丰富。除开自用的「知识平台」功能以外,偶尔还能发发博文装大尾巴狼,也是蛮不错的感觉。\n\n网上介绍怎么搭建Hexo以及添加绚丽功能的帖子海了去了,但我基本没有发现分享「如何管理」的。因为绝大多数这些博主,搭建Hexo只是用来玩一阵子。回头有更新更好玩的东西,就跑去玩别的了。极少数有博客,站内文章超过50篇的。所以,对他们来说,根本不存在——管理——这个议题。\n\n虽然Hexo在逻辑上支持`分类`和`标签`,但物理上它把所有的Post都放到一个单一的目录下面。而我是打算把它当作知识库,长期、密集使用的。可预见的将来,站内笔记会非常多。不但写新贴,还可能经常更改旧贴。那势必会带来一个问题:如何管理数量少日益膨胀的笔记?\n\n# 解决思路\n\n我能想到的办法很简单,也很传统。就是不但逻辑分类,而且也必须物理上分目录存放。理论上在自己的PC分目录保存就好了。但我有好几台电脑,单位一台、自己Windows一台、Mac一台,还有平板。为了让能在不同的电脑上能随时修改、添加笔记,必须放在托管在云端。\n\n## 硬件\n没有必要租用传统的VPS,太贵了,而且连10%的运算能力都用不上。用共享的Web Hosting就完全能解决需求。比如百度云,或者Azure的Web App。而我是租用 1&1 公司的Web Hosting,每个月 1€\n- 1 CPU\n- 500M 内存\n- 20G SSD\n\n就算那么低的运算能力,平时我的网站也用不到25%的运算能力。应付起啦,绰绰有余。\n\n## 软件\n我采用了`MM-Wiki` 管理平台(以下简称维基平台)。这是一个非常优秀的开源项目,具体请参看[作者的文档](https://github.com/phachon/mm-wiki)。部署超级简单,可以说一键部署,然后就可以用起啦了。简单来说这个平台有以下几个特点:\n- [x] 支持空间管理、空间内支持多级目录。\n- [x] 支持Markdown编辑。\n- [x] 支持附件。\n- [x] 有修改记录。\n- [ ] 不支持内容搜索,只支持笔记的题目搜索。\n- [ ] 标签只支持到空间级别,目录和笔记都没有标签。\n\n但它跟Hexo博客搭配使用,就完全满足我的需求了。其实Hexo博客中,有个仿维基的Wikitten主题,跟`MM-Wiki`项目非常像。但毕竟不是所有内容,都适合摆在公开的地方。以`MM-Wiki` 作为私用平台,增加了私隐保护。\n\n我的做法是,在维基平台中开辟一个独立的空间,用来存放博客上所有的源文件。而在Github Pages上托管的静态网站其实都是HTML文件。所有的改动,都必须在源Markdownn文件上修改,然后再推送到博客网站的。\n\n在维基平台修改、添加、删除笔记的源文件。然后复制到Hexo的项目目录,编译后推送到Github Pages站点。维基百科内置的在线版`Editor.md `编辑器,非常美观实用。基本上我都不太需要在自己的电脑上用Typora等编辑器写MD文本了。思路有了,实现起来还是有一点问题。\n\n# 难点的解决办法\n\n首先,在维基平台内,MD文件是分目录存储的。这个目录不能直接拷贝到Hexo的`_post`目录。懒得每修改一个,或者添加一个笔记,就立马拷贝到博客中去。解决笔记复制的问题。\n\n其次,笔记的物理保存目录,**必须**跟Hexo上的「分类」是一一对应的。否则,管理起来会很麻烦。在维基平台移动了笔记的保存目录后,在一一修改内容,也是很吃力的事情。\n\n## 笔记复制的解决办法\n\n说来也超级简单,一个脚本命令就够了。先用`find`命令在指定目录找出所有的MD文件,然后通过管道传给复制命令`cp`,搞定!\n```sh\nfind /root/bibliothek/markdowns/博客草稿/ -type f -name \"*.md\" -exec cp {} /home/_post/ \\;\n```\n然后`hexo d -g`编译、发布,结束!\n\n## 管理笔记的分类\n\n这个问题有一点麻烦。因为必须打开每一个文件,读取笔记的头文件描述,然后再比较跟文件的物理位置是否符合。我尝试用shell脚本解决这难题。无奈我的的shell脚本功底是在很差,搞半天未果就放弃了。用Java或者.NET Core啥的,正儿八经写一个Console程序,也不是不行。但有种杀鸡用牛刀的感觉。\n\n最后想到了用Javascript。因为编译Hexo是需要安装Node.js的,写一段JavaScript,让Node跑起来。通往罗马的道路千万条,选一条自己最熟悉的就完了。\n\n{% fold 点击查看代码 %}\n\n{% endfold %}\n\n> 上面这个脚本使用的都是我个人设置,你如果要用的话需要改成自己实际文件目录。\n\n![](https://github.com/maiernte/img/raw/master/fun/给力.jpg)","slug":"IT/Web/如何系统化管理Hexo博客","published":1,"updated":"2019-08-15T21:51:57.000Z","_id":"cka1y598b001y4huuppnodfz2","comments":1,"layout":"post","photos":[],"link":"","content":"

建立博客的初衷

\n

虽说这篇笔记的题目是「如何管理」,为了更好的回答这个问题,必须要回到最原始问题上来——我为何要建一个博客,而且是费那么大劲。而我的初衷是建立和维护一个属于自己的「知识库」。通常来说,为了达成这个目的,更好的选择是笔记APP,而不是博客。我确实也是这么做的。一开始用印象笔记,因为它死活不支持多级目录,我又转到国内的为知笔记,做了五年的VIP用户。但它五年来似乎从没改进过。随着近年来有道云异军突起,以及IOS生态圈中琳琅满目的APP,如熊掌记、Notion、谷歌的Keep、阿里的语雀。。。。。。各有各的惊艳,各有各的槽点。

\n

随着国外的Github和国内的Coding等公司,相继开放永久免费、不限流量的静态网页托管平台,如Github Pages。我走上了自建Bolg的不归路。当然不是说,搭博客这条路完全没有槽点。而是——自己造的孽,含着泪也会继续造下去。至少它满足了我以下几点「必不可少」的要求:

\n
    \n
  • [x] 多级目录
  • \n
  • [x] 支持Markdown文本
  • \n
  • [x] 支持分类、标签、以及站内全文检索
  • \n
  • [x] 没有IOS、Windows、Android等平台限制
  • \n
\n

说白了,我是利用Github提供的免费平台,把Blog当笔记本来用。最后选了Hexo,简单易用、界面绚丽、插件丰富。除开自用的「知识平台」功能以外,偶尔还能发发博文装大尾巴狼,也是蛮不错的感觉。

\n

网上介绍怎么搭建Hexo以及添加绚丽功能的帖子海了去了,但我基本没有发现分享「如何管理」的。因为绝大多数这些博主,搭建Hexo只是用来玩一阵子。回头有更新更好玩的东西,就跑去玩别的了。极少数有博客,站内文章超过50篇的。所以,对他们来说,根本不存在——管理——这个议题。

\n

虽然Hexo在逻辑上支持分类标签,但物理上它把所有的Post都放到一个单一的目录下面。而我是打算把它当作知识库,长期、密集使用的。可预见的将来,站内笔记会非常多。不但写新贴,还可能经常更改旧贴。那势必会带来一个问题:如何管理数量少日益膨胀的笔记?

\n

解决思路

\n

我能想到的办法很简单,也很传统。就是不但逻辑分类,而且也必须物理上分目录存放。理论上在自己的PC分目录保存就好了。但我有好几台电脑,单位一台、自己Windows一台、Mac一台,还有平板。为了让能在不同的电脑上能随时修改、添加笔记,必须放在托管在云端。

\n

硬件

\n

没有必要租用传统的VPS,太贵了,而且连10%的运算能力都用不上。用共享的Web Hosting就完全能解决需求。比如百度云,或者Azure的Web App。而我是租用 1&1 公司的Web Hosting,每个月 1€

\n
    \n
  • 1 CPU
  • \n
  • 500M 内存
  • \n
  • 20G SSD
  • \n
\n

就算那么低的运算能力,平时我的网站也用不到25%的运算能力。应付起啦,绰绰有余。

\n

软件

\n

我采用了MM-Wiki 管理平台(以下简称维基平台)。这是一个非常优秀的开源项目,具体请参看作者的文档。部署超级简单,可以说一键部署,然后就可以用起啦了。简单来说这个平台有以下几个特点:

\n
    \n
  • [x] 支持空间管理、空间内支持多级目录。
  • \n
  • [x] 支持Markdown编辑。
  • \n
  • [x] 支持附件。
  • \n
  • [x] 有修改记录。
  • \n
  • [ ] 不支持内容搜索,只支持笔记的题目搜索。
  • \n
  • [ ] 标签只支持到空间级别,目录和笔记都没有标签。
  • \n
\n

但它跟Hexo博客搭配使用,就完全满足我的需求了。其实Hexo博客中,有个仿维基的Wikitten主题,跟MM-Wiki项目非常像。但毕竟不是所有内容,都适合摆在公开的地方。以MM-Wiki 作为私用平台,增加了私隐保护。

\n

我的做法是,在维基平台中开辟一个独立的空间,用来存放博客上所有的源文件。而在Github Pages上托管的静态网站其实都是HTML文件。所有的改动,都必须在源Markdownn文件上修改,然后再推送到博客网站的。

\n

在维基平台修改、添加、删除笔记的源文件。然后复制到Hexo的项目目录,编译后推送到Github Pages站点。维基百科内置的在线版Editor.md 编辑器,非常美观实用。基本上我都不太需要在自己的电脑上用Typora等编辑器写MD文本了。思路有了,实现起来还是有一点问题。

\n

难点的解决办法

\n

首先,在维基平台内,MD文件是分目录存储的。这个目录不能直接拷贝到Hexo的_post目录。懒得每修改一个,或者添加一个笔记,就立马拷贝到博客中去。解决笔记复制的问题。

\n

其次,笔记的物理保存目录,必须跟Hexo上的「分类」是一一对应的。否则,管理起来会很麻烦。在维基平台移动了笔记的保存目录后,在一一修改内容,也是很吃力的事情。

\n

笔记复制的解决办法

\n

说来也超级简单,一个脚本命令就够了。先用find命令在指定目录找出所有的MD文件,然后通过管道传给复制命令cp,搞定!

\n
1
find  /root/bibliothek/markdowns/博客草稿/  -type f -name \"*.md\" -exec cp {} /home/_post/ \\;
\n

然后hexo d -g编译、发布,结束!

\n

管理笔记的分类

\n

这个问题有一点麻烦。因为必须打开每一个文件,读取笔记的头文件描述,然后再比较跟文件的物理位置是否符合。我尝试用shell脚本解决这难题。无奈我的的shell脚本功底是在很差,搞半天未果就放弃了。用Java或者.NET Core啥的,正儿八经写一个Console程序,也不是不行。但有种杀鸡用牛刀的感觉。

\n

最后想到了用Javascript。因为编译Hexo是需要安装Node.js的,写一段JavaScript,让Node跑起来。通往罗马的道路千万条,选一条自己最熟悉的就完了。

\n
点击查看代码
\n\n
\n
\n

上面这个脚本使用的都是我个人设置,你如果要用的话需要改成自己实际文件目录。

\n
\n

","site":{"data":{}},"excerpt":"

管理?

\n

","more":"

建立博客的初衷

\n

虽说这篇笔记的题目是「如何管理」,为了更好的回答这个问题,必须要回到最原始问题上来——我为何要建一个博客,而且是费那么大劲。而我的初衷是建立和维护一个属于自己的「知识库」。通常来说,为了达成这个目的,更好的选择是笔记APP,而不是博客。我确实也是这么做的。一开始用印象笔记,因为它死活不支持多级目录,我又转到国内的为知笔记,做了五年的VIP用户。但它五年来似乎从没改进过。随着近年来有道云异军突起,以及IOS生态圈中琳琅满目的APP,如熊掌记、Notion、谷歌的Keep、阿里的语雀。。。。。。各有各的惊艳,各有各的槽点。

\n

随着国外的Github和国内的Coding等公司,相继开放永久免费、不限流量的静态网页托管平台,如Github Pages。我走上了自建Bolg的不归路。当然不是说,搭博客这条路完全没有槽点。而是——自己造的孽,含着泪也会继续造下去。至少它满足了我以下几点「必不可少」的要求:

\n
    \n
  • [x] 多级目录
  • \n
  • [x] 支持Markdown文本
  • \n
  • [x] 支持分类、标签、以及站内全文检索
  • \n
  • [x] 没有IOS、Windows、Android等平台限制
  • \n
\n

说白了,我是利用Github提供的免费平台,把Blog当笔记本来用。最后选了Hexo,简单易用、界面绚丽、插件丰富。除开自用的「知识平台」功能以外,偶尔还能发发博文装大尾巴狼,也是蛮不错的感觉。

\n

网上介绍怎么搭建Hexo以及添加绚丽功能的帖子海了去了,但我基本没有发现分享「如何管理」的。因为绝大多数这些博主,搭建Hexo只是用来玩一阵子。回头有更新更好玩的东西,就跑去玩别的了。极少数有博客,站内文章超过50篇的。所以,对他们来说,根本不存在——管理——这个议题。

\n

虽然Hexo在逻辑上支持分类标签,但物理上它把所有的Post都放到一个单一的目录下面。而我是打算把它当作知识库,长期、密集使用的。可预见的将来,站内笔记会非常多。不但写新贴,还可能经常更改旧贴。那势必会带来一个问题:如何管理数量少日益膨胀的笔记?

\n

解决思路

\n

我能想到的办法很简单,也很传统。就是不但逻辑分类,而且也必须物理上分目录存放。理论上在自己的PC分目录保存就好了。但我有好几台电脑,单位一台、自己Windows一台、Mac一台,还有平板。为了让能在不同的电脑上能随时修改、添加笔记,必须放在托管在云端。

\n

硬件

\n

没有必要租用传统的VPS,太贵了,而且连10%的运算能力都用不上。用共享的Web Hosting就完全能解决需求。比如百度云,或者Azure的Web App。而我是租用 1&1 公司的Web Hosting,每个月 1€

\n
    \n
  • 1 CPU
  • \n
  • 500M 内存
  • \n
  • 20G SSD
  • \n
\n

就算那么低的运算能力,平时我的网站也用不到25%的运算能力。应付起啦,绰绰有余。

\n

软件

\n

我采用了MM-Wiki 管理平台(以下简称维基平台)。这是一个非常优秀的开源项目,具体请参看作者的文档。部署超级简单,可以说一键部署,然后就可以用起啦了。简单来说这个平台有以下几个特点:

\n
    \n
  • [x] 支持空间管理、空间内支持多级目录。
  • \n
  • [x] 支持Markdown编辑。
  • \n
  • [x] 支持附件。
  • \n
  • [x] 有修改记录。
  • \n
  • [ ] 不支持内容搜索,只支持笔记的题目搜索。
  • \n
  • [ ] 标签只支持到空间级别,目录和笔记都没有标签。
  • \n
\n

但它跟Hexo博客搭配使用,就完全满足我的需求了。其实Hexo博客中,有个仿维基的Wikitten主题,跟MM-Wiki项目非常像。但毕竟不是所有内容,都适合摆在公开的地方。以MM-Wiki 作为私用平台,增加了私隐保护。

\n

我的做法是,在维基平台中开辟一个独立的空间,用来存放博客上所有的源文件。而在Github Pages上托管的静态网站其实都是HTML文件。所有的改动,都必须在源Markdownn文件上修改,然后再推送到博客网站的。

\n

在维基平台修改、添加、删除笔记的源文件。然后复制到Hexo的项目目录,编译后推送到Github Pages站点。维基百科内置的在线版Editor.md 编辑器,非常美观实用。基本上我都不太需要在自己的电脑上用Typora等编辑器写MD文本了。思路有了,实现起来还是有一点问题。

\n

难点的解决办法

\n

首先,在维基平台内,MD文件是分目录存储的。这个目录不能直接拷贝到Hexo的_post目录。懒得每修改一个,或者添加一个笔记,就立马拷贝到博客中去。解决笔记复制的问题。

\n

其次,笔记的物理保存目录,必须跟Hexo上的「分类」是一一对应的。否则,管理起来会很麻烦。在维基平台移动了笔记的保存目录后,在一一修改内容,也是很吃力的事情。

\n

笔记复制的解决办法

\n

说来也超级简单,一个脚本命令就够了。先用find命令在指定目录找出所有的MD文件,然后通过管道传给复制命令cp,搞定!

\n\n

然后hexo d -g编译、发布,结束!

\n

管理笔记的分类

\n

这个问题有一点麻烦。因为必须打开每一个文件,读取笔记的头文件描述,然后再比较跟文件的物理位置是否符合。我尝试用shell脚本解决这难题。无奈我的的shell脚本功底是在很差,搞半天未果就放弃了。用Java或者.NET Core啥的,正儿八经写一个Console程序,也不是不行。但有种杀鸡用牛刀的感觉。

\n

最后想到了用Javascript。因为编译Hexo是需要安装Node.js的,写一段JavaScript,让Node跑起来。通往罗马的道路千万条,选一条自己最熟悉的就完了。

\n
点击查看代码
\n\n
\n
\n

上面这个脚本使用的都是我个人设置,你如果要用的话需要改成自己实际文件目录。

\n
\n

"},{"title":"还在用七牛?","date":"2019-08-14T21:41:28.000Z","urlname":"still-using-qiniu","toc":true,"_content":"\n\n\n自从七牛换了服务条款,每个空间就只分配测试域名, 30天到期。想省钱的用户,必须每30天倒腾一次。如果忘记了,过了期限,据说图都找不回来。不想费那个劲的用户, 得绑定自己的域名。 这样不但增加费用,还要考虑到域名备案。 十分麻烦。\n\n\n\n这是我弃用七牛的主要原因。 第二个原因就是——`慢`! 也许我人在国外的原因吧, 每次打开七牛的后台,刷好几遍都打不开对象存储的页面,只能用第三方软件进行上传下载,那样会相对好一些.\n\n\n\n第三个原因是七牛的图床不能分目录存储。 当图片越积越多的时候,管理和查找起来非常麻烦。比如我昨天用Typora的Pandoc功能将一个Word技术文档转换成MD文件,一个文件就有100来张图。放在七牛得分好几页显示了。如果再想找别的图, 那得多费劲.\n\n\n\n后来还是把心思用在了Github上。 在自己的账号下新开一个仓库, 然后在自己的本地电脑专建立一个文件夹, 用来存放MD文档或者博客中使用到的图片, 把这个专门的文件夹推送到新的仓库就完了! 相比七牛, Github还有不少优势:\n\n- **可以分多级目录存储** \n- **传输速度快** !(*可能国内慢吧, 但国内可以同样的思路, 放到 Coding 或者 CSDN 上* )\n- **免费** \n- **不限流量** \n\n\n\n还要我说啥呢? \n\n\n\n但引用Github图片, 要做一个小小的改动. 比如Github上一个图片的原始地址是:\n\n> https://github.com/maiernte/img/blob/master/books/ng-book2-71/image100.png\n\n需要把其中的 `blob` 改成 `raw`, 变成\n\n> https://github.com/maiernte/img/raw/master/books/ng-book2-71/image100.png\n\n\n\n自打有了Github这个神器, 可以跟七牛说再见! 再也不见!","source":"_posts/IT/skill/还在用七牛.md","raw":"---\ntitle: 还在用七牛?\ndate: 2019-08-14 23:41:28\nurlname: still-using-qiniu\ntoc: true\ntags: [工具]\ncategories: [IT, skill]\n\n---\n\n\n\n自从七牛换了服务条款,每个空间就只分配测试域名, 30天到期。想省钱的用户,必须每30天倒腾一次。如果忘记了,过了期限,据说图都找不回来。不想费那个劲的用户, 得绑定自己的域名。 这样不但增加费用,还要考虑到域名备案。 十分麻烦。\n\n\n\n这是我弃用七牛的主要原因。 第二个原因就是——`慢`! 也许我人在国外的原因吧, 每次打开七牛的后台,刷好几遍都打不开对象存储的页面,只能用第三方软件进行上传下载,那样会相对好一些.\n\n\n\n第三个原因是七牛的图床不能分目录存储。 当图片越积越多的时候,管理和查找起来非常麻烦。比如我昨天用Typora的Pandoc功能将一个Word技术文档转换成MD文件,一个文件就有100来张图。放在七牛得分好几页显示了。如果再想找别的图, 那得多费劲.\n\n\n\n后来还是把心思用在了Github上。 在自己的账号下新开一个仓库, 然后在自己的本地电脑专建立一个文件夹, 用来存放MD文档或者博客中使用到的图片, 把这个专门的文件夹推送到新的仓库就完了! 相比七牛, Github还有不少优势:\n\n- **可以分多级目录存储** \n- **传输速度快** !(*可能国内慢吧, 但国内可以同样的思路, 放到 Coding 或者 CSDN 上* )\n- **免费** \n- **不限流量** \n\n\n\n还要我说啥呢? \n\n\n\n但引用Github图片, 要做一个小小的改动. 比如Github上一个图片的原始地址是:\n\n> https://github.com/maiernte/img/blob/master/books/ng-book2-71/image100.png\n\n需要把其中的 `blob` 改成 `raw`, 变成\n\n> https://github.com/maiernte/img/raw/master/books/ng-book2-71/image100.png\n\n\n\n自打有了Github这个神器, 可以跟七牛说再见! 再也不见!","slug":"IT/skill/还在用七牛","published":1,"updated":"2019-08-15T06:54:53.000Z","_id":"cka1y598d00214huuioh2rw8e","comments":1,"layout":"post","photos":[],"link":"","content":"

自从七牛换了服务条款,每个空间就只分配测试域名, 30天到期。想省钱的用户,必须每30天倒腾一次。如果忘记了,过了期限,据说图都找不回来。不想费那个劲的用户, 得绑定自己的域名。 这样不但增加费用,还要考虑到域名备案。 十分麻烦。

\n\n

这是我弃用七牛的主要原因。 第二个原因就是——! 也许我人在国外的原因吧, 每次打开七牛的后台,刷好几遍都打不开对象存储的页面,只能用第三方软件进行上传下载,那样会相对好一些.

\n

第三个原因是七牛的图床不能分目录存储。 当图片越积越多的时候,管理和查找起来非常麻烦。比如我昨天用Typora的Pandoc功能将一个Word技术文档转换成MD文件,一个文件就有100来张图。放在七牛得分好几页显示了。如果再想找别的图, 那得多费劲.

\n

后来还是把心思用在了Github上。 在自己的账号下新开一个仓库, 然后在自己的本地电脑专建立一个文件夹, 用来存放MD文档或者博客中使用到的图片, 把这个专门的文件夹推送到新的仓库就完了! 相比七牛, Github还有不少优势:

\n
    \n
  • 可以分多级目录存储
  • \n
  • 传输速度快 !(可能国内慢吧, 但国内可以同样的思路, 放到 Coding 或者 CSDN 上 )
  • \n
  • 免费
  • \n
  • 不限流量
  • \n
\n

还要我说啥呢?

\n

但引用Github图片, 要做一个小小的改动. 比如Github上一个图片的原始地址是:

\n
\n

https://github.com/maiernte/img/blob/master/books/ng-book2-71/image100.png

\n
\n

需要把其中的 blob 改成 raw, 变成

\n
\n

https://github.com/maiernte/img/raw/master/books/ng-book2-71/image100.png

\n
\n

自打有了Github这个神器, 可以跟七牛说再见! 再也不见!

\n","site":{"data":{}},"excerpt":"

自从七牛换了服务条款,每个空间就只分配测试域名, 30天到期。想省钱的用户,必须每30天倒腾一次。如果忘记了,过了期限,据说图都找不回来。不想费那个劲的用户, 得绑定自己的域名。 这样不但增加费用,还要考虑到域名备案。 十分麻烦。

","more":"

这是我弃用七牛的主要原因。 第二个原因就是——! 也许我人在国外的原因吧, 每次打开七牛的后台,刷好几遍都打不开对象存储的页面,只能用第三方软件进行上传下载,那样会相对好一些.

\n

第三个原因是七牛的图床不能分目录存储。 当图片越积越多的时候,管理和查找起来非常麻烦。比如我昨天用Typora的Pandoc功能将一个Word技术文档转换成MD文件,一个文件就有100来张图。放在七牛得分好几页显示了。如果再想找别的图, 那得多费劲.

\n

后来还是把心思用在了Github上。 在自己的账号下新开一个仓库, 然后在自己的本地电脑专建立一个文件夹, 用来存放MD文档或者博客中使用到的图片, 把这个专门的文件夹推送到新的仓库就完了! 相比七牛, Github还有不少优势:

\n
    \n
  • 可以分多级目录存储
  • \n
  • 传输速度快 !(可能国内慢吧, 但国内可以同样的思路, 放到 Coding 或者 CSDN 上 )
  • \n
  • 免费
  • \n
  • 不限流量
  • \n
\n

还要我说啥呢?

\n

但引用Github图片, 要做一个小小的改动. 比如Github上一个图片的原始地址是:

\n
\n

https://github.com/maiernte/img/blob/master/books/ng-book2-71/image100.png

\n
\n

需要把其中的 blob 改成 raw, 变成

\n
\n

https://github.com/maiernte/img/raw/master/books/ng-book2-71/image100.png

\n
\n

自打有了Github这个神器, 可以跟七牛说再见! 再也不见!

"},{"title":"佛偈集合","date":"2019-07-29T07:10:50.000Z","urlname":"budahlisisch-poeim-collection","toc":true,"notshow":false,"_content":"\n
佛偈(jì)
\n\n\n![](https://raw.githubusercontent.com/maiernte/img/master/collection/tempel_3.jpg)\n\n\n\n虚云老和尚悟道偈\n\n杯子扑落地,响声明历历。\n虚空粉碎也,狂心当下息。\n\n烫着手,打碎杯,家破人亡语难开。\n春到花香处处秀,山河大地是如来。\n\n\n\n###### 布袋和尚\n\n手把青秧插满田,低头便见水中天。\n心地清净方为道,退步原来是向前。\n\n###### 赠药山高僧惟俨\n\n练得身形似鹤形,千株松下两函经。\n我来问道无馀说,云在青天水在瓶。\n\n——李翱 \n\n###### 牛头山法融禅师\n\n恰恰用心时,恰恰无心用。曲谭名相劳,直说无繁重。\n无心恰恰用,常用恰恰无。今说无心处,不与有心殊。\n\n——唐永徽年中\n\n###### 天衣义怀禅师\n\n雁过长空,影沉寒底,雁无留影之心,影无遗踪之意。\n\n> 《菜根谭》中的一句古诗:“风来疏竹,风过而竹不留声;雁渡寒潭,雁过而潭不留影。\n>\n> 另一版本:竹影扫阶尘不动,雁过寒潭水无痕。\n\n","source":"_posts/摘录/片段/佛偈集合.md","raw":"---\ntitle: 佛偈集合\ndate: 2019-07-29 09:10:50\nurlname: budahlisisch-poeim-collection\ntoc: true\ntags: [文学]\ncategories: [摘录, 片段]\nnotshow: false\n\n---\n\n
佛偈(jì)
\n\n\n![](https://raw.githubusercontent.com/maiernte/img/master/collection/tempel_3.jpg)\n\n\n\n虚云老和尚悟道偈\n\n杯子扑落地,响声明历历。\n虚空粉碎也,狂心当下息。\n\n烫着手,打碎杯,家破人亡语难开。\n春到花香处处秀,山河大地是如来。\n\n\n\n###### 布袋和尚\n\n手把青秧插满田,低头便见水中天。\n心地清净方为道,退步原来是向前。\n\n###### 赠药山高僧惟俨\n\n练得身形似鹤形,千株松下两函经。\n我来问道无馀说,云在青天水在瓶。\n\n——李翱 \n\n###### 牛头山法融禅师\n\n恰恰用心时,恰恰无心用。曲谭名相劳,直说无繁重。\n无心恰恰用,常用恰恰无。今说无心处,不与有心殊。\n\n——唐永徽年中\n\n###### 天衣义怀禅师\n\n雁过长空,影沉寒底,雁无留影之心,影无遗踪之意。\n\n> 《菜根谭》中的一句古诗:“风来疏竹,风过而竹不留声;雁渡寒潭,雁过而潭不留影。\n>\n> 另一版本:竹影扫阶尘不动,雁过寒潭水无痕。\n\n","slug":"摘录/片段/佛偈集合","published":1,"updated":"2019-08-15T21:46:14.000Z","_id":"cka1y598f00254huufdsy7udi","comments":1,"layout":"post","photos":[],"link":"","content":"
佛偈(jì)
\n

\n

虚云老和尚悟道偈

\n

杯子扑落地,响声明历历。
\n虚空粉碎也,狂心当下息。

\n

烫着手,打碎杯,家破人亡语难开。
\n春到花香处处秀,山河大地是如来。

\n\n
布袋和尚
\n

手把青秧插满田,低头便见水中天。
\n心地清净方为道,退步原来是向前。

\n
赠药山高僧惟俨
\n

练得身形似鹤形,千株松下两函经。
\n我来问道无馀说,云在青天水在瓶。

\n

——李翱

\n
牛头山法融禅师
\n

恰恰用心时,恰恰无心用。曲谭名相劳,直说无繁重。
\n无心恰恰用,常用恰恰无。今说无心处,不与有心殊。

\n

——唐永徽年中

\n
天衣义怀禅师
\n

雁过长空,影沉寒底,雁无留影之心,影无遗踪之意。

\n
\n

《菜根谭》中的一句古诗:“风来疏竹,风过而竹不留声;雁渡寒潭,雁过而潭不留影。

\n

另一版本:竹影扫阶尘不动,雁过寒潭水无痕。

\n
\n","site":{"data":{}},"excerpt":"
佛偈(jì)
\n

\n

虚云老和尚悟道偈

\n

杯子扑落地,响声明历历。
\n虚空粉碎也,狂心当下息。

\n

烫着手,打碎杯,家破人亡语难开。
\n春到花香处处秀,山河大地是如来。

","more":"
布袋和尚
\n

手把青秧插满田,低头便见水中天。
\n心地清净方为道,退步原来是向前。

\n
赠药山高僧惟俨
\n

练得身形似鹤形,千株松下两函经。
\n我来问道无馀说,云在青天水在瓶。

\n

——李翱

\n
牛头山法融禅师
\n

恰恰用心时,恰恰无心用。曲谭名相劳,直说无繁重。
\n无心恰恰用,常用恰恰无。今说无心处,不与有心殊。

\n

——唐永徽年中

\n
天衣义怀禅师
\n

雁过长空,影沉寒底,雁无留影之心,影无遗踪之意。

\n
\n

《菜根谭》中的一句古诗:“风来疏竹,风过而竹不留声;雁渡寒潭,雁过而潭不留影。

\n

另一版本:竹影扫阶尘不动,雁过寒潭水无痕。

\n
"},{"title":"搞笑段子","date":"2019-07-29T06:40:50.000Z","urlname":"funny-things-collection","toc":true,"notshow":true,"_content":"\n###### 慢慢就习惯了\n\n某人四十多岁了还碌碌无为,于是跑去找算命先生。算命先生掐指一算,然后问:“一个好消息,一个坏消息,你先听哪个?”哥们说:“那就先听坏的吧”。算命先生说:“坏消息是,你四十岁之前穷困潦倒……”那哥们眉头一挑,问:“那好消息呢?”算命先生幽幽的说到:“四十岁以后,你就习惯了。”\n\n\n\n###### 身体就像一辆车子\n\n身体就像一辆车子,还新的时候,遇到问题花点钱修理一下,就又能风驰电掣。车子越旧,修理费越高。旧到不行了,修理费比换辆新的还贵,还修个啥劲?你「身体」这家企业,当对它的投入远大于产出的时候,上帝都要考虑撤资了,你还拼命追加投资?\n\n###### 凌凌漆\n\n外景:深圳某一市场猪肉摊前。 \n某女甲:你以为你匿喺度就揾唔到你咩? 冇用架! 你啲咁出色嘅难忍(男人),无论喺边度,都好似漆黑中嘅萤火虫一样,咁鲜明,咁出众。 你忧郁嘅眼神,唏嘘嘅须根,神乎其技嘅刀法,同埋嗰杯Dry Martine,都彻底噉将你出卖咗。 不过,你虽然系咁出色,始终行有行规,无论典(点)你都要找埋寻晚嗰条过夜数,叫鸡唔使畀钱呀? \n凌凌漆:我重估我哋嘅交往系建筑喺感情之上,估唔到,原来都系一盘生意。 \n某女甲:讲感情都要畀钱架。 \n凌凌漆:明白嘅,有一早畀咗你啦。 但系近排兴食斋,冇乜人帮衬,不如噉啦,攞篘猪肉返去顶住数先啦。 嚟吖,粗粗地,唔该。 \n某女甲:你好嘢,山水有山逢。 (某女甲提猪肉转身走。) \n凌凌漆: \n有兴趣嘅不如今天再相逢啦。 \n(某女甲把猪肉投向凌凌漆) \n凌凌漆(用刀接住猪肉):悭番。 (顺势将猪肉切成两半,挂喺猪肉钩上) \n某女乙:咩话? 个衰佬唔肯畀钱? 我帮你拖马喐佢! \n某女甲:算啦,话到尾,佢始终都系一个独一无二、风度翩翩嘅猪肉佬。 \n(阿漆依着猪肉摊,品着白兰地。) \n\n###### 情人节广告\n\n14号晚报名打麻将,只报不打,报名费100元,报完名爱干嘛干嘛,爱去哪去哪,爱跟谁跟谁。本人承诺:保证任何人问你的行踪都可以证明你跟我一起打麻将了,你所有报不了的花费都可以说成是被我赢了,具体时间为2月14日17点至凌晨2点,时间地点任选。额外业务:如支付200元,还提供大牌合照以及朋友圈回复业务,做戏做全套!小本经营,童叟无欺!有意者私聊。","source":"_posts/摘录/娱乐/搞笑段子.md","raw":"---\ntitle: 搞笑段子\ndate: 2019-07-29 08:40:50\nurlname: funny-things-collection\ntoc: true\ntags: [娱乐]\ncategories: [摘录, 娱乐]\nnotshow: true\n\n---\n\n###### 慢慢就习惯了\n\n某人四十多岁了还碌碌无为,于是跑去找算命先生。算命先生掐指一算,然后问:“一个好消息,一个坏消息,你先听哪个?”哥们说:“那就先听坏的吧”。算命先生说:“坏消息是,你四十岁之前穷困潦倒……”那哥们眉头一挑,问:“那好消息呢?”算命先生幽幽的说到:“四十岁以后,你就习惯了。”\n\n\n\n###### 身体就像一辆车子\n\n身体就像一辆车子,还新的时候,遇到问题花点钱修理一下,就又能风驰电掣。车子越旧,修理费越高。旧到不行了,修理费比换辆新的还贵,还修个啥劲?你「身体」这家企业,当对它的投入远大于产出的时候,上帝都要考虑撤资了,你还拼命追加投资?\n\n###### 凌凌漆\n\n外景:深圳某一市场猪肉摊前。 \n某女甲:你以为你匿喺度就揾唔到你咩? 冇用架! 你啲咁出色嘅难忍(男人),无论喺边度,都好似漆黑中嘅萤火虫一样,咁鲜明,咁出众。 你忧郁嘅眼神,唏嘘嘅须根,神乎其技嘅刀法,同埋嗰杯Dry Martine,都彻底噉将你出卖咗。 不过,你虽然系咁出色,始终行有行规,无论典(点)你都要找埋寻晚嗰条过夜数,叫鸡唔使畀钱呀? \n凌凌漆:我重估我哋嘅交往系建筑喺感情之上,估唔到,原来都系一盘生意。 \n某女甲:讲感情都要畀钱架。 \n凌凌漆:明白嘅,有一早畀咗你啦。 但系近排兴食斋,冇乜人帮衬,不如噉啦,攞篘猪肉返去顶住数先啦。 嚟吖,粗粗地,唔该。 \n某女甲:你好嘢,山水有山逢。 (某女甲提猪肉转身走。) \n凌凌漆: \n有兴趣嘅不如今天再相逢啦。 \n(某女甲把猪肉投向凌凌漆) \n凌凌漆(用刀接住猪肉):悭番。 (顺势将猪肉切成两半,挂喺猪肉钩上) \n某女乙:咩话? 个衰佬唔肯畀钱? 我帮你拖马喐佢! \n某女甲:算啦,话到尾,佢始终都系一个独一无二、风度翩翩嘅猪肉佬。 \n(阿漆依着猪肉摊,品着白兰地。) \n\n###### 情人节广告\n\n14号晚报名打麻将,只报不打,报名费100元,报完名爱干嘛干嘛,爱去哪去哪,爱跟谁跟谁。本人承诺:保证任何人问你的行踪都可以证明你跟我一起打麻将了,你所有报不了的花费都可以说成是被我赢了,具体时间为2月14日17点至凌晨2点,时间地点任选。额外业务:如支付200元,还提供大牌合照以及朋友圈回复业务,做戏做全套!小本经营,童叟无欺!有意者私聊。","slug":"摘录/娱乐/搞笑段子","published":1,"updated":"2019-07-31T03:51:35.000Z","_id":"cka1y598g00294huuytpjchoh","comments":1,"layout":"post","photos":[],"link":"","content":"
慢慢就习惯了
\n

某人四十多岁了还碌碌无为,于是跑去找算命先生。算命先生掐指一算,然后问:“一个好消息,一个坏消息,你先听哪个?”哥们说:“那就先听坏的吧”。算命先生说:“坏消息是,你四十岁之前穷困潦倒……”那哥们眉头一挑,问:“那好消息呢?”算命先生幽幽的说到:“四十岁以后,你就习惯了。”

\n\n
身体就像一辆车子
\n

身体就像一辆车子,还新的时候,遇到问题花点钱修理一下,就又能风驰电掣。车子越旧,修理费越高。旧到不行了,修理费比换辆新的还贵,还修个啥劲?你「身体」这家企业,当对它的投入远大于产出的时候,上帝都要考虑撤资了,你还拼命追加投资?

\n
凌凌漆
\n

外景:深圳某一市场猪肉摊前。
\n某女甲:你以为你匿喺度就揾唔到你咩? 冇用架! 你啲咁出色嘅难忍(男人),无论喺边度,都好似漆黑中嘅萤火虫一样,咁鲜明,咁出众。 你忧郁嘅眼神,唏嘘嘅须根,神乎其技嘅刀法,同埋嗰杯Dry Martine,都彻底噉将你出卖咗。 不过,你虽然系咁出色,始终行有行规,无论典(点)你都要找埋寻晚嗰条过夜数,叫鸡唔使畀钱呀?
\n凌凌漆:我重估我哋嘅交往系建筑喺感情之上,估唔到,原来都系一盘生意。
\n某女甲:讲感情都要畀钱架。
\n凌凌漆:明白嘅,有一早畀咗你啦。 但系近排兴食斋,冇乜人帮衬,不如噉啦,攞篘猪肉返去顶住数先啦。 嚟吖,粗粗地,唔该。
\n某女甲:你好嘢,山水有山逢。 (某女甲提猪肉转身走。)
\n凌凌漆:
\n有兴趣嘅不如今天再相逢啦。
\n(某女甲把猪肉投向凌凌漆)
\n凌凌漆(用刀接住猪肉):悭番。 (顺势将猪肉切成两半,挂喺猪肉钩上)
\n某女乙:咩话? 个衰佬唔肯畀钱? 我帮你拖马喐佢!
\n某女甲:算啦,话到尾,佢始终都系一个独一无二、风度翩翩嘅猪肉佬。
\n(阿漆依着猪肉摊,品着白兰地。)

\n
情人节广告
\n

14号晚报名打麻将,只报不打,报名费100元,报完名爱干嘛干嘛,爱去哪去哪,爱跟谁跟谁。本人承诺:保证任何人问你的行踪都可以证明你跟我一起打麻将了,你所有报不了的花费都可以说成是被我赢了,具体时间为2月14日17点至凌晨2点,时间地点任选。额外业务:如支付200元,还提供大牌合照以及朋友圈回复业务,做戏做全套!小本经营,童叟无欺!有意者私聊。

\n","site":{"data":{}},"excerpt":"
慢慢就习惯了
\n

某人四十多岁了还碌碌无为,于是跑去找算命先生。算命先生掐指一算,然后问:“一个好消息,一个坏消息,你先听哪个?”哥们说:“那就先听坏的吧”。算命先生说:“坏消息是,你四十岁之前穷困潦倒……”那哥们眉头一挑,问:“那好消息呢?”算命先生幽幽的说到:“四十岁以后,你就习惯了。”

","more":"
身体就像一辆车子
\n

身体就像一辆车子,还新的时候,遇到问题花点钱修理一下,就又能风驰电掣。车子越旧,修理费越高。旧到不行了,修理费比换辆新的还贵,还修个啥劲?你「身体」这家企业,当对它的投入远大于产出的时候,上帝都要考虑撤资了,你还拼命追加投资?

\n
凌凌漆
\n

外景:深圳某一市场猪肉摊前。
\n某女甲:你以为你匿喺度就揾唔到你咩? 冇用架! 你啲咁出色嘅难忍(男人),无论喺边度,都好似漆黑中嘅萤火虫一样,咁鲜明,咁出众。 你忧郁嘅眼神,唏嘘嘅须根,神乎其技嘅刀法,同埋嗰杯Dry Martine,都彻底噉将你出卖咗。 不过,你虽然系咁出色,始终行有行规,无论典(点)你都要找埋寻晚嗰条过夜数,叫鸡唔使畀钱呀?
\n凌凌漆:我重估我哋嘅交往系建筑喺感情之上,估唔到,原来都系一盘生意。
\n某女甲:讲感情都要畀钱架。
\n凌凌漆:明白嘅,有一早畀咗你啦。 但系近排兴食斋,冇乜人帮衬,不如噉啦,攞篘猪肉返去顶住数先啦。 嚟吖,粗粗地,唔该。
\n某女甲:你好嘢,山水有山逢。 (某女甲提猪肉转身走。)
\n凌凌漆:
\n有兴趣嘅不如今天再相逢啦。
\n(某女甲把猪肉投向凌凌漆)
\n凌凌漆(用刀接住猪肉):悭番。 (顺势将猪肉切成两半,挂喺猪肉钩上)
\n某女乙:咩话? 个衰佬唔肯畀钱? 我帮你拖马喐佢!
\n某女甲:算啦,话到尾,佢始终都系一个独一无二、风度翩翩嘅猪肉佬。
\n(阿漆依着猪肉摊,品着白兰地。)

\n
情人节广告
\n

14号晚报名打麻将,只报不打,报名费100元,报完名爱干嘛干嘛,爱去哪去哪,爱跟谁跟谁。本人承诺:保证任何人问你的行踪都可以证明你跟我一起打麻将了,你所有报不了的花费都可以说成是被我赢了,具体时间为2月14日17点至凌晨2点,时间地点任选。额外业务:如支付200元,还提供大牌合照以及朋友圈回复业务,做戏做全套!小本经营,童叟无欺!有意者私聊。

"},{"title":"名人语录","date":"2019-07-29T06:40:50.000Z","urlname":"prominaent-slogen-collection","toc":true,"notshow":true,"_content":"\n###### 祈祷文\n\n- 上帝,请赐予我平静让我可以接受我所不能改变的,赐予我勇气让我可以改变我能够改变的,赐予我智慧以分辨这二者的不同。\n- God grand me the serenity to accept the things I cannot change, Courage to change the things I can, and wisdom to know the difference.\n\n###### 尼采\n\nHe who has a strong enough why can bear almost any how. – Friedrich Nietzsche \n\n###### 苏格拉底\n\nBeware the barrenness of a busy life. – Socrates \n\n###### 亚里士多德\n\nWe are what we repeatedly do. Excellence, then, is not an act, but a habit. – Aristotle \n\n###### 维克多 弗兰克\n\n人所拥有的任何东西都可以被剥夺,唯独人性最后的自由——也就是在任何境遇中选择一己态度和生活方式的自由——不能被剥夺。\n\n###### 马克吐温\n\n让你陷入困境的并不是这个世界;真正让你陷入困境的,是这个世界最终并非你所想象。\n\n###### 赛斯\n\n每一个心愿都预设了对于一个缺憾的承认,每一个挑战也预设了有一个要征服的阻碍。\n\n###### 叔本华\n\n痛苦和无聊是人类幸福的两个死敌。欲望不满足就痛苦,满足就无聊。人生如同钟摆在痛苦和无聊两个极点之间摆动。离开一个极点就意味着正在走向另一个极点。\n\n###### 谚语\n\nDon’t shoot the messenger.\n英文有句谚语叫“不要枪毙信使”。枪毙信使并不能改变坏消息。\n\n###### 曾国藩\n\n- 既往不恋,当下不染, 未来不迎。天涯:染,不被当下的情绪感染。要跳出情绪来观察当下。\n- 倚天照海花无数, 流水高山心自知。\n- 久利之事勿为,众争之地勿往。\n- 勿以小恶弃人大美, 勿以小怨忘人大恩。\n\n###### 宗棠\n\n人生最不幸處,是偶一失言而禍不及,偶一失謀而事倖成,偶一恣行而獲小利, 後乃視為故常,而恬不為意。則莫大之患,由此生矣。\n\n###### 俞敏洪\n\n优秀是一种习惯。","source":"_posts/摘录/片段/名人语录.md","raw":"---\ntitle: 名人语录\ndate: 2019-07-29 08:40:50\nurlname: prominaent-slogen-collection\ntoc: true\ntags: [文学]\ncategories: [摘录, 片段]\nnotshow: true\n\n---\n\n###### 祈祷文\n\n- 上帝,请赐予我平静让我可以接受我所不能改变的,赐予我勇气让我可以改变我能够改变的,赐予我智慧以分辨这二者的不同。\n- God grand me the serenity to accept the things I cannot change, Courage to change the things I can, and wisdom to know the difference.\n\n###### 尼采\n\nHe who has a strong enough why can bear almost any how. – Friedrich Nietzsche \n\n###### 苏格拉底\n\nBeware the barrenness of a busy life. – Socrates \n\n###### 亚里士多德\n\nWe are what we repeatedly do. Excellence, then, is not an act, but a habit. – Aristotle \n\n###### 维克多 弗兰克\n\n人所拥有的任何东西都可以被剥夺,唯独人性最后的自由——也就是在任何境遇中选择一己态度和生活方式的自由——不能被剥夺。\n\n###### 马克吐温\n\n让你陷入困境的并不是这个世界;真正让你陷入困境的,是这个世界最终并非你所想象。\n\n###### 赛斯\n\n每一个心愿都预设了对于一个缺憾的承认,每一个挑战也预设了有一个要征服的阻碍。\n\n###### 叔本华\n\n痛苦和无聊是人类幸福的两个死敌。欲望不满足就痛苦,满足就无聊。人生如同钟摆在痛苦和无聊两个极点之间摆动。离开一个极点就意味着正在走向另一个极点。\n\n###### 谚语\n\nDon’t shoot the messenger.\n英文有句谚语叫“不要枪毙信使”。枪毙信使并不能改变坏消息。\n\n###### 曾国藩\n\n- 既往不恋,当下不染, 未来不迎。天涯:染,不被当下的情绪感染。要跳出情绪来观察当下。\n- 倚天照海花无数, 流水高山心自知。\n- 久利之事勿为,众争之地勿往。\n- 勿以小恶弃人大美, 勿以小怨忘人大恩。\n\n###### 宗棠\n\n人生最不幸處,是偶一失言而禍不及,偶一失謀而事倖成,偶一恣行而獲小利, 後乃視為故常,而恬不為意。則莫大之患,由此生矣。\n\n###### 俞敏洪\n\n优秀是一种习惯。","slug":"摘录/片段/名人语录","published":1,"updated":"2019-07-31T03:51:35.000Z","_id":"cka1y598i002d4huu06onppzf","comments":1,"layout":"post","photos":[],"link":"","content":"
祈祷文
\n
    \n
  • 上帝,请赐予我平静让我可以接受我所不能改变的,赐予我勇气让我可以改变我能够改变的,赐予我智慧以分辨这二者的不同。
  • \n
  • God grand me the serenity to accept the things I cannot change, Courage to change the things I can, and wisdom to know the difference.
  • \n
\n
尼采
\n

He who has a strong enough why can bear almost any how. – Friedrich Nietzsche

\n
苏格拉底
\n

Beware the barrenness of a busy life. – Socrates

\n
亚里士多德
\n

We are what we repeatedly do. Excellence, then, is not an act, but a habit. – Aristotle

\n
维克多 弗兰克
\n

人所拥有的任何东西都可以被剥夺,唯独人性最后的自由——也就是在任何境遇中选择一己态度和生活方式的自由——不能被剥夺。

\n
马克吐温
\n

让你陷入困境的并不是这个世界;真正让你陷入困境的,是这个世界最终并非你所想象。

\n
赛斯
\n

每一个心愿都预设了对于一个缺憾的承认,每一个挑战也预设了有一个要征服的阻碍。

\n
叔本华
\n

痛苦和无聊是人类幸福的两个死敌。欲望不满足就痛苦,满足就无聊。人生如同钟摆在痛苦和无聊两个极点之间摆动。离开一个极点就意味着正在走向另一个极点。

\n
谚语
\n

Don’t shoot the messenger.
\n英文有句谚语叫“不要枪毙信使”。枪毙信使并不能改变坏消息。

\n
曾国藩
\n
    \n
  • 既往不恋,当下不染, 未来不迎。天涯:染,不被当下的情绪感染。要跳出情绪来观察当下。
  • \n
  • 倚天照海花无数, 流水高山心自知。
  • \n
  • 久利之事勿为,众争之地勿往。
  • \n
  • 勿以小恶弃人大美, 勿以小怨忘人大恩。
  • \n
\n
宗棠
\n

人生最不幸處,是偶一失言而禍不及,偶一失謀而事倖成,偶一恣行而獲小利, 後乃視為故常,而恬不為意。則莫大之患,由此生矣。

\n
俞敏洪
\n

优秀是一种习惯。

\n","site":{"data":{}},"excerpt":"","more":"
祈祷文
\n
    \n
  • 上帝,请赐予我平静让我可以接受我所不能改变的,赐予我勇气让我可以改变我能够改变的,赐予我智慧以分辨这二者的不同。
  • \n
  • God grand me the serenity to accept the things I cannot change, Courage to change the things I can, and wisdom to know the difference.
  • \n
\n
尼采
\n

He who has a strong enough why can bear almost any how. – Friedrich Nietzsche

\n
苏格拉底
\n

Beware the barrenness of a busy life. – Socrates

\n
亚里士多德
\n

We are what we repeatedly do. Excellence, then, is not an act, but a habit. – Aristotle

\n
维克多 弗兰克
\n

人所拥有的任何东西都可以被剥夺,唯独人性最后的自由——也就是在任何境遇中选择一己态度和生活方式的自由——不能被剥夺。

\n
马克吐温
\n

让你陷入困境的并不是这个世界;真正让你陷入困境的,是这个世界最终并非你所想象。

\n
赛斯
\n

每一个心愿都预设了对于一个缺憾的承认,每一个挑战也预设了有一个要征服的阻碍。

\n
叔本华
\n

痛苦和无聊是人类幸福的两个死敌。欲望不满足就痛苦,满足就无聊。人生如同钟摆在痛苦和无聊两个极点之间摆动。离开一个极点就意味着正在走向另一个极点。

\n
谚语
\n

Don’t shoot the messenger.
\n英文有句谚语叫“不要枪毙信使”。枪毙信使并不能改变坏消息。

\n
曾国藩
\n
    \n
  • 既往不恋,当下不染, 未来不迎。天涯:染,不被当下的情绪感染。要跳出情绪来观察当下。
  • \n
  • 倚天照海花无数, 流水高山心自知。
  • \n
  • 久利之事勿为,众争之地勿往。
  • \n
  • 勿以小恶弃人大美, 勿以小怨忘人大恩。
  • \n
\n
宗棠
\n

人生最不幸處,是偶一失言而禍不及,偶一失謀而事倖成,偶一恣行而獲小利, 後乃視為故常,而恬不為意。則莫大之患,由此生矣。

\n
俞敏洪
\n

优秀是一种习惯。

\n"},{"title":"零散句子","date":"2019-07-29T06:50:50.000Z","urlname":"funny-sloga-collection","toc":true,"notshow":true,"_content":"\n###### 幸福的路有两条\n\n中岛美雪写的歌《幸福》(任贤齐翻唱的伤心太平洋):到幸福的路有两条,一条是所有愿望都成真,另外一条是把愿望这东西扔掉。\n\n\n\n###### Matrix\n\n> Cypher: You know, I know this steak doesn't exist. I know that when I put it in my mounth, the Matrix is telling my brain that it is ..... juicy and delicious. After nine years, you know what I realize? en ...... Ignorance is bliss\n\n###### 几个顺口溜\n\n- 认认真真说假话,扎扎实实走过场。\n- 失败乃成功之母——失败生了100个孩子,其中一个叫「成功」,其它99个还叫「失败」。\n- “人类一思考,上帝就发笑。” —— “你一说要学什么东西,人们就发笑。”\n- 晚上想想千条路,早上起来走原路。(有个共同特点:不困难、不痛苦)\n- 暂时的失败要比暂时的成功要好得多。\n- 别让「半途而废」 成为你唯一坚持下来的事情。\n- 世上没有听一遍就管用的道理。\n- (你的脑袋)不要做别人思想的跑马场。\n- 路是自己走的,脚上的泡也是自己好的。\n- 忍一时越想越气,退一步越想越亏。(总是忍的人,从来都不开心。总是退让的人,却从来没有真的海阔天空)\n- 遇到烂事不纠结,遇到烂人不纠缠。\n- 每个人都想努力做,却总是做不好。\n- 曹操评袁绍:「色厉胆薄,好谋无断,干大事而惜身,见小利而忘命。」","source":"_posts/摘录/片段/零散句子.md","raw":"---\ntitle: 零散句子\ndate: 2019-07-29 08:50:50\nurlname: funny-sloga-collection\ntoc: true\ntags: [文学]\ncategories: [摘录, 片段]\nnotshow: true\n\n---\n\n###### 幸福的路有两条\n\n中岛美雪写的歌《幸福》(任贤齐翻唱的伤心太平洋):到幸福的路有两条,一条是所有愿望都成真,另外一条是把愿望这东西扔掉。\n\n\n\n###### Matrix\n\n> Cypher: You know, I know this steak doesn't exist. I know that when I put it in my mounth, the Matrix is telling my brain that it is ..... juicy and delicious. After nine years, you know what I realize? en ...... Ignorance is bliss\n\n###### 几个顺口溜\n\n- 认认真真说假话,扎扎实实走过场。\n- 失败乃成功之母——失败生了100个孩子,其中一个叫「成功」,其它99个还叫「失败」。\n- “人类一思考,上帝就发笑。” —— “你一说要学什么东西,人们就发笑。”\n- 晚上想想千条路,早上起来走原路。(有个共同特点:不困难、不痛苦)\n- 暂时的失败要比暂时的成功要好得多。\n- 别让「半途而废」 成为你唯一坚持下来的事情。\n- 世上没有听一遍就管用的道理。\n- (你的脑袋)不要做别人思想的跑马场。\n- 路是自己走的,脚上的泡也是自己好的。\n- 忍一时越想越气,退一步越想越亏。(总是忍的人,从来都不开心。总是退让的人,却从来没有真的海阔天空)\n- 遇到烂事不纠结,遇到烂人不纠缠。\n- 每个人都想努力做,却总是做不好。\n- 曹操评袁绍:「色厉胆薄,好谋无断,干大事而惜身,见小利而忘命。」","slug":"摘录/片段/零散句子","published":1,"updated":"2019-08-04T18:15:28.000Z","_id":"cka1y598k002h4huuc3fgsb7o","comments":1,"layout":"post","photos":[],"link":"","content":"
幸福的路有两条
\n

中岛美雪写的歌《幸福》(任贤齐翻唱的伤心太平洋):到幸福的路有两条,一条是所有愿望都成真,另外一条是把愿望这东西扔掉。

\n\n
Matrix
\n
\n

Cypher: You know, I know this steak doesn’t exist. I know that when I put it in my mounth, the Matrix is telling my brain that it is … juicy and delicious. After nine years, you know what I realize? en … Ignorance is bliss

\n
\n
几个顺口溜
\n
    \n
  • 认认真真说假话,扎扎实实走过场。
  • \n
  • 失败乃成功之母——失败生了100个孩子,其中一个叫「成功」,其它99个还叫「失败」。
  • \n
  • “人类一思考,上帝就发笑。” —— “你一说要学什么东西,人们就发笑。”
  • \n
  • 晚上想想千条路,早上起来走原路。(有个共同特点:不困难、不痛苦)
  • \n
  • 暂时的失败要比暂时的成功要好得多。
  • \n
  • 别让「半途而废」 成为你唯一坚持下来的事情。
  • \n
  • 世上没有听一遍就管用的道理。
  • \n
  • (你的脑袋)不要做别人思想的跑马场。
  • \n
  • 路是自己走的,脚上的泡也是自己好的。
  • \n
  • 忍一时越想越气,退一步越想越亏。(总是忍的人,从来都不开心。总是退让的人,却从来没有真的海阔天空)
  • \n
  • 遇到烂事不纠结,遇到烂人不纠缠。
  • \n
  • 每个人都想努力做,却总是做不好。
  • \n
  • 曹操评袁绍:「色厉胆薄,好谋无断,干大事而惜身,见小利而忘命。」
  • \n
\n","site":{"data":{}},"excerpt":"
幸福的路有两条
\n

中岛美雪写的歌《幸福》(任贤齐翻唱的伤心太平洋):到幸福的路有两条,一条是所有愿望都成真,另外一条是把愿望这东西扔掉。

","more":"
Matrix
\n
\n

Cypher: You know, I know this steak doesn’t exist. I know that when I put it in my mounth, the Matrix is telling my brain that it is … juicy and delicious. After nine years, you know what I realize? en … Ignorance is bliss

\n
\n
几个顺口溜
\n
    \n
  • 认认真真说假话,扎扎实实走过场。
  • \n
  • 失败乃成功之母——失败生了100个孩子,其中一个叫「成功」,其它99个还叫「失败」。
  • \n
  • “人类一思考,上帝就发笑。” —— “你一说要学什么东西,人们就发笑。”
  • \n
  • 晚上想想千条路,早上起来走原路。(有个共同特点:不困难、不痛苦)
  • \n
  • 暂时的失败要比暂时的成功要好得多。
  • \n
  • 别让「半途而废」 成为你唯一坚持下来的事情。
  • \n
  • 世上没有听一遍就管用的道理。
  • \n
  • (你的脑袋)不要做别人思想的跑马场。
  • \n
  • 路是自己走的,脚上的泡也是自己好的。
  • \n
  • 忍一时越想越气,退一步越想越亏。(总是忍的人,从来都不开心。总是退让的人,却从来没有真的海阔天空)
  • \n
  • 遇到烂事不纠结,遇到烂人不纠缠。
  • \n
  • 每个人都想努力做,却总是做不好。
  • \n
  • 曹操评袁绍:「色厉胆薄,好谋无断,干大事而惜身,见小利而忘命。」
  • \n
"},{"title":"缠中说禅","date":"2019-07-29T06:40:50.000Z","urlname":"funny-things-collection","toc":true,"notshow":true,"_content":"\n[TOC]\n\n##### 诗词\n\n###### 满江红\n\n万古长空,今犹昔,一朝风月。何处住?\n春花夏雨,秋鸿冬雪。\n百代浮华皆作土,千江吸尽无堪说。\n问世间,多少梦消磨、英雄血。\n星旋轨,天补裂,山崩柱,河倾缺。\n捣神宫鬼府,凤巢龙穴。\n怒剑穿云惊浩宇,狂涛卷日横孤筏。\n纵生死,劫火洗乾坤,齐欢悦。\n\n###### 临江仙\n\n浊水倾波三万里,愀然独坐孤峰。\n龙潜狮睡侯飙风。\n无情皆竖子,有泪亦英雄。\n长剑倚天星斗烂,古今过眼成空。\n乾坤俯仰任穷痛。\n半轮沧海上,一苇大江东。\n\n###### 卜算子\n\n本是后山人,偶做堂前客。\n醉舞经阁半卷书,坐井说天阔。\n大志戏功名,海斗量祸福。\n论到囊中羞涩时,怒指乾坤错。\n\n—— 丁元英","source":"_posts/摘录/片段/缠中说禅.md","raw":"---\ntitle: 缠中说禅\ndate: 2019-07-29 08:40:50\nurlname: funny-things-collection\ntoc: true\ntags: [文学]\ncategories: [摘录, 片段]\nnotshow: true\n\n---\n\n[TOC]\n\n##### 诗词\n\n###### 满江红\n\n万古长空,今犹昔,一朝风月。何处住?\n春花夏雨,秋鸿冬雪。\n百代浮华皆作土,千江吸尽无堪说。\n问世间,多少梦消磨、英雄血。\n星旋轨,天补裂,山崩柱,河倾缺。\n捣神宫鬼府,凤巢龙穴。\n怒剑穿云惊浩宇,狂涛卷日横孤筏。\n纵生死,劫火洗乾坤,齐欢悦。\n\n###### 临江仙\n\n浊水倾波三万里,愀然独坐孤峰。\n龙潜狮睡侯飙风。\n无情皆竖子,有泪亦英雄。\n长剑倚天星斗烂,古今过眼成空。\n乾坤俯仰任穷痛。\n半轮沧海上,一苇大江东。\n\n###### 卜算子\n\n本是后山人,偶做堂前客。\n醉舞经阁半卷书,坐井说天阔。\n大志戏功名,海斗量祸福。\n论到囊中羞涩时,怒指乾坤错。\n\n—— 丁元英","slug":"摘录/片段/缠中说禅","published":1,"updated":"2019-07-31T03:51:35.000Z","_id":"cka1y598o002l4huuoby01avt","comments":1,"layout":"post","photos":[],"link":"","content":"

[TOC]

\n
诗词
\n
满江红
\n

万古长空,今犹昔,一朝风月。何处住?
\n春花夏雨,秋鸿冬雪。
\n百代浮华皆作土,千江吸尽无堪说。
\n问世间,多少梦消磨、英雄血。
\n星旋轨,天补裂,山崩柱,河倾缺。
\n捣神宫鬼府,凤巢龙穴。
\n怒剑穿云惊浩宇,狂涛卷日横孤筏。
\n纵生死,劫火洗乾坤,齐欢悦。

\n
临江仙
\n

浊水倾波三万里,愀然独坐孤峰。
\n龙潜狮睡侯飙风。
\n无情皆竖子,有泪亦英雄。
\n长剑倚天星斗烂,古今过眼成空。
\n乾坤俯仰任穷痛。
\n半轮沧海上,一苇大江东。

\n
卜算子
\n

本是后山人,偶做堂前客。
\n醉舞经阁半卷书,坐井说天阔。
\n大志戏功名,海斗量祸福。
\n论到囊中羞涩时,怒指乾坤错。

\n

—— 丁元英

\n","site":{"data":{}},"excerpt":"","more":"

[TOC]

\n
诗词
\n
满江红
\n

万古长空,今犹昔,一朝风月。何处住?
\n春花夏雨,秋鸿冬雪。
\n百代浮华皆作土,千江吸尽无堪说。
\n问世间,多少梦消磨、英雄血。
\n星旋轨,天补裂,山崩柱,河倾缺。
\n捣神宫鬼府,凤巢龙穴。
\n怒剑穿云惊浩宇,狂涛卷日横孤筏。
\n纵生死,劫火洗乾坤,齐欢悦。

\n
临江仙
\n

浊水倾波三万里,愀然独坐孤峰。
\n龙潜狮睡侯飙风。
\n无情皆竖子,有泪亦英雄。
\n长剑倚天星斗烂,古今过眼成空。
\n乾坤俯仰任穷痛。
\n半轮沧海上,一苇大江东。

\n
卜算子
\n

本是后山人,偶做堂前客。
\n醉舞经阁半卷书,坐井说天阔。
\n大志戏功名,海斗量祸福。
\n论到囊中羞涩时,怒指乾坤错。

\n

—— 丁元英

\n"},{"title":"简短书摘","date":"2019-07-29T07:00:50.000Z","urlname":"brief-notions-collection","toc":true,"notshow":true,"_content":"\n###### 癌症\n\n“以我个人有限的接触癌症的经历总结,似乎越是传统意义上的“好人”越是容易生癌。这些人往往脾气很好,性格内向,照顾周围,万事替别人考虑,总是在乎别人眼里的自己,总是担心一些可能发生的小概率负面事件。”\n\n—— 冯唐. “无所畏【冯唐2018全新作品,一部坦露自我的真诚之作!】。” \n\n\n\n###### 暗算\n\n金风未动蝉先觉,暗算无常死不知。\n青山只会明今古,绿水何曾洗是非?\n\n###### 五个人生思维\n\n- 能把问题清楚的写下来,就是解决了问题的一半。发现问题比解决问题更重要。\n- 墨菲定律:如果事情有变坏的可能,那它就一定会发生。\n- 吉伯特法则:真正的危险是没有人告诉你有危险。「人在事中迷,就怕没人提」。\n- 福克兰定律:当你不知道如何行动时,最好的行动就是不要行动,最好的决策就是没有决策。\n- 费斯诺定律:人有两只耳朵,却只有一张嘴巴。就是说,人应该多听少讲。","source":"_posts/摘录/片段/简短书摘.md","raw":"---\ntitle: 简短书摘\ndate: 2019-07-29 09:00:50\nurlname: brief-notions-collection\ntoc: true\ntags: [文学]\ncategories: [摘录, 片段]\nnotshow: true\n\n---\n\n###### 癌症\n\n“以我个人有限的接触癌症的经历总结,似乎越是传统意义上的“好人”越是容易生癌。这些人往往脾气很好,性格内向,照顾周围,万事替别人考虑,总是在乎别人眼里的自己,总是担心一些可能发生的小概率负面事件。”\n\n—— 冯唐. “无所畏【冯唐2018全新作品,一部坦露自我的真诚之作!】。” \n\n\n\n###### 暗算\n\n金风未动蝉先觉,暗算无常死不知。\n青山只会明今古,绿水何曾洗是非?\n\n###### 五个人生思维\n\n- 能把问题清楚的写下来,就是解决了问题的一半。发现问题比解决问题更重要。\n- 墨菲定律:如果事情有变坏的可能,那它就一定会发生。\n- 吉伯特法则:真正的危险是没有人告诉你有危险。「人在事中迷,就怕没人提」。\n- 福克兰定律:当你不知道如何行动时,最好的行动就是不要行动,最好的决策就是没有决策。\n- 费斯诺定律:人有两只耳朵,却只有一张嘴巴。就是说,人应该多听少讲。","slug":"摘录/片段/简短书摘","published":1,"updated":"2019-07-31T03:51:35.000Z","_id":"cka1y598q002p4huudjt7uk0a","comments":1,"layout":"post","photos":[],"link":"","content":"
癌症
\n

“以我个人有限的接触癌症的经历总结,似乎越是传统意义上的“好人”越是容易生癌。这些人往往脾气很好,性格内向,照顾周围,万事替别人考虑,总是在乎别人眼里的自己,总是担心一些可能发生的小概率负面事件。”

\n

—— 冯唐. “无所畏【冯唐2018全新作品,一部坦露自我的真诚之作!】。”

\n\n
暗算
\n

金风未动蝉先觉,暗算无常死不知。
\n青山只会明今古,绿水何曾洗是非?

\n
五个人生思维
\n
    \n
  • 能把问题清楚的写下来,就是解决了问题的一半。发现问题比解决问题更重要。
  • \n
  • 墨菲定律:如果事情有变坏的可能,那它就一定会发生。
  • \n
  • 吉伯特法则:真正的危险是没有人告诉你有危险。「人在事中迷,就怕没人提」。
  • \n
  • 福克兰定律:当你不知道如何行动时,最好的行动就是不要行动,最好的决策就是没有决策。
  • \n
  • 费斯诺定律:人有两只耳朵,却只有一张嘴巴。就是说,人应该多听少讲。
  • \n
\n","site":{"data":{}},"excerpt":"
癌症
\n

“以我个人有限的接触癌症的经历总结,似乎越是传统意义上的“好人”越是容易生癌。这些人往往脾气很好,性格内向,照顾周围,万事替别人考虑,总是在乎别人眼里的自己,总是担心一些可能发生的小概率负面事件。”

\n

—— 冯唐. “无所畏【冯唐2018全新作品,一部坦露自我的真诚之作!】。”

","more":"
暗算
\n

金风未动蝉先觉,暗算无常死不知。
\n青山只会明今古,绿水何曾洗是非?

\n
五个人生思维
\n
    \n
  • 能把问题清楚的写下来,就是解决了问题的一半。发现问题比解决问题更重要。
  • \n
  • 墨菲定律:如果事情有变坏的可能,那它就一定会发生。
  • \n
  • 吉伯特法则:真正的危险是没有人告诉你有危险。「人在事中迷,就怕没人提」。
  • \n
  • 福克兰定律:当你不知道如何行动时,最好的行动就是不要行动,最好的决策就是没有决策。
  • \n
  • 费斯诺定律:人有两只耳朵,却只有一张嘴巴。就是说,人应该多听少讲。
  • \n
"},{"title":"有用的Shell命令","date":"2019-07-30T15:30:28.000Z","urlname":"helpfull-shell-command","toc":true,"notshow":true,"_content":"\n在线网站可以找到基本的东西:[Linux命令大全](https://man.linuxde.net/) [shell 正则表达式](https://man.linuxde.net/docs/shell_regex.html)\n\n# 文件&内容检索\n\n## 正则表达式注意的地方\n\n- 花括号之前要加转义字符 `[a-z]\\{3\\}`\n- 空格就是转义加空格`\\ `,而不是`\\s` 。如 `[a-z0-9_\\ ]\\{3,\\}`\n- 这几个符号 `_ - . #`都不需要加转义符。\n- 不要轻易加==行结束符==$,可能回车才是最后符号,所以可能找不到。\n\n\n\n## grep\n\n```sh\n# -r 递归搜索子目录\n# -l 只显示文件\n# -n 显示文件和匹配的行\n# 搜索 “markdown” 字符串并输入到文件里\n# Formating the Results...\ngrep $begrif $directory $args |awk '{ print \"[\" $1 \"](\" $1 \")\\n\" }' > suchergebnisse.md\n# 将结果转为Windows目录\nsed -i -- 's/\\/D\\//D:\\/\\//g' suchergebnisse.md\necho \"Fertig! Ergebnisse siehe Datei 'suchergebnisse.md'\"\nread\n```\n\n[更多参数请读此文](https://blog.csdn.net/u013485792/article/details/52243479) 示例脚本\n\n`grep` 正则表达式的例子\n\n```sh\n#!bin/bash\n# {#part0000_split_050.html#nav_point-99 .calibre13}\nresult=$(grep '{#part0000_split_[0-9]\\{3\\}.html[a-z0-9_\\ -.#]\\{3,\\}calibre13}' 文件名)\n\nif [ \"$result\" = \"\" ];\nthen\n\techo \"Nichts gefunden!\"\nfi\n\necho $result\nread\n```\n\ngrep或操作\n\n```sh\ngrep -E '123|abc' filename // 找出文件(filename)中包含123或者包含abc的行\negrep '123|abc' filename // 用egrep同样可以实现\nawk '/123|abc/' filename // awk 的实现方式\n```\n\ngrep与操作\n\n```sh\ngrep pattern1 files | grep pattern2 //显示既匹配 pattern1 又匹配 pattern2 的行。\n```\n\n其它常用选项\n\n```sh\ngrep -i pattern files //不区分大小写地搜索。默认情况区分大小写,\ngrep -l pattern files //只列出匹配的文件名,\ngrep -L pattern files //列出不匹配的文件名,\ngrep -w pattern files //只匹配整个单词,而不是字符串的一部分(如匹配‘magic’,而不是‘magical’),\ngrep -C number pattern files //匹配的上下文分别显示[number]行,\n```\n\n{% fold 点击显/隐代码 %}\n\n\n{% endfold %}\n\n## sed 命令\n\n[参考文献](https://man.linuxde.net/sed)\n\n### 文本替代\n\n以下文本替换通过`pandoc`导入后的文件,残留很多内部跳转链接:如\n\n```sh\n{#part0000_split_003.html#nav_point_1 .not-in-toc}\n```\n\n\n\n```bash\n#!bin/bash\necho running\n#sed 's/^#part0000_split_$/p' -f ../Linux_shell_Anleitung.md ;\nsed -i -- 's/^\\[\\]{#part0000_split_[0-9]\\{3\\}.html}$//g' ../Linux_shell_Anleitung.md \n\n#{#part0000_split_017.html#nav_point_21 .calibre8} {#part0000_split_003.html#nav_point_1 .not-in-toc}\nsed -i -- 's/{#part0000_split_[0-9]\\{3\\}.html#[a-z0-9_-]\\+ .[a-z0-9_-]\\+}//g' ../Linux_shell_Anleitung.md \n\necho fertig!\nread\n```\n\n### 整行替代\n\n[参考文献](https://www.cnblogs.com/wangqiguo/p/6718512.html)\n\n替代以 `categories:` 开头的整行(允许行开头有空格或制表符)。`c` 代表整行,以字符串 *categories: [IE]* 替代整行。\n\n```sh\n# Linux 下的写法\nsed -i -- '/^[[:blank:]]*categories:/c categories: [IE]' result.txt \n# Mac 下的写法\nsed -i '' 's/^[[:blank:]]*tags:.*/tags: [心理]/' $1 \n```\n\n错误:如果将参数 `c` 写在前面,会将整个文本每一行都替换掉。\n\n```sh\n# Linux 下的写法\nsed -i -- 'c/^[[:blank:]]*categories:/categories: [IE]/' result.txt \n```\n\n\n\n## find\n\n```sh\n# 查找所有的 md 文件\nfind /root/bibliothek/markdowns/blog_posts/ -type f -name \"*.md\" \n# 查找一天之前的文件, 一小时前时 -1h,一周 -1w\nfind . -type f -mtime -1d\n```\n\n如果要处理复杂的事情,就要用到函数\n\n```sh\n# 定义函数\nshowFileInfo(){\n echo $1\n}\n\n# 声明函数\nexport -f showFileInfo\n# 使用函数\nfind $dirPath -name \"*.md\" | xargs -n 1 -P 10 -I {} bash -c 'showFileInfo \"$@\"' _ {} \\;\n```\n\n\n\n## 查找最新文件\n\n- 将文件按从新到旧排列,取第一个。\n\n `ls -t *.cpp | head -1`\n\n- 将文件按从旧到新排列,取最后一个。\n\n `ls -rt *.cpp | tail -1`\n\n- 列出文件时间戳\n\n `ls -l simpleNode.js |awk '{print $6 \"-\" $7 \"-\" $8 }'`\n\n- 整合以上两个命令,找到最新的文件,读取时间戳 \n\n `ls -t *.* | head -1 | xargs ls -l | awk '{print $6 \"-\" $7 \"-\" $8 }'`\n\n\n\n# 字符串处理\n\n[字符串处理参考文献](https://www.jianshu.com/p/5709118af1c6) [将分隔符的字符串转为数组的几种方法](https://blog.csdn.net/Jerry_1126/article/details/83930956)\n\n配合使用,可以直接用 shell 实现文件内标签和分类的替换。\n\n## 数组转字符串\n\n使用分隔符将数组转字符串:\n\n```sh\nids=(1 2 3 4); \nlst=$( IFS='/'; echo \"${ids[*]}\" ); \necho $lst\n# 结果是:1/2/3/4\n```\n\n## 字符串转数组\n\n[懒得写,看范例](https://blog.csdn.net/Jerry_1126/article/details/83930956)\n\n## 字符串替换\n\n```sh\n# 原串 [娱乐,经济,重要] => 目标串 [娱乐, 经济, 重要]\n${tags/,/, } # 只替换了一个,结果变成 [娱乐, 经济,重要]\n${tags//,/, } # 替换了所有符合的,结果变成 [娱乐, 经济, 重要]\n# 原串 [重要] => 目标串 重要\n${tags//[\\[\\] ]/}\n```\n\n### 消除回车符、换行符、制表符\n\n```sh\n# arg是个字符串变量, 可能带有回车符\\r\n# 把它整个作为参数使用会带来很多麻烦。用以下命令将其替换掉\nnewvar=${arg//[$'\\t\\r\\n']/}\n```\n\n\n\n## 详细用法\n\n[参考文献](https://blog.csdn.net/ljianhui/article/details/43128465)\n\n1. `${var##*/}`\n该命令的作用是去掉变量var从左边算起的最后一个'/'字符及其左边的内容,返回从左边算起的最后一个'/'(不含该字符)的右边的内容。使用例子及结果如下:\n\n```sh\nvar=dir1/dir2/file.txt \n--> file.txt\n```\n\n从运行结果可以看到,使用该命令,可以提取出我们需要的文件名*file.txt*。\n\n若使用时在shell程序文件中,可以使用变量来保存这个结果,再加以利用,如file=`${var##*/}`\n\n2. `${var##*.}`\n该命令的作用是去掉变量var从左边算起的最后一个'.'字符及其左边的内容,返回从左边算起的最后一个'.'(不含该字符)的右边的内容。使用例子及结果如下:\n\n```sh\nvar=dir1/dir2/file.txt \n--> txt\n```\n\n从运行结果可以看到,使用该命令,可以提取出我们需要的文件后缀。\n\n如果文件的后缀不仅有一个,例如,file.tar.gz,命令`${var##*.}`仅能提取最后一个后缀,而我想提取tar.gz时该怎么办?那么就要用下面所说的`${var#*.}`命令了。\n\n3. `${var#*.}`\n该命令的作用是去掉变量var从左边算起的第一个'.'字符及其左边的内容,返回从左边算起第一个'.'(不含该字符)的右边部分的内容。使用例子及结果如下:\n\n```sh\nvar=dir1/dir2/file.tar.gz \n--> tar.gz\n```\n\n从运行结果可以看到,使用该命令,可以提取出文件的多个后缀。\n\n4. `${var%/*}`\n 该命令的使用是去掉变量var从右边算起的第一个'/'字符及其右边的内容,返回从右边算起的第一个'/'(不含该字符)的左边的内容。使用例子及结果如下:\n\n```sh\nvar=dir1/dir2/file.txt \n--> dir1/dir2\n```\n\n\n\n从运行的结果可以看到,使用该命令,可以提取出我们需要的文件所在的目录\n\n5. `${var%%.*}`\n该命令的使用是去掉变量var从右边算起的最后一个'.'字符及其右边的内容,返回从右边算起的最后一个'.'(不含该字符)的左边的内容。使用例子及结果如下:\n\n```sh\nvar=dir1/dir2/file.txt \n--> dir1/dir2/file\n```\n\n当我们需要建立一个与文件名相同名字(没有后缀)的目录与对应的文件相对应时,就可以使用该命令来进行操作。例如,解压文件的情况就与此类似,我们压缩文件file.zip时,会在与file.zip同级目录下建立一个名为file的目录。\n\n6. 总结\n\n 其实${}并不是专门为提取文件名或目录名的,它的使用是变量的提取和替换等等操作,它可以提取非常多的内容,并不一定是上面五个例子中的'/'或'.'。也就是说,上面的使用方法只是它使用的一个特例。\n\n\n\n看到上面的这些命令,可能会让人感到非常难以理解和记忆,其实不然,它们都是有规律的。\n\n- \\#:表示从左边算起第一个\n\n- %:表示从右边算起第一个\n\n- \\##:表示从左边算起最后一个\n\n- %%:表示从右边算起最后一个\n\n换句话来说,#总是表示左边算起,%总是表示右边算起。\n\n*:表示要删除的内容,对于#和##的情况,它位于指定的字符(例子中的'/'和'.')的左边,表于删除指定字符及其左边的内容;对于%和%%的情况,它位于指定的字符(例子中的'/'和'.')的右边,表示删除指定字符及其右边的内容。这里的'*'的位置不能互换,即不能把*号放在#或##的右边,反之亦然。\n\n例如:`${var%%x*}`表示找出从右边算起最后一个字符x,并删除字符x及其右边的字符。\n\n看到这里,就可以知道,其实该命令的用途非常广泛,上面只是指针文件名和目录名的命名特性来进行提取的一些特例而已。\n\n## basename和dirname\n\n`${}`并不是专门为提取文件名和目录名设计的命令,那么`basename`和`dirname`命令就是专门为做这一件事而已准备的了。\n\n1. `basename`\n 该命令的作用是从路径中提取出文件名,使用方法为basename NAME [SUFFIX]。\n\n 1.1 从路径中提出出文件名(带后缀),例子如下:\n\n 1.2 从上面命令的用法中可以看到,后缀(SUFFIX)是一个可选项。所以,若只想提取出文件名file,而不带有后缀,还可以在变量的后面加上后缀名,例子如下:\n\n\n2. `dirname`\n该命令的作用是从路径中提取出目录名,使用方法为 dirname NAME。使用例子如下:\n\n这样就提取出了file.txt文件所在的目录。\n\n注:该命令不仅能提取出普通文件所的目录,它能提取出任何文件所在的目录,例如目录所在的目录,如下:\n\n它提取出了目录dir2所在的目录dir1.\n\n---------------------\n\n\n\n# 查看硬盘剩余空间\n\n```sh\n# 整个硬盘空间\ndf -hl\n# 查看某个文件夹大小\ndu -h your_directory # 列出每个子文件夹大小\ndu -hcs your_directory # 汇总\n```\n\n\n\n## 查看 package 版本\n\n```sh\napt-cache show packagename\n```\n\n\n\n# Windwos 下的脚本\n\nwindows 下显示环境变量\n\n`echo %http_proxy%`\n\nwindows 下设置代理服务器\n$$\n\n$$\n\n```sh\nset http_proxy=http://username:pwd$$$@proxy-rzf:8080\nset https_proxy=http://username:pwd$$$@proxy-rzf:8080\n```\n\n","source":"_posts/IT/Tools/有用的shell命令.md","raw":"---\ntitle: 有用的Shell命令\ndate: 2019-07-30 17:30:28\nurlname: helpfull-shell-command\ntoc: true\ntags: [工具]\ncategories: [IT, Tools]\nnotshow: true\n---\n\n在线网站可以找到基本的东西:[Linux命令大全](https://man.linuxde.net/) [shell 正则表达式](https://man.linuxde.net/docs/shell_regex.html)\n\n# 文件&内容检索\n\n## 正则表达式注意的地方\n\n- 花括号之前要加转义字符 `[a-z]\\{3\\}`\n- 空格就是转义加空格`\\ `,而不是`\\s` 。如 `[a-z0-9_\\ ]\\{3,\\}`\n- 这几个符号 `_ - . #`都不需要加转义符。\n- 不要轻易加==行结束符==$,可能回车才是最后符号,所以可能找不到。\n\n\n\n## grep\n\n```sh\n# -r 递归搜索子目录\n# -l 只显示文件\n# -n 显示文件和匹配的行\n# 搜索 “markdown” 字符串并输入到文件里\n# Formating the Results...\ngrep $begrif $directory $args |awk '{ print \"[\" $1 \"](\" $1 \")\\n\" }' > suchergebnisse.md\n# 将结果转为Windows目录\nsed -i -- 's/\\/D\\//D:\\/\\//g' suchergebnisse.md\necho \"Fertig! Ergebnisse siehe Datei 'suchergebnisse.md'\"\nread\n```\n\n[更多参数请读此文](https://blog.csdn.net/u013485792/article/details/52243479) 示例脚本\n\n`grep` 正则表达式的例子\n\n```sh\n#!bin/bash\n# {#part0000_split_050.html#nav_point-99 .calibre13}\nresult=$(grep '{#part0000_split_[0-9]\\{3\\}.html[a-z0-9_\\ -.#]\\{3,\\}calibre13}' 文件名)\n\nif [ \"$result\" = \"\" ];\nthen\n\techo \"Nichts gefunden!\"\nfi\n\necho $result\nread\n```\n\ngrep或操作\n\n```sh\ngrep -E '123|abc' filename // 找出文件(filename)中包含123或者包含abc的行\negrep '123|abc' filename // 用egrep同样可以实现\nawk '/123|abc/' filename // awk 的实现方式\n```\n\ngrep与操作\n\n```sh\ngrep pattern1 files | grep pattern2 //显示既匹配 pattern1 又匹配 pattern2 的行。\n```\n\n其它常用选项\n\n```sh\ngrep -i pattern files //不区分大小写地搜索。默认情况区分大小写,\ngrep -l pattern files //只列出匹配的文件名,\ngrep -L pattern files //列出不匹配的文件名,\ngrep -w pattern files //只匹配整个单词,而不是字符串的一部分(如匹配‘magic’,而不是‘magical’),\ngrep -C number pattern files //匹配的上下文分别显示[number]行,\n```\n\n{% fold 点击显/隐代码 %}\n\n\n{% endfold %}\n\n## sed 命令\n\n[参考文献](https://man.linuxde.net/sed)\n\n### 文本替代\n\n以下文本替换通过`pandoc`导入后的文件,残留很多内部跳转链接:如\n\n```sh\n{#part0000_split_003.html#nav_point_1 .not-in-toc}\n```\n\n\n\n```bash\n#!bin/bash\necho running\n#sed 's/^#part0000_split_$/p' -f ../Linux_shell_Anleitung.md ;\nsed -i -- 's/^\\[\\]{#part0000_split_[0-9]\\{3\\}.html}$//g' ../Linux_shell_Anleitung.md \n\n#{#part0000_split_017.html#nav_point_21 .calibre8} {#part0000_split_003.html#nav_point_1 .not-in-toc}\nsed -i -- 's/{#part0000_split_[0-9]\\{3\\}.html#[a-z0-9_-]\\+ .[a-z0-9_-]\\+}//g' ../Linux_shell_Anleitung.md \n\necho fertig!\nread\n```\n\n### 整行替代\n\n[参考文献](https://www.cnblogs.com/wangqiguo/p/6718512.html)\n\n替代以 `categories:` 开头的整行(允许行开头有空格或制表符)。`c` 代表整行,以字符串 *categories: [IE]* 替代整行。\n\n```sh\n# Linux 下的写法\nsed -i -- '/^[[:blank:]]*categories:/c categories: [IE]' result.txt \n# Mac 下的写法\nsed -i '' 's/^[[:blank:]]*tags:.*/tags: [心理]/' $1 \n```\n\n错误:如果将参数 `c` 写在前面,会将整个文本每一行都替换掉。\n\n```sh\n# Linux 下的写法\nsed -i -- 'c/^[[:blank:]]*categories:/categories: [IE]/' result.txt \n```\n\n\n\n## find\n\n```sh\n# 查找所有的 md 文件\nfind /root/bibliothek/markdowns/blog_posts/ -type f -name \"*.md\" \n# 查找一天之前的文件, 一小时前时 -1h,一周 -1w\nfind . -type f -mtime -1d\n```\n\n如果要处理复杂的事情,就要用到函数\n\n```sh\n# 定义函数\nshowFileInfo(){\n echo $1\n}\n\n# 声明函数\nexport -f showFileInfo\n# 使用函数\nfind $dirPath -name \"*.md\" | xargs -n 1 -P 10 -I {} bash -c 'showFileInfo \"$@\"' _ {} \\;\n```\n\n\n\n## 查找最新文件\n\n- 将文件按从新到旧排列,取第一个。\n\n `ls -t *.cpp | head -1`\n\n- 将文件按从旧到新排列,取最后一个。\n\n `ls -rt *.cpp | tail -1`\n\n- 列出文件时间戳\n\n `ls -l simpleNode.js |awk '{print $6 \"-\" $7 \"-\" $8 }'`\n\n- 整合以上两个命令,找到最新的文件,读取时间戳 \n\n `ls -t *.* | head -1 | xargs ls -l | awk '{print $6 \"-\" $7 \"-\" $8 }'`\n\n\n\n# 字符串处理\n\n[字符串处理参考文献](https://www.jianshu.com/p/5709118af1c6) [将分隔符的字符串转为数组的几种方法](https://blog.csdn.net/Jerry_1126/article/details/83930956)\n\n配合使用,可以直接用 shell 实现文件内标签和分类的替换。\n\n## 数组转字符串\n\n使用分隔符将数组转字符串:\n\n```sh\nids=(1 2 3 4); \nlst=$( IFS='/'; echo \"${ids[*]}\" ); \necho $lst\n# 结果是:1/2/3/4\n```\n\n## 字符串转数组\n\n[懒得写,看范例](https://blog.csdn.net/Jerry_1126/article/details/83930956)\n\n## 字符串替换\n\n```sh\n# 原串 [娱乐,经济,重要] => 目标串 [娱乐, 经济, 重要]\n${tags/,/, } # 只替换了一个,结果变成 [娱乐, 经济,重要]\n${tags//,/, } # 替换了所有符合的,结果变成 [娱乐, 经济, 重要]\n# 原串 [重要] => 目标串 重要\n${tags//[\\[\\] ]/}\n```\n\n### 消除回车符、换行符、制表符\n\n```sh\n# arg是个字符串变量, 可能带有回车符\\r\n# 把它整个作为参数使用会带来很多麻烦。用以下命令将其替换掉\nnewvar=${arg//[$'\\t\\r\\n']/}\n```\n\n\n\n## 详细用法\n\n[参考文献](https://blog.csdn.net/ljianhui/article/details/43128465)\n\n1. `${var##*/}`\n该命令的作用是去掉变量var从左边算起的最后一个'/'字符及其左边的内容,返回从左边算起的最后一个'/'(不含该字符)的右边的内容。使用例子及结果如下:\n\n```sh\nvar=dir1/dir2/file.txt \n--> file.txt\n```\n\n从运行结果可以看到,使用该命令,可以提取出我们需要的文件名*file.txt*。\n\n若使用时在shell程序文件中,可以使用变量来保存这个结果,再加以利用,如file=`${var##*/}`\n\n2. `${var##*.}`\n该命令的作用是去掉变量var从左边算起的最后一个'.'字符及其左边的内容,返回从左边算起的最后一个'.'(不含该字符)的右边的内容。使用例子及结果如下:\n\n```sh\nvar=dir1/dir2/file.txt \n--> txt\n```\n\n从运行结果可以看到,使用该命令,可以提取出我们需要的文件后缀。\n\n如果文件的后缀不仅有一个,例如,file.tar.gz,命令`${var##*.}`仅能提取最后一个后缀,而我想提取tar.gz时该怎么办?那么就要用下面所说的`${var#*.}`命令了。\n\n3. `${var#*.}`\n该命令的作用是去掉变量var从左边算起的第一个'.'字符及其左边的内容,返回从左边算起第一个'.'(不含该字符)的右边部分的内容。使用例子及结果如下:\n\n```sh\nvar=dir1/dir2/file.tar.gz \n--> tar.gz\n```\n\n从运行结果可以看到,使用该命令,可以提取出文件的多个后缀。\n\n4. `${var%/*}`\n 该命令的使用是去掉变量var从右边算起的第一个'/'字符及其右边的内容,返回从右边算起的第一个'/'(不含该字符)的左边的内容。使用例子及结果如下:\n\n```sh\nvar=dir1/dir2/file.txt \n--> dir1/dir2\n```\n\n\n\n从运行的结果可以看到,使用该命令,可以提取出我们需要的文件所在的目录\n\n5. `${var%%.*}`\n该命令的使用是去掉变量var从右边算起的最后一个'.'字符及其右边的内容,返回从右边算起的最后一个'.'(不含该字符)的左边的内容。使用例子及结果如下:\n\n```sh\nvar=dir1/dir2/file.txt \n--> dir1/dir2/file\n```\n\n当我们需要建立一个与文件名相同名字(没有后缀)的目录与对应的文件相对应时,就可以使用该命令来进行操作。例如,解压文件的情况就与此类似,我们压缩文件file.zip时,会在与file.zip同级目录下建立一个名为file的目录。\n\n6. 总结\n\n 其实${}并不是专门为提取文件名或目录名的,它的使用是变量的提取和替换等等操作,它可以提取非常多的内容,并不一定是上面五个例子中的'/'或'.'。也就是说,上面的使用方法只是它使用的一个特例。\n\n\n\n看到上面的这些命令,可能会让人感到非常难以理解和记忆,其实不然,它们都是有规律的。\n\n- \\#:表示从左边算起第一个\n\n- %:表示从右边算起第一个\n\n- \\##:表示从左边算起最后一个\n\n- %%:表示从右边算起最后一个\n\n换句话来说,#总是表示左边算起,%总是表示右边算起。\n\n*:表示要删除的内容,对于#和##的情况,它位于指定的字符(例子中的'/'和'.')的左边,表于删除指定字符及其左边的内容;对于%和%%的情况,它位于指定的字符(例子中的'/'和'.')的右边,表示删除指定字符及其右边的内容。这里的'*'的位置不能互换,即不能把*号放在#或##的右边,反之亦然。\n\n例如:`${var%%x*}`表示找出从右边算起最后一个字符x,并删除字符x及其右边的字符。\n\n看到这里,就可以知道,其实该命令的用途非常广泛,上面只是指针文件名和目录名的命名特性来进行提取的一些特例而已。\n\n## basename和dirname\n\n`${}`并不是专门为提取文件名和目录名设计的命令,那么`basename`和`dirname`命令就是专门为做这一件事而已准备的了。\n\n1. `basename`\n 该命令的作用是从路径中提取出文件名,使用方法为basename NAME [SUFFIX]。\n\n 1.1 从路径中提出出文件名(带后缀),例子如下:\n\n 1.2 从上面命令的用法中可以看到,后缀(SUFFIX)是一个可选项。所以,若只想提取出文件名file,而不带有后缀,还可以在变量的后面加上后缀名,例子如下:\n\n\n2. `dirname`\n该命令的作用是从路径中提取出目录名,使用方法为 dirname NAME。使用例子如下:\n\n这样就提取出了file.txt文件所在的目录。\n\n注:该命令不仅能提取出普通文件所的目录,它能提取出任何文件所在的目录,例如目录所在的目录,如下:\n\n它提取出了目录dir2所在的目录dir1.\n\n---------------------\n\n\n\n# 查看硬盘剩余空间\n\n```sh\n# 整个硬盘空间\ndf -hl\n# 查看某个文件夹大小\ndu -h your_directory # 列出每个子文件夹大小\ndu -hcs your_directory # 汇总\n```\n\n\n\n## 查看 package 版本\n\n```sh\napt-cache show packagename\n```\n\n\n\n# Windwos 下的脚本\n\nwindows 下显示环境变量\n\n`echo %http_proxy%`\n\nwindows 下设置代理服务器\n$$\n\n$$\n\n```sh\nset http_proxy=http://username:pwd$$$@proxy-rzf:8080\nset https_proxy=http://username:pwd$$$@proxy-rzf:8080\n```\n\n","slug":"IT/Tools/有用的shell命令","published":1,"updated":"2019-08-14T13:12:36.000Z","_id":"cka1y599o004i4huuvxxo90p7","comments":1,"layout":"post","photos":[],"link":"","content":"

在线网站可以找到基本的东西:Linux命令大全 shell 正则表达式

\n

文件&内容检索

\n

正则表达式注意的地方

\n
    \n
  • 花括号之前要加转义字符 [a-z]\\{3\\}
  • \n
  • 空格就是转义加空格\\ ,而不是\\s 。如 [a-z0-9_\\ ]\\{3,\\}
  • \n
  • 这几个符号 _ - . #都不需要加转义符。
  • \n
  • 不要轻易加==行结束符==$,可能回车才是最后符号,所以可能找不到。
  • \n
\n\n

grep

\n
1
2
3
4
5
6
7
8
9
10
# -r 递归搜索子目录
# -l 只显示文件
# -n 显示文件和匹配的行
# 搜索 “markdown” 字符串并输入到文件里
# Formating the Results...
grep $begrif $directory $args |awk '{ print \"[\" $1 \"](\" $1 \")\\n\" }' > suchergebnisse.md
# 将结果转为Windows目录
sed -i -- 's/\\/D\\//D:\\/\\//g' suchergebnisse.md
echo \"Fertig! Ergebnisse siehe Datei 'suchergebnisse.md'\"
read
\n

更多参数请读此文 示例脚本

\n

grep 正则表达式的例子

\n
1
2
3
4
5
6
7
8
9
10
11
#!bin/bash
# {#part0000_split_050.html#nav_point-99 .calibre13}
result=$(grep '{#part0000_split_[0-9]\\{3\\}.html[a-z0-9_\\ -.#]\\{3,\\}calibre13}' 文件名)

if [ \"$result\" = \"\" ];
then
\techo \"Nichts gefunden!\"
fi

echo $result
read
\n

grep或操作

\n
1
2
3
grep -E '123|abc' filename  // 找出文件(filename)中包含123或者包含abc的行
egrep '123|abc' filename // 用egrep同样可以实现
awk '/123|abc/' filename // awk 的实现方式
\n

grep与操作

\n
1
grep pattern1 files | grep pattern2 //显示既匹配 pattern1 又匹配 pattern2 的行。
\n

其它常用选项

\n
1
2
3
4
5
grep -i pattern files   //不区分大小写地搜索。默认情况区分大小写,
grep -l pattern files //只列出匹配的文件名,
grep -L pattern files //列出不匹配的文件名,
grep -w pattern files //只匹配整个单词,而不是字符串的一部分(如匹配‘magic’,而不是‘magical’),
grep -C number pattern files //匹配的上下文分别显示[number]行,
\n
点击显/隐代码
\n\n
\n

sed 命令

\n

参考文献

\n

文本替代

\n

以下文本替换通过pandoc导入后的文件,残留很多内部跳转链接:如

\n
1
{#part0000_split_003.html#nav_point_1 .not-in-toc}
\n
1
2
3
4
5
6
7
8
9
10
#!bin/bash
echo running
#sed 's/^#part0000_split_$/p' -f ../Linux_shell_Anleitung.md ;
sed -i -- 's/^\\[\\]{#part0000_split_[0-9]\\{3\\}.html}$//g' ../Linux_shell_Anleitung.md

#{#part0000_split_017.html#nav_point_21 .calibre8} {#part0000_split_003.html#nav_point_1 .not-in-toc}
sed -i -- 's/{#part0000_split_[0-9]\\{3\\}.html#[a-z0-9_-]\\+ .[a-z0-9_-]\\+}//g' ../Linux_shell_Anleitung.md

echo fertig!
read
\n

整行替代

\n

参考文献

\n

替代以 categories: 开头的整行(允许行开头有空格或制表符)。c 代表整行,以字符串 categories: [IE] 替代整行。

\n
1
2
3
4
# Linux 下的写法
sed -i -- '/^[[:blank:]]*categories:/c categories: [IE]' result.txt
# Mac 下的写法
sed -i '' 's/^[[:blank:]]*tags:.*/tags: [心理]/' $1
\n

错误:如果将参数 c 写在前面,会将整个文本每一行都替换掉。

\n
1
2
# Linux 下的写法
sed -i -- 'c/^[[:blank:]]*categories:/categories: [IE]/' result.txt
\n

find

\n
1
2
3
4
# 查找所有的 md 文件
find /root/bibliothek/markdowns/blog_posts/ -type f -name \"*.md\"
# 查找一天之前的文件, 一小时前时 -1h,一周 -1w
find . -type f -mtime -1d
\n

如果要处理复杂的事情,就要用到函数

\n
1
2
3
4
5
6
7
8
9
# 定义函数
showFileInfo(){
echo $1
}

# 声明函数
export -f showFileInfo
# 使用函数
find $dirPath -name \"*.md\" | xargs -n 1 -P 10 -I {} bash -c 'showFileInfo \"$@\"' _ {} \\;
\n

查找最新文件

\n
    \n
  • \n

    将文件按从新到旧排列,取第一个。

    \n

    ls -t *.cpp | head -1

    \n
  • \n
  • \n

    将文件按从旧到新排列,取最后一个。

    \n

    ls -rt *.cpp | tail -1

    \n
  • \n
  • \n

    列出文件时间戳

    \n

    ls -l simpleNode.js |awk '{print $6 "-" $7 "-" $8 }'

    \n
  • \n
  • \n

    整合以上两个命令,找到最新的文件,读取时间戳

    \n

    ls -t *.* | head -1 | xargs ls -l | awk '{print $6 "-" $7 "-" $8 }'

    \n
  • \n
\n

字符串处理

\n

字符串处理参考文献 将分隔符的字符串转为数组的几种方法

\n

配合使用,可以直接用 shell 实现文件内标签和分类的替换。

\n

数组转字符串

\n

使用分隔符将数组转字符串:

\n
1
2
3
4
ids=(1 2 3 4); 
lst=$( IFS='/'; echo \"${ids[*]}\" );
echo $lst
# 结果是:1/2/3/4
\n

字符串转数组

\n

懒得写,看范例

\n

字符串替换

\n
1
2
3
4
5
# 原串 [娱乐,经济,重要] => 目标串 [娱乐, 经济, 重要]
${tags/,/, } # 只替换了一个,结果变成 [娱乐, 经济,重要]
${tags//,/, } # 替换了所有符合的,结果变成 [娱乐, 经济, 重要]
# 原串 [重要] => 目标串 重要
${tags//[\\[\\] ]/}
\n

消除回车符、换行符、制表符

\n
1
2
3
# arg是个字符串变量, 可能带有回车符\\r
# 把它整个作为参数使用会带来很多麻烦。用以下命令将其替换掉
newvar=${arg//[$'\\t\\r\\n']/}
\n

详细用法

\n

参考文献

\n
    \n
  1. ${var##*/}
    \n该命令的作用是去掉变量var从左边算起的最后一个’/‘字符及其左边的内容,返回从左边算起的最后一个’/’(不含该字符)的右边的内容。使用例子及结果如下:
  2. \n
\n
1
2
var=dir1/dir2/file.txt 
--> file.txt
\n

从运行结果可以看到,使用该命令,可以提取出我们需要的文件名file.txt

\n

若使用时在shell程序文件中,可以使用变量来保存这个结果,再加以利用,如file=${var##*/}

\n
    \n
  1. ${var##*.}
    \n该命令的作用是去掉变量var从左边算起的最后一个’.‘字符及其左边的内容,返回从左边算起的最后一个’.’(不含该字符)的右边的内容。使用例子及结果如下:
  2. \n
\n
1
2
var=dir1/dir2/file.txt 
--> txt
\n

从运行结果可以看到,使用该命令,可以提取出我们需要的文件后缀。

\n

如果文件的后缀不仅有一个,例如,file.tar.gz,命令${var##*.}仅能提取最后一个后缀,而我想提取tar.gz时该怎么办?那么就要用下面所说的${var#*.}命令了。

\n
    \n
  1. ${var#*.}
    \n该命令的作用是去掉变量var从左边算起的第一个’.‘字符及其左边的内容,返回从左边算起第一个’.’(不含该字符)的右边部分的内容。使用例子及结果如下:
  2. \n
\n
1
2
var=dir1/dir2/file.tar.gz 
--> tar.gz
\n

从运行结果可以看到,使用该命令,可以提取出文件的多个后缀。

\n
    \n
  1. ${var%/*}
    \n该命令的使用是去掉变量var从右边算起的第一个’/‘字符及其右边的内容,返回从右边算起的第一个’/’(不含该字符)的左边的内容。使用例子及结果如下:
  2. \n
\n
1
2
var=dir1/dir2/file.txt 
--> dir1/dir2
\n

从运行的结果可以看到,使用该命令,可以提取出我们需要的文件所在的目录

\n
    \n
  1. ${var%%.*}
    \n该命令的使用是去掉变量var从右边算起的最后一个’.‘字符及其右边的内容,返回从右边算起的最后一个’.’(不含该字符)的左边的内容。使用例子及结果如下:
  2. \n
\n
1
2
var=dir1/dir2/file.txt 
--> dir1/dir2/file
\n

当我们需要建立一个与文件名相同名字(没有后缀)的目录与对应的文件相对应时,就可以使用该命令来进行操作。例如,解压文件的情况就与此类似,我们压缩文件file.zip时,会在与file.zip同级目录下建立一个名为file的目录。

\n
    \n
  1. 总结
  2. \n
\n

其实${}并不是专门为提取文件名或目录名的,它的使用是变量的提取和替换等等操作,它可以提取非常多的内容,并不一定是上面五个例子中的’/‘或’.’。也就是说,上面的使用方法只是它使用的一个特例。

\n

看到上面的这些命令,可能会让人感到非常难以理解和记忆,其实不然,它们都是有规律的。

\n
    \n
  • \n

    #:表示从左边算起第一个

    \n
  • \n
  • \n

    %:表示从右边算起第一个

    \n
  • \n
  • \n

    ##:表示从左边算起最后一个

    \n
  • \n
  • \n

    %%:表示从右边算起最后一个

    \n
  • \n
\n

换句话来说,#总是表示左边算起,%总是表示右边算起。

\n

*:表示要删除的内容,对于#和##的情况,它位于指定的字符(例子中的’/‘和’.’)的左边,表于删除指定字符及其左边的内容;对于%和%%的情况,它位于指定的字符(例子中的’/‘和’.’)的右边,表示删除指定字符及其右边的内容。这里的’'的位置不能互换,即不能把号放在#或##的右边,反之亦然。

\n

例如:${var%%x*}表示找出从右边算起最后一个字符x,并删除字符x及其右边的字符。

\n

看到这里,就可以知道,其实该命令的用途非常广泛,上面只是指针文件名和目录名的命名特性来进行提取的一些特例而已。

\n

basename和dirname

\n

${}并不是专门为提取文件名和目录名设计的命令,那么basenamedirname命令就是专门为做这一件事而已准备的了。

\n
    \n
  1. basename
    \n该命令的作用是从路径中提取出文件名,使用方法为basename NAME [SUFFIX]。
  2. \n
\n

1.1 从路径中提出出文件名(带后缀),例子如下:

\n

1.2 从上面命令的用法中可以看到,后缀(SUFFIX)是一个可选项。所以,若只想提取出文件名file,而不带有后缀,还可以在变量的后面加上后缀名,例子如下:

\n
    \n
  1. dirname
    \n该命令的作用是从路径中提取出目录名,使用方法为 dirname NAME。使用例子如下:
  2. \n
\n

这样就提取出了file.txt文件所在的目录。

\n

注:该命令不仅能提取出普通文件所的目录,它能提取出任何文件所在的目录,例如目录所在的目录,如下:

\n

它提取出了目录dir2所在的目录dir1.

\n
\n

查看硬盘剩余空间

\n
1
2
3
4
5
# 整个硬盘空间
df -hl
# 查看某个文件夹大小
du -h your_directory # 列出每个子文件夹大小
du -hcs your_directory # 汇总
\n

查看 package 版本

\n
1
apt-cache show packagename
\n

Windwos 下的脚本

\n

windows 下显示环境变量

\n

echo %http_proxy%

\n

windows 下设置代理服务器
\n$$

\n

$$

\n
1
2
set http_proxy=http://username:pwd$$$@proxy-rzf:8080
set https_proxy=http://username:pwd$$$@proxy-rzf:8080
\n","site":{"data":{}},"excerpt":"

在线网站可以找到基本的东西:Linux命令大全 shell 正则表达式

\n

文件&内容检索

\n

正则表达式注意的地方

\n
    \n
  • 花括号之前要加转义字符 [a-z]\\{3\\}
  • \n
  • 空格就是转义加空格\\ ,而不是\\s 。如 [a-z0-9_\\ ]\\{3,\\}
  • \n
  • 这几个符号 _ - . #都不需要加转义符。
  • \n
  • 不要轻易加==行结束符==$,可能回车才是最后符号,所以可能找不到。
  • \n
","more":"

grep

\n\n

更多参数请读此文 示例脚本

\n

grep 正则表达式的例子

\n\n

grep或操作

\n\n

grep与操作

\n\n

其它常用选项

\n\n
点击显/隐代码
\n\n
\n

sed 命令

\n

参考文献

\n

文本替代

\n

以下文本替换通过pandoc导入后的文件,残留很多内部跳转链接:如

\n\n\n

整行替代

\n

参考文献

\n

替代以 categories: 开头的整行(允许行开头有空格或制表符)。c 代表整行,以字符串 categories: [IE] 替代整行。

\n\n

错误:如果将参数 c 写在前面,会将整个文本每一行都替换掉。

\n\n

find

\n\n

如果要处理复杂的事情,就要用到函数

\n\n

查找最新文件

\n
    \n
  • \n

    将文件按从新到旧排列,取第一个。

    \n

    ls -t *.cpp | head -1

    \n
  • \n
  • \n

    将文件按从旧到新排列,取最后一个。

    \n

    ls -rt *.cpp | tail -1

    \n
  • \n
  • \n

    列出文件时间戳

    \n

    ls -l simpleNode.js |awk '{print $6 "-" $7 "-" $8 }'

    \n
  • \n
  • \n

    整合以上两个命令,找到最新的文件,读取时间戳

    \n

    ls -t *.* | head -1 | xargs ls -l | awk '{print $6 "-" $7 "-" $8 }'

    \n
  • \n
\n

字符串处理

\n

字符串处理参考文献 将分隔符的字符串转为数组的几种方法

\n

配合使用,可以直接用 shell 实现文件内标签和分类的替换。

\n

数组转字符串

\n

使用分隔符将数组转字符串:

\n\n

字符串转数组

\n

懒得写,看范例

\n

字符串替换

\n\n

消除回车符、换行符、制表符

\n\n

详细用法

\n

参考文献

\n
    \n
  1. ${var##*/}
    \n该命令的作用是去掉变量var从左边算起的最后一个’/‘字符及其左边的内容,返回从左边算起的最后一个’/’(不含该字符)的右边的内容。使用例子及结果如下:
  2. \n
\n\n

从运行结果可以看到,使用该命令,可以提取出我们需要的文件名file.txt

\n

若使用时在shell程序文件中,可以使用变量来保存这个结果,再加以利用,如file=${var##*/}

\n
    \n
  1. ${var##*.}
    \n该命令的作用是去掉变量var从左边算起的最后一个’.‘字符及其左边的内容,返回从左边算起的最后一个’.’(不含该字符)的右边的内容。使用例子及结果如下:
  2. \n
\n\n

从运行结果可以看到,使用该命令,可以提取出我们需要的文件后缀。

\n

如果文件的后缀不仅有一个,例如,file.tar.gz,命令${var##*.}仅能提取最后一个后缀,而我想提取tar.gz时该怎么办?那么就要用下面所说的${var#*.}命令了。

\n
    \n
  1. ${var#*.}
    \n该命令的作用是去掉变量var从左边算起的第一个’.‘字符及其左边的内容,返回从左边算起第一个’.’(不含该字符)的右边部分的内容。使用例子及结果如下:
  2. \n
\n\n

从运行结果可以看到,使用该命令,可以提取出文件的多个后缀。

\n
    \n
  1. ${var%/*}
    \n该命令的使用是去掉变量var从右边算起的第一个’/‘字符及其右边的内容,返回从右边算起的第一个’/’(不含该字符)的左边的内容。使用例子及结果如下:
  2. \n
\n\n

从运行的结果可以看到,使用该命令,可以提取出我们需要的文件所在的目录

\n
    \n
  1. ${var%%.*}
    \n该命令的使用是去掉变量var从右边算起的最后一个’.‘字符及其右边的内容,返回从右边算起的最后一个’.’(不含该字符)的左边的内容。使用例子及结果如下:
  2. \n
\n\n

当我们需要建立一个与文件名相同名字(没有后缀)的目录与对应的文件相对应时,就可以使用该命令来进行操作。例如,解压文件的情况就与此类似,我们压缩文件file.zip时,会在与file.zip同级目录下建立一个名为file的目录。

\n
    \n
  1. 总结
  2. \n
\n

其实${}并不是专门为提取文件名或目录名的,它的使用是变量的提取和替换等等操作,它可以提取非常多的内容,并不一定是上面五个例子中的’/‘或’.’。也就是说,上面的使用方法只是它使用的一个特例。

\n

看到上面的这些命令,可能会让人感到非常难以理解和记忆,其实不然,它们都是有规律的。

\n
    \n
  • \n

    #:表示从左边算起第一个

    \n
  • \n
  • \n

    %:表示从右边算起第一个

    \n
  • \n
  • \n

    ##:表示从左边算起最后一个

    \n
  • \n
  • \n

    %%:表示从右边算起最后一个

    \n
  • \n
\n

换句话来说,#总是表示左边算起,%总是表示右边算起。

\n

*:表示要删除的内容,对于#和##的情况,它位于指定的字符(例子中的’/‘和’.’)的左边,表于删除指定字符及其左边的内容;对于%和%%的情况,它位于指定的字符(例子中的’/‘和’.’)的右边,表示删除指定字符及其右边的内容。这里的’'的位置不能互换,即不能把号放在#或##的右边,反之亦然。

\n

例如:${var%%x*}表示找出从右边算起最后一个字符x,并删除字符x及其右边的字符。

\n

看到这里,就可以知道,其实该命令的用途非常广泛,上面只是指针文件名和目录名的命名特性来进行提取的一些特例而已。

\n

basename和dirname

\n

${}并不是专门为提取文件名和目录名设计的命令,那么basenamedirname命令就是专门为做这一件事而已准备的了。

\n
    \n
  1. basename
    \n该命令的作用是从路径中提取出文件名,使用方法为basename NAME [SUFFIX]。
  2. \n
\n

1.1 从路径中提出出文件名(带后缀),例子如下:

\n

1.2 从上面命令的用法中可以看到,后缀(SUFFIX)是一个可选项。所以,若只想提取出文件名file,而不带有后缀,还可以在变量的后面加上后缀名,例子如下:

\n
    \n
  1. dirname
    \n该命令的作用是从路径中提取出目录名,使用方法为 dirname NAME。使用例子如下:
  2. \n
\n

这样就提取出了file.txt文件所在的目录。

\n

注:该命令不仅能提取出普通文件所的目录,它能提取出任何文件所在的目录,例如目录所在的目录,如下:

\n

它提取出了目录dir2所在的目录dir1.

\n
\n

查看硬盘剩余空间

\n\n

查看 package 版本

\n\n

Windwos 下的脚本

\n

windows 下显示环境变量

\n

echo %http_proxy%

\n

windows 下设置代理服务器
\n$$

\n

$$

\n"},{"title":"用TypeScript编写JS函数库","date":"2019-08-16T20:15:28.000Z","urlname":"TypeScript-build-JS-Package","toc":true,"_content":"\n本文具体介绍如何用TypeScript编写JavaScript库文件,以及制作npm工具包。主要参考下面两篇文章。我也省却一步步解释,只罗列相关的代码和我遇到的坑。想知道代码含义的请参阅原帖\n\n- [TypeScript第一步](http://imzc.me/dev/2016/11/22/getting-start-with-typescript/)\n- [如何使用Gulp构建TypeScript](https://www.gowhich.com/blog/869)\n- [从Javascript迁移到Typescript](https://zhongsp.gitbooks.io/typescript-handbook/doc/handbook/tutorials/Migrating%20from%20JavaScript.html) *只看相关的那一章就可以*\n\n\n\n\n# 安装 TypeScript\n\n终端执行 `npm install typescript -g` \n\n```sh\n$ tsc --version\nVersion 3.5.3\n```\n\n# 创建工程\n\n1. 初始化项目\n\n```sh\nmkdir typescript_demo && cd typescript_demo\nnpm init -y # 初始化项目,会生成 package.json 文件\n```\n\n2. 安装Gulp, 并在项目根目录下新建 `gulpfile.js` 文件\n\n```sh\nnpm install gulp-cli gulp typescript gulp-typescript --save-dev\n```\n\n3. 在命令行中执行 `tsc --init` 可以在当前目录中快速创建一个 tsconfig.json 文件。\n\n4. 安装 Browserify :目的是把所有**ts**文件打包成一个单一的**js**文件。\n\n```sh\nnpm install browserify tsify vinyl-source-stream --save-dev\n```\n\n5. Watchify、Babel和Uglify :目的是让编译器保持运行,无需每次修改手动编译。\n\nnpm install watchify gulp-util --save-dev\n\n```sh\nnpm install watchify gulp-util --save-dev\n```\n\n6. 安装 Uglify : 将输出文件 bundle.js 压缩\n\n```sh\nnpm install gulp-uglify vinyl-buffer gulp-sourcemaps --save-dev\n```\n\n7. Babel :允许按新标准**ES6**编写代码,而最终会编译**es05**标准,兼容低版本浏览器。\n\n```sh\nnpm install babelify babel-core babel-preset-env vinyl-buffer gulp-sourcemaps --save-dev\n```\n\n:bangbang: 安装中出现了错误, 显示babelify 版本太低. 将命令改为 `npm install babelify@8` 就能顺利进行下去了.\n\n\n\n\n8. 编写主文件 `src/main.ts` (*名字随便起*),在 `package.json` 中改为 $ \"main\": \"./dist/main.js\", $。创建两文件夹 `src` 和 `dist`,分别放置原文件和编译后的文件。为演示调用,再新建一个 `src/greet.ts` 文件\n\n ```typescript\n # src/greet.ts\n declare function require(path: string): any;\n \n export function sayHello(name: string) {\n console.log(ln)\n return `Hallo von ${name}`;\n }\n ```\n\n ```typescript\n # src/main.ts\n import { sayHello } from \"./greet\";\n \n function showHello(idName: string, name: string) {\n const elt = document.getElementById(idName);\n elt.innerText = sayHello(name);\n }\n \n showHello(\"greeting\", \"TypeScript\");\n ```\n\n9. 新建 `src/index.html` \n\n```html\n\n\n \n \n Hello World!\n \n \n

Loading ...

\n \n \n\n```\n\n10. 修改 `gulpfile.js` \n\n```javascript\nconst gulp = require(\"gulp\");\nconst browserify = require(\"browserify\");\nconst source = require('vinyl-source-stream');\nconst tsify = require(\"tsify\");\nconst watchify = require(\"watchify\");\nconst gutil = require(\"gulp-util\");\nconst uglify = require('gulp-uglify');\nconst sourcemaps = require('gulp-sourcemaps');\nconst buffer = require('vinyl-buffer');\nconst paths = {\n pages: ['src/*.html']\n};\n\nconst watchedBrowserify = watchify(browserify({\n basedir: '.',\n debug: true,\n entries: ['src/main.ts'],\n cache: {},\n packageCache: {}\n}).plugin(tsify));\n\ngulp.task(\"copy-html\", function () {\n return gulp.src(paths.pages)\n .pipe(gulp.dest(\"dist\"));\n})\n\nfunction browserifyBundle() {\n return watchedBrowserify\n .transform('babelify', {\n presets: ['env'],\n extensions: ['.ts']\n })\n .bundle()\n .pipe(source('bundle.js'))\n .pipe(buffer())\n .pipe(sourcemaps.init({\n loadMaps: true\n }))\n .pipe(uglify())\n .pipe(sourcemaps.write('./'))\n .pipe(gulp.dest(\"dist\"));\n}\n\ngulp.task(\"browserify\", function () {\n return browserifyBundle();\n})\n\ngulp.task(\"default\", gulp.series('copy-html', 'browserify'));\nwatchedBrowserify.on(\"update\", browserifyBundle);\nwatchedBrowserify.on(\"log\", gutil.log);\n```\n11. 修改 tsconfig.json\n\n ```json\n {\n \"files\": [\n \"src/*.ts\"\n ],\n \"compilerOptions\": {\n \"noImplicitAny\": true,\n \"target\": \"es2015\"\n }\n }\n ```\n\n12. 编译并在浏览器打开 `dist/index.html`\n\n```sh\n# 通过gulp编译代码\nnpx gulp\n```\n\n> 显示器中会显示 “Hello from TypeScript” 字样。\n\n\n\n我们看到 main.ts 调用了 greet.ts 的函数, 并生成一个 bundle.js 文件, 在 index.html 中被加载使用. \n\n\n\n# 调用JavaScript文件\n\n为了使用以前已经存在的JavaScript库文件, 在 src 下新建一个文件夹 libs 用来存放第三方JavaScript. \n\n> projectRoot\n> ├── src/\n> │ ├── libs/\n> │ │ ├── lunar.js\n> │ ├── main.ts\n> │ └── greet.ts\n> │ \n> ├── dist/\n> └── tsconfig.json\n\n```javascript\n# src/libs/lunar.js\n\nLunar = {\n Name: \"Dick\",\n sayHallo:function(){\n return 'i am Lunar';\n }\n} \n\nfunction Ab () {\n this.a = 1\n }\n \nAb.prototype.seta = function (num) {\n this.a = num\n }\n \nAb.prototype.geta = function (num) {\n return this.a\n }\n \nexports.Ab = Ab\nexports.Lunar = Lunar;\n\n```\n\n修改 `greet.ts` 文件, 调用 `src/libs/lunar.js` 中的函数和对象\n\n```typescript\ndeclare function require(path: string): any;\n\nvar ln = require(\"./libs/lunar\");\n\nexport function sayHello(name: string) {\n \tln.Ab = 10\n console.log(ln.Ab)\n return `Hallo von ${name}, ${ln.Lunar.Name}`;\n}\n```\n\nTypeScript使用`tsconfig.json`文件管理工程配置,例如想包含哪些文件和进行哪些检查。\n\n```json\n{\n \"compilerOptions\": {\n \t\t\"noImplicitAny\": true, \n //\"outDir\": \"./dist\", //不需要. gulpfile.js 已经处理过了\n \"allowJs\": true,\n \"target\": \"es2015\",\n \"esModuleInterop\": true /* Enables emit interoperability between CommonJS and ES Modules via creation of namespace objects for all imports. Implies 'allowSyntheticDefaultImports'. */\n },\n \"files\": [\n \"src/*.ts\"\n ],\n \"include\": [\n \"./src/**/*.js\"\n ]\n}\n```\n\n\n\n我们看到网页显示 *Hallo von TypeScript, Dick*, 打开chrome的开发者工具, 看到console 中写出 `10`. \n\n\n\n# Unit-Test\n\n[参考:Unit testing node applications with Typescript -- using nocha and chai](https://journal.artfuldev.com/unit-testing-node-applications-with-typescript-using-mocha-and-chai-384ef05f32b2)\n\n1. 安装测试包文件\n\n```sh\nnpm install chai mocha ts-node @types/chai @types/mocha --save-dev\n```\n\n2. 新建一个test目录专门存放测试文件,并新建一个测试文件 `test/ganzhi.spec.ts`\n\n```typescript\nimport { expect } from 'chai';\nimport 'mocha';\n\ndescribe('干支 function', () => {\n\n it('should return hello world', () => {\n const result = 'Hello world!';\n expect(result).to.equal('Hello world!');\n });\n \n });\n```\n\n3. 在 `package.json` 文件中配置测试参数和路径\n\n```json\n{\n \"scripts\": {\n \"test\": \"mocha -r ts-node/register test/**/*.spec.ts\"\n }\n}\n```\n\n4. 运行测试\n\n> $ npm run test\n>\n> \\> huahets@1.0.0 test /Users/mai/Projects/huahets\n>\n> \\> mocha -r ts-node/register test/**/*.spec.ts\n>\n> 干支 function\n>\n> ​ ✓ should return hello world\n>\n> 1 passing (19ms)\n\n\n\n## 错误处理\n\n假设有以下函数调用中`LandMaps.FindCity`会给出一个异常。\n\n```typescript\nvar result = LandMaps.FindCity(\"xx省\", \"xx市\");\nexpect(LandMaps.FindCity.bind(LandMaps, \"err\", \"\")).throw(\"Error Message\") # 或者\nexpect(LandMaps.FindCity.bind(LandMaps, \"err\", \"\")).throw(new Error(\"Error Message\"))\n```\n\n\n\n# 打包\n\n[用 TypeScript 编写函数库](https://www.xuejiayuan.net/blog/27db473912f642d8a5fa0e32af3bb600)\n\n[require.js 官方文档](https://requirejs.org/docs/start.html)\n\n通过上述方式生成的 bundle.js 文件不能被浏览器直接使用。参考上面两个网页提供的方式,可以生成给浏览器用的单一js文件。\n\n1. 新建一个入口文件,将所有接口都连接起来,并统一导出\n\n ```typescript\n # yixue.ts\n import {TYDate, TYLunar} from \"./tylunar\";\n import {GanZhi} from \"./ganzhi\";\n import {ShenSha} from \"./shensha\";\n import {WuXing, FetchWuXing} from \"./wuxing\";\n import {Gua} from './gua'\n import {LandMaps} from \"./landmaps\"\n \n exports.GanZhi = GanZhi\n exports.TYDate = TYDate\n exports.Gua = Gua\n ```\n2. 设置`tsconfig.json`让编译后的文件导出到`dist/cmjs`目录\n\n```json\n{\n \"compilerOptions\": {\n \"target\": \"es5\",\n \"module\": \"commonjs\",\n \"moduleResolution\": \"node\",\n \"outDir\": \"dist/cmjs\",\n \"rootDir\": \"./src\",\n \"declaration\": true,\n \"sourceMap\": true,\n \"lib\": [\"dom\", \"es6\"]\n }\n}\n```\n\n3. 通过命令 tsc 编译\n\n```sh\ntsc -P tsconfig.json\n```\n\n也可以在 package.json 中设定,然后运行 `npm run build:cmjs` 编译。编译后的 yixue.js 文件就是统一入口。\n\n4. yi xue.js 实际就是个目录,我需要将其打包成一个单一文件。 安装 browserify , \n\n```sh\nbrowserify dist/cmjs/base/yixue.js --standalone huahejs -o dist/web/yixue.js\n```\n\n5. 下载 [require.js](https://requirejs.org/docs/start.html), 并放到项目目录中。以下方式将 yixue.js 中的 `class GanZhi` 设为当前网页的一个全局函数。其它函数就可以调用。 \n\n```html\n\n\n \n \n 易学包\n \n \n

易学包测试

\n \n\n
\n
gua
\n \n\n```\n\n6. 在 Node.js 中调用更简单\n\n1. ```javascript\n const {Gua, GanZhi, TYDate} = require(\"./web/yixue\")\n ```\n\n\n\n\n\n\n\n\n需要更详细代码请下载项目:\n\n[演示项目地址](https://gitee.com/maiernte/typescript-build-js-package)","source":"_posts/IT/skill/用Typescript编写JS函数库.md","raw":"---\ntitle: 用TypeScript编写JS函数库\ndate: 2019-08-16 22:15:28\nurlname: TypeScript-build-JS-Package\ntoc: true\ntags: [工具]\ncategories: [IT, skill]\n---\n\n本文具体介绍如何用TypeScript编写JavaScript库文件,以及制作npm工具包。主要参考下面两篇文章。我也省却一步步解释,只罗列相关的代码和我遇到的坑。想知道代码含义的请参阅原帖\n\n- [TypeScript第一步](http://imzc.me/dev/2016/11/22/getting-start-with-typescript/)\n- [如何使用Gulp构建TypeScript](https://www.gowhich.com/blog/869)\n- [从Javascript迁移到Typescript](https://zhongsp.gitbooks.io/typescript-handbook/doc/handbook/tutorials/Migrating%20from%20JavaScript.html) *只看相关的那一章就可以*\n\n\n\n\n# 安装 TypeScript\n\n终端执行 `npm install typescript -g` \n\n```sh\n$ tsc --version\nVersion 3.5.3\n```\n\n# 创建工程\n\n1. 初始化项目\n\n```sh\nmkdir typescript_demo && cd typescript_demo\nnpm init -y # 初始化项目,会生成 package.json 文件\n```\n\n2. 安装Gulp, 并在项目根目录下新建 `gulpfile.js` 文件\n\n```sh\nnpm install gulp-cli gulp typescript gulp-typescript --save-dev\n```\n\n3. 在命令行中执行 `tsc --init` 可以在当前目录中快速创建一个 tsconfig.json 文件。\n\n4. 安装 Browserify :目的是把所有**ts**文件打包成一个单一的**js**文件。\n\n```sh\nnpm install browserify tsify vinyl-source-stream --save-dev\n```\n\n5. Watchify、Babel和Uglify :目的是让编译器保持运行,无需每次修改手动编译。\n\nnpm install watchify gulp-util --save-dev\n\n```sh\nnpm install watchify gulp-util --save-dev\n```\n\n6. 安装 Uglify : 将输出文件 bundle.js 压缩\n\n```sh\nnpm install gulp-uglify vinyl-buffer gulp-sourcemaps --save-dev\n```\n\n7. Babel :允许按新标准**ES6**编写代码,而最终会编译**es05**标准,兼容低版本浏览器。\n\n```sh\nnpm install babelify babel-core babel-preset-env vinyl-buffer gulp-sourcemaps --save-dev\n```\n\n:bangbang: 安装中出现了错误, 显示babelify 版本太低. 将命令改为 `npm install babelify@8` 就能顺利进行下去了.\n\n\n\n\n8. 编写主文件 `src/main.ts` (*名字随便起*),在 `package.json` 中改为 $ \"main\": \"./dist/main.js\", $。创建两文件夹 `src` 和 `dist`,分别放置原文件和编译后的文件。为演示调用,再新建一个 `src/greet.ts` 文件\n\n ```typescript\n # src/greet.ts\n declare function require(path: string): any;\n \n export function sayHello(name: string) {\n console.log(ln)\n return `Hallo von ${name}`;\n }\n ```\n\n ```typescript\n # src/main.ts\n import { sayHello } from \"./greet\";\n \n function showHello(idName: string, name: string) {\n const elt = document.getElementById(idName);\n elt.innerText = sayHello(name);\n }\n \n showHello(\"greeting\", \"TypeScript\");\n ```\n\n9. 新建 `src/index.html` \n\n```html\n\n\n \n \n Hello World!\n \n \n

Loading ...

\n \n \n\n```\n\n10. 修改 `gulpfile.js` \n\n```javascript\nconst gulp = require(\"gulp\");\nconst browserify = require(\"browserify\");\nconst source = require('vinyl-source-stream');\nconst tsify = require(\"tsify\");\nconst watchify = require(\"watchify\");\nconst gutil = require(\"gulp-util\");\nconst uglify = require('gulp-uglify');\nconst sourcemaps = require('gulp-sourcemaps');\nconst buffer = require('vinyl-buffer');\nconst paths = {\n pages: ['src/*.html']\n};\n\nconst watchedBrowserify = watchify(browserify({\n basedir: '.',\n debug: true,\n entries: ['src/main.ts'],\n cache: {},\n packageCache: {}\n}).plugin(tsify));\n\ngulp.task(\"copy-html\", function () {\n return gulp.src(paths.pages)\n .pipe(gulp.dest(\"dist\"));\n})\n\nfunction browserifyBundle() {\n return watchedBrowserify\n .transform('babelify', {\n presets: ['env'],\n extensions: ['.ts']\n })\n .bundle()\n .pipe(source('bundle.js'))\n .pipe(buffer())\n .pipe(sourcemaps.init({\n loadMaps: true\n }))\n .pipe(uglify())\n .pipe(sourcemaps.write('./'))\n .pipe(gulp.dest(\"dist\"));\n}\n\ngulp.task(\"browserify\", function () {\n return browserifyBundle();\n})\n\ngulp.task(\"default\", gulp.series('copy-html', 'browserify'));\nwatchedBrowserify.on(\"update\", browserifyBundle);\nwatchedBrowserify.on(\"log\", gutil.log);\n```\n11. 修改 tsconfig.json\n\n ```json\n {\n \"files\": [\n \"src/*.ts\"\n ],\n \"compilerOptions\": {\n \"noImplicitAny\": true,\n \"target\": \"es2015\"\n }\n }\n ```\n\n12. 编译并在浏览器打开 `dist/index.html`\n\n```sh\n# 通过gulp编译代码\nnpx gulp\n```\n\n> 显示器中会显示 “Hello from TypeScript” 字样。\n\n\n\n我们看到 main.ts 调用了 greet.ts 的函数, 并生成一个 bundle.js 文件, 在 index.html 中被加载使用. \n\n\n\n# 调用JavaScript文件\n\n为了使用以前已经存在的JavaScript库文件, 在 src 下新建一个文件夹 libs 用来存放第三方JavaScript. \n\n> projectRoot\n> ├── src/\n> │ ├── libs/\n> │ │ ├── lunar.js\n> │ ├── main.ts\n> │ └── greet.ts\n> │ \n> ├── dist/\n> └── tsconfig.json\n\n```javascript\n# src/libs/lunar.js\n\nLunar = {\n Name: \"Dick\",\n sayHallo:function(){\n return 'i am Lunar';\n }\n} \n\nfunction Ab () {\n this.a = 1\n }\n \nAb.prototype.seta = function (num) {\n this.a = num\n }\n \nAb.prototype.geta = function (num) {\n return this.a\n }\n \nexports.Ab = Ab\nexports.Lunar = Lunar;\n\n```\n\n修改 `greet.ts` 文件, 调用 `src/libs/lunar.js` 中的函数和对象\n\n```typescript\ndeclare function require(path: string): any;\n\nvar ln = require(\"./libs/lunar\");\n\nexport function sayHello(name: string) {\n \tln.Ab = 10\n console.log(ln.Ab)\n return `Hallo von ${name}, ${ln.Lunar.Name}`;\n}\n```\n\nTypeScript使用`tsconfig.json`文件管理工程配置,例如想包含哪些文件和进行哪些检查。\n\n```json\n{\n \"compilerOptions\": {\n \t\t\"noImplicitAny\": true, \n //\"outDir\": \"./dist\", //不需要. gulpfile.js 已经处理过了\n \"allowJs\": true,\n \"target\": \"es2015\",\n \"esModuleInterop\": true /* Enables emit interoperability between CommonJS and ES Modules via creation of namespace objects for all imports. Implies 'allowSyntheticDefaultImports'. */\n },\n \"files\": [\n \"src/*.ts\"\n ],\n \"include\": [\n \"./src/**/*.js\"\n ]\n}\n```\n\n\n\n我们看到网页显示 *Hallo von TypeScript, Dick*, 打开chrome的开发者工具, 看到console 中写出 `10`. \n\n\n\n# Unit-Test\n\n[参考:Unit testing node applications with Typescript -- using nocha and chai](https://journal.artfuldev.com/unit-testing-node-applications-with-typescript-using-mocha-and-chai-384ef05f32b2)\n\n1. 安装测试包文件\n\n```sh\nnpm install chai mocha ts-node @types/chai @types/mocha --save-dev\n```\n\n2. 新建一个test目录专门存放测试文件,并新建一个测试文件 `test/ganzhi.spec.ts`\n\n```typescript\nimport { expect } from 'chai';\nimport 'mocha';\n\ndescribe('干支 function', () => {\n\n it('should return hello world', () => {\n const result = 'Hello world!';\n expect(result).to.equal('Hello world!');\n });\n \n });\n```\n\n3. 在 `package.json` 文件中配置测试参数和路径\n\n```json\n{\n \"scripts\": {\n \"test\": \"mocha -r ts-node/register test/**/*.spec.ts\"\n }\n}\n```\n\n4. 运行测试\n\n> $ npm run test\n>\n> \\> huahets@1.0.0 test /Users/mai/Projects/huahets\n>\n> \\> mocha -r ts-node/register test/**/*.spec.ts\n>\n> 干支 function\n>\n> ​ ✓ should return hello world\n>\n> 1 passing (19ms)\n\n\n\n## 错误处理\n\n假设有以下函数调用中`LandMaps.FindCity`会给出一个异常。\n\n```typescript\nvar result = LandMaps.FindCity(\"xx省\", \"xx市\");\nexpect(LandMaps.FindCity.bind(LandMaps, \"err\", \"\")).throw(\"Error Message\") # 或者\nexpect(LandMaps.FindCity.bind(LandMaps, \"err\", \"\")).throw(new Error(\"Error Message\"))\n```\n\n\n\n# 打包\n\n[用 TypeScript 编写函数库](https://www.xuejiayuan.net/blog/27db473912f642d8a5fa0e32af3bb600)\n\n[require.js 官方文档](https://requirejs.org/docs/start.html)\n\n通过上述方式生成的 bundle.js 文件不能被浏览器直接使用。参考上面两个网页提供的方式,可以生成给浏览器用的单一js文件。\n\n1. 新建一个入口文件,将所有接口都连接起来,并统一导出\n\n ```typescript\n # yixue.ts\n import {TYDate, TYLunar} from \"./tylunar\";\n import {GanZhi} from \"./ganzhi\";\n import {ShenSha} from \"./shensha\";\n import {WuXing, FetchWuXing} from \"./wuxing\";\n import {Gua} from './gua'\n import {LandMaps} from \"./landmaps\"\n \n exports.GanZhi = GanZhi\n exports.TYDate = TYDate\n exports.Gua = Gua\n ```\n2. 设置`tsconfig.json`让编译后的文件导出到`dist/cmjs`目录\n\n```json\n{\n \"compilerOptions\": {\n \"target\": \"es5\",\n \"module\": \"commonjs\",\n \"moduleResolution\": \"node\",\n \"outDir\": \"dist/cmjs\",\n \"rootDir\": \"./src\",\n \"declaration\": true,\n \"sourceMap\": true,\n \"lib\": [\"dom\", \"es6\"]\n }\n}\n```\n\n3. 通过命令 tsc 编译\n\n```sh\ntsc -P tsconfig.json\n```\n\n也可以在 package.json 中设定,然后运行 `npm run build:cmjs` 编译。编译后的 yixue.js 文件就是统一入口。\n\n4. yi xue.js 实际就是个目录,我需要将其打包成一个单一文件。 安装 browserify , \n\n```sh\nbrowserify dist/cmjs/base/yixue.js --standalone huahejs -o dist/web/yixue.js\n```\n\n5. 下载 [require.js](https://requirejs.org/docs/start.html), 并放到项目目录中。以下方式将 yixue.js 中的 `class GanZhi` 设为当前网页的一个全局函数。其它函数就可以调用。 \n\n```html\n\n\n \n \n 易学包\n \n \n

易学包测试

\n \n\n
\n
gua
\n \n\n```\n\n6. 在 Node.js 中调用更简单\n\n1. ```javascript\n const {Gua, GanZhi, TYDate} = require(\"./web/yixue\")\n ```\n\n\n\n\n\n\n\n\n需要更详细代码请下载项目:\n\n[演示项目地址](https://gitee.com/maiernte/typescript-build-js-package)","slug":"IT/skill/用Typescript编写JS函数库","published":1,"updated":"2019-08-24T11:30:40.000Z","_id":"cka1y599p004j4huucopvbcs0","comments":1,"layout":"post","photos":[],"link":"","content":"

本文具体介绍如何用TypeScript编写JavaScript库文件,以及制作npm工具包。主要参考下面两篇文章。我也省却一步步解释,只罗列相关的代码和我遇到的坑。想知道代码含义的请参阅原帖

\n\n\n

安装 TypeScript

\n

终端执行 npm install typescript -g

\n
1
2
$ tsc --version
Version 3.5.3
\n

创建工程

\n
    \n
  1. 初始化项目
  2. \n
\n
1
2
mkdir typescript_demo && cd typescript_demo
npm init -y # 初始化项目,会生成 package.json 文件
\n
    \n
  1. 安装Gulp, 并在项目根目录下新建 gulpfile.js 文件
  2. \n
\n
1
npm install gulp-cli gulp typescript gulp-typescript --save-dev
\n
    \n
  1. \n

    在命令行中执行 tsc --init 可以在当前目录中快速创建一个 tsconfig.json 文件。

    \n
  2. \n
  3. \n

    安装 Browserify :目的是把所有ts文件打包成一个单一的js文件。

    \n
  4. \n
\n
1
npm install browserify tsify vinyl-source-stream --save-dev
\n
    \n
  1. Watchify、Babel和Uglify :目的是让编译器保持运行,无需每次修改手动编译。
  2. \n
\n

npm install watchify gulp-util --save-dev

\n
1
npm install watchify gulp-util --save-dev
\n
    \n
  1. 安装 Uglify : 将输出文件 bundle.js 压缩
  2. \n
\n
1
npm install gulp-uglify vinyl-buffer gulp-sourcemaps --save-dev
\n
    \n
  1. Babel :允许按新标准ES6编写代码,而最终会编译es05标准,兼容低版本浏览器。
  2. \n
\n
1
npm install babelify babel-core babel-preset-env vinyl-buffer gulp-sourcemaps --save-dev
\n

:bangbang: 安装中出现了错误, 显示babelify 版本太低. 将命令改为 npm install babelify@8 就能顺利进行下去了.

\n
    \n
  1. \n

    编写主文件 src/main.ts (名字随便起),在 package.json 中改为 $ “main”: “./dist/main.js”, $。创建两文件夹 srcdist,分别放置原文件和编译后的文件。为演示调用,再新建一个 src/greet.ts 文件

    \n
    1
    2
    3
    4
    5
    6
    7
    # src/greet.ts
    declare function require(path: string): any;

    export function sayHello(name: string) {
    console.log(ln)
    return `Hallo von ${name}`;
    }
    \n
    1
    2
    3
    4
    5
    6
    7
    8
    9
    # src/main.ts
    import { sayHello } from \"./greet\";

    function showHello(idName: string, name: string) {
    const elt = document.getElementById(idName);
    elt.innerText = sayHello(name);
    }

    showHello(\"greeting\", \"TypeScript\");
    \n
  2. \n
  3. \n

    新建 src/index.html

    \n
  4. \n
\n
1
2
3
4
5
6
7
8
9
10
11
<!DOCTYPE html>
<html>
<head>
<meta charset=\"UTF-8\" />
<title>Hello World!</title>
</head>
<body>
<p id=\"greeting\">Loading ...</p>
<script src=\"bundle.js\"></script>
</body>
</html>
\n
    \n
  1. 修改 gulpfile.js
  2. \n
\n
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
const gulp = require(\"gulp\");
const browserify = require(\"browserify\");
const source = require('vinyl-source-stream');
const tsify = require(\"tsify\");
const watchify = require(\"watchify\");
const gutil = require(\"gulp-util\");
const uglify = require('gulp-uglify');
const sourcemaps = require('gulp-sourcemaps');
const buffer = require('vinyl-buffer');
const paths = {
pages: ['src/*.html']
};

const watchedBrowserify = watchify(browserify({
basedir: '.',
debug: true,
entries: ['src/main.ts'],
cache: {},
packageCache: {}
}).plugin(tsify));

gulp.task(\"copy-html\", function () {
return gulp.src(paths.pages)
.pipe(gulp.dest(\"dist\"));
})

function browserifyBundle() {
return watchedBrowserify
.transform('babelify', {
presets: ['env'],
extensions: ['.ts']
})
.bundle()
.pipe(source('bundle.js'))
.pipe(buffer())
.pipe(sourcemaps.init({
loadMaps: true
}))
.pipe(uglify())
.pipe(sourcemaps.write('./'))
.pipe(gulp.dest(\"dist\"));
}

gulp.task(\"browserify\", function () {
return browserifyBundle();
})

gulp.task(\"default\", gulp.series('copy-html', 'browserify'));
watchedBrowserify.on(\"update\", browserifyBundle);
watchedBrowserify.on(\"log\", gutil.log);
\n
    \n
  1. \n

    修改 tsconfig.json

    \n
    1
    2
    3
    4
    5
    6
    7
    8
    9
    {
    \"files\": [
    \"src/*.ts\"
    ],
    \"compilerOptions\": {
    \"noImplicitAny\": true,
    \"target\": \"es2015\"
    }
    }
    \n
  2. \n
  3. \n

    编译并在浏览器打开 dist/index.html

    \n
  4. \n
\n
1
2
# 通过gulp编译代码
npx gulp
\n
\n

显示器中会显示 “Hello from TypeScript” 字样。

\n
\n

我们看到 main.ts 调用了 greet.ts 的函数, 并生成一个 bundle.js 文件, 在 index.html 中被加载使用.

\n

调用JavaScript文件

\n

为了使用以前已经存在的JavaScript库文件, 在 src 下新建一个文件夹 libs 用来存放第三方JavaScript.

\n
\n

projectRoot
\n├── src/
\n│ ├── libs/
\n│ │ ├── lunar.js
\n│ ├── main.ts
\n│ └── greet.ts
\n│
\n├── dist/
\n└── tsconfig.json

\n
\n
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
# src/libs/lunar.js

Lunar = {
Name: \"Dick\",
sayHallo:function(){
return 'i am Lunar';
}
}

function Ab () {
this.a = 1
}

Ab.prototype.seta = function (num) {
this.a = num
}

Ab.prototype.geta = function (num) {
return this.a
}

exports.Ab = Ab
exports.Lunar = Lunar;
\n

修改 greet.ts 文件, 调用 src/libs/lunar.js 中的函数和对象

\n
1
2
3
4
5
6
7
8
9
declare function require(path: string): any;

var ln = require(\"./libs/lunar\");

export function sayHello(name: string) {
\tln.Ab = 10
console.log(ln.Ab)
return `Hallo von ${name}, ${ln.Lunar.Name}`;
}
\n

TypeScript使用tsconfig.json文件管理工程配置,例如想包含哪些文件和进行哪些检查。

\n
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
{
\"compilerOptions\": {
\t\t\"noImplicitAny\": true,
//\"outDir\": \"./dist\", //不需要. gulpfile.js 已经处理过了
\"allowJs\": true,
\"target\": \"es2015\",
\"esModuleInterop\": true /* Enables emit interoperability between CommonJS and ES Modules via creation of namespace objects for all imports. Implies 'allowSyntheticDefaultImports'. */
},
\"files\": [
\"src/*.ts\"
],
\"include\": [
\"./src/**/*.js\"
]
}
\n

我们看到网页显示 Hallo von TypeScript, Dick, 打开chrome的开发者工具, 看到console 中写出 10.

\n

Unit-Test

\n

参考:Unit testing node applications with Typescript – using nocha and chai

\n
    \n
  1. 安装测试包文件
  2. \n
\n
1
npm install chai mocha ts-node @types/chai @types/mocha --save-dev
\n
    \n
  1. 新建一个test目录专门存放测试文件,并新建一个测试文件 test/ganzhi.spec.ts
  2. \n
\n
1
2
3
4
5
6
7
8
9
10
11
import { expect } from 'chai';
import 'mocha';

describe('干支 function', () => {

it('should return hello world', () => {
const result = 'Hello world!';
expect(result).to.equal('Hello world!');
});

});
\n
    \n
  1. package.json 文件中配置测试参数和路径
  2. \n
\n
1
2
3
4
5
{
\"scripts\": {
\"test\": \"mocha -r ts-node/register test/**/*.spec.ts\"
}
}
\n
    \n
  1. 运行测试
  2. \n
\n
\n

$ npm run test

\n

> huahets@1.0.0 test /Users/mai/Projects/huahets

\n

> mocha -r ts-node/register test/**/*.spec.ts

\n

干支 function

\n

​ ✓ should return hello world

\n

1 passing (19ms)

\n
\n

错误处理

\n

假设有以下函数调用中LandMaps.FindCity会给出一个异常。

\n
1
2
3
var result = LandMaps.FindCity(\"xx省\", \"xx市\");
expect(LandMaps.FindCity.bind(LandMaps, \"err\", \"\")).throw(\"Error Message\") # 或者
expect(LandMaps.FindCity.bind(LandMaps, \"err\", \"\")).throw(new Error(\"Error Message\"))
\n

打包

\n

用 TypeScript 编写函数库

\n

require.js 官方文档

\n

通过上述方式生成的 bundle.js 文件不能被浏览器直接使用。参考上面两个网页提供的方式,可以生成给浏览器用的单一js文件。

\n
    \n
  1. 新建一个入口文件,将所有接口都连接起来,并统一导出
  2. \n
\n
1
2
3
4
5
6
7
8
9
10
11
# yixue.ts
import {TYDate, TYLunar} from \"./tylunar\";
import {GanZhi} from \"./ganzhi\";
import {ShenSha} from \"./shensha\";
import {WuXing, FetchWuXing} from \"./wuxing\";
import {Gua} from './gua'
import {LandMaps} from \"./landmaps\"

exports.GanZhi = GanZhi
exports.TYDate = TYDate
exports.Gua = Gua
\n
    \n
  1. 设置tsconfig.json让编译后的文件导出到dist/cmjs目录
  2. \n
\n
1
2
3
4
5
6
7
8
9
10
11
12
{
\"compilerOptions\": {
\"target\": \"es5\",
\"module\": \"commonjs\",
\"moduleResolution\": \"node\",
\"outDir\": \"dist/cmjs\",
\"rootDir\": \"./src\",
\"declaration\": true,
\"sourceMap\": true,
\"lib\": [\"dom\", \"es6\"]
}
}
\n
    \n
  1. 通过命令 tsc 编译
  2. \n
\n
1
tsc -P tsconfig.json
\n

也可以在 package.json 中设定,然后运行 npm run build:cmjs 编译。编译后的 yixue.js 文件就是统一入口。

\n
    \n
  1. yi xue.js 实际就是个目录,我需要将其打包成一个单一文件。 安装 browserify ,
  2. \n
\n
1
browserify dist/cmjs/base/yixue.js --standalone huahejs -o dist/web/yixue.js
\n
    \n
  1. 下载 require.js, 并放到项目目录中。以下方式将 yixue.js 中的 class GanZhi 设为当前网页的一个全局函数。其它函数就可以调用。
  2. \n
\n
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
<!DOCTYPE html>
<html>
<head>
<meta charset=\"UTF-8\" />
<title>易学包</title>
<script type=\"text/javascript\"
src=\"libs/require.js\"></script>
<body >
<p id=\"greeting\">易学包测试</p>
<script>
var newGanZhi

requirejs([\"web/yixue\"], function(yixue) {
console.log(yixue)
newGanZhi = function(arg){
return new yixue.GanZhi(arg)
}

init()
});

function init(){
console.log(\"init will be called\")
var ele = document.getElementById(\"gz1\")
var gz = newGanZhi(1)
ele.innerText = gz.Name
}
</script>

<div id=\"gz1\"></div>
<div name=\"gua\">gua</div>
</body>
</html>
\n
    \n
  1. \n

    在 Node.js 中调用更简单

    \n
  2. \n
  3. \n
    1
    const {Gua, GanZhi, TYDate} = require(\"./web/yixue\")
    \n
  4. \n
\n

需要更详细代码请下载项目:

\n

演示项目地址

\n","site":{"data":{}},"excerpt":"

本文具体介绍如何用TypeScript编写JavaScript库文件,以及制作npm工具包。主要参考下面两篇文章。我也省却一步步解释,只罗列相关的代码和我遇到的坑。想知道代码含义的请参阅原帖

\n","more":"

安装 TypeScript

\n

终端执行 npm install typescript -g

\n\n

创建工程

\n
    \n
  1. 初始化项目
  2. \n
\n\n
    \n
  1. 安装Gulp, 并在项目根目录下新建 gulpfile.js 文件
  2. \n
\n\n
    \n
  1. \n

    在命令行中执行 tsc --init 可以在当前目录中快速创建一个 tsconfig.json 文件。

    \n
  2. \n
  3. \n

    安装 Browserify :目的是把所有ts文件打包成一个单一的js文件。

    \n
  4. \n
\n\n
    \n
  1. Watchify、Babel和Uglify :目的是让编译器保持运行,无需每次修改手动编译。
  2. \n
\n

npm install watchify gulp-util --save-dev

\n\n
    \n
  1. 安装 Uglify : 将输出文件 bundle.js 压缩
  2. \n
\n\n
    \n
  1. Babel :允许按新标准ES6编写代码,而最终会编译es05标准,兼容低版本浏览器。
  2. \n
\n\n

:bangbang: 安装中出现了错误, 显示babelify 版本太低. 将命令改为 npm install babelify@8 就能顺利进行下去了.

\n
    \n
  1. \n

    编写主文件 src/main.ts (名字随便起),在 package.json 中改为 $ “main”: “./dist/main.js”, $。创建两文件夹 srcdist,分别放置原文件和编译后的文件。为演示调用,再新建一个 src/greet.ts 文件

    \n\n\n
  2. \n
  3. \n

    新建 src/index.html

    \n
  4. \n
\n\n
    \n
  1. 修改 gulpfile.js
  2. \n
\n\n
    \n
  1. \n

    修改 tsconfig.json

    \n\n
  2. \n
  3. \n

    编译并在浏览器打开 dist/index.html

    \n
  4. \n
\n\n
\n

显示器中会显示 “Hello from TypeScript” 字样。

\n
\n

我们看到 main.ts 调用了 greet.ts 的函数, 并生成一个 bundle.js 文件, 在 index.html 中被加载使用.

\n

调用JavaScript文件

\n

为了使用以前已经存在的JavaScript库文件, 在 src 下新建一个文件夹 libs 用来存放第三方JavaScript.

\n
\n

projectRoot
\n├── src/
\n│ ├── libs/
\n│ │ ├── lunar.js
\n│ ├── main.ts
\n│ └── greet.ts
\n│
\n├── dist/
\n└── tsconfig.json

\n
\n\n

修改 greet.ts 文件, 调用 src/libs/lunar.js 中的函数和对象

\n\n

TypeScript使用tsconfig.json文件管理工程配置,例如想包含哪些文件和进行哪些检查。

\n\n

我们看到网页显示 Hallo von TypeScript, Dick, 打开chrome的开发者工具, 看到console 中写出 10.

\n

Unit-Test

\n

参考:Unit testing node applications with Typescript – using nocha and chai

\n
    \n
  1. 安装测试包文件
  2. \n
\n\n
    \n
  1. 新建一个test目录专门存放测试文件,并新建一个测试文件 test/ganzhi.spec.ts
  2. \n
\n\n
    \n
  1. package.json 文件中配置测试参数和路径
  2. \n
\n\n
    \n
  1. 运行测试
  2. \n
\n
\n

$ npm run test

\n

> huahets@1.0.0 test /Users/mai/Projects/huahets

\n

> mocha -r ts-node/register test/**/*.spec.ts

\n

干支 function

\n

​ ✓ should return hello world

\n

1 passing (19ms)

\n
\n

错误处理

\n

假设有以下函数调用中LandMaps.FindCity会给出一个异常。

\n\n

打包

\n

用 TypeScript 编写函数库

\n

require.js 官方文档

\n

通过上述方式生成的 bundle.js 文件不能被浏览器直接使用。参考上面两个网页提供的方式,可以生成给浏览器用的单一js文件。

\n
    \n
  1. 新建一个入口文件,将所有接口都连接起来,并统一导出
  2. \n
\n \n
    \n
  1. 设置tsconfig.json让编译后的文件导出到dist/cmjs目录
  2. \n
\n\n
    \n
  1. 通过命令 tsc 编译
  2. \n
\n\n

也可以在 package.json 中设定,然后运行 npm run build:cmjs 编译。编译后的 yixue.js 文件就是统一入口。

\n
    \n
  1. yi xue.js 实际就是个目录,我需要将其打包成一个单一文件。 安装 browserify ,
  2. \n
\n\n
    \n
  1. 下载 require.js, 并放到项目目录中。以下方式将 yixue.js 中的 class GanZhi 设为当前网页的一个全局函数。其它函数就可以调用。
  2. \n
\n\n
    \n
  1. \n

    在 Node.js 中调用更简单

    \n
  2. \n
  3. \n\n
  4. \n
\n

需要更详细代码请下载项目:

\n

演示项目地址

"},{"title":"MathJax用于易学领域","date":"2019-08-30T08:15:28.000Z","urlname":"mathjax-yixue-usage","toc":true,"mathjax":true,"_content":"\n关于利用 `MathJax` 和 `Katex` 数学公式解释器,实现易学上排六爻盘和八字盘个功能。今天实现了易学上的核心功能。有望将来能添加更多的函数,以便利各位同门以及广大易友。\n\n\n\n### 效果与演示\n\n\n无法观看油管的朋友请移步B站:[使用MathJax渲染六爻和八字盘](https://www.bilibili.com/video/av66317810/)\n\n\n\n\n### 安装和使用\n\n首先,你需要一个支持 Markdown (简称MD) 语言格式的文本编辑器。如果不知道什么是MD的话,请参阅以下介绍:\n\n- [Markdown介绍及使用教程](https://www.jianshu.com/p/7771794c88a1)\n\n- [Markdown - 简单的世界](https://wizardforcel.gitbooks.io/markdown-simple-world/index.html)\n\n- [认识与入门 Markdown](https://sspai.com/post/25137)\n\n\n\nMarkdown 语言**简约而优美**,可以自由转换成pdf、word、Html 等等各种其它格式的文本。可以推送到博客、微信公众号等等。虽然算卦是一个传统的行业,我们仍然不宜**固步自封**。MD语言支持MathJax和Katex书写Latex数学公式,可以写出非常漂亮的数学、物理、化学方面的公式。正式的科技刊物都要求用Latex格式。\n\n\n\n这个易学解决方案是对 MathJax 进行扩展,加入指定的易学公式,让 MathJax 解释器去完成公式渲染。它并不是一个独立的程序。需要构建在已有的MD文本编辑器之上。我使用一个文件夹存放所有的关于易学方面的MD文件,并将这个文件夹同步到 [坚果云](https://www.jianguoyun.com/#/),这样就可以实现多台电脑和移动端之间的同步,而不太需要一个独立的易学软件。甚至可以将MD文件导出为HTML文件,放到我的HEXO博客上(您正在阅读的这篇博文即是例子)。\n\n\n\n理论上所有支持Markdown语言和MathJax的文本编辑器,都可以改装。改装过程需要两段代码和一个库文件。\n\n#### 文本编辑器\n\n##### Typora \n\nTypora 是我个人最钟爱的MD编辑器,因此这里着重介绍。如果你喜欢用别的MD编辑器,比如iAWrte等,理论上可以用同样的方式改装。(无法百分百保证) 有需要的朋友可以私下联系我。\n\n最新的安装教程请参考[华鹤易学平台文档](https://maiernte.gitee.io/huahedocument/chapter6/libinstall.html)\n\n##### VSCode\n\n同样请移步[华鹤易学平台文档](https://maiernte.gitee.io/huahedocument/chapter6/libinstall.html)。那里有详细描述。\n\n\n\n#### Hexo博客\n\n🔔 注意:首先要检查自己的 Hexo 博客使用的渲染器是否默认开启了Katex或者MathJax数学插件。如果有的话需要卸载或者禁用数学插件,如果不能禁用,就必须更换Markdown渲染器。\n\n> 因为系统使用的数学插件会在网页生成之前就改动数学表达,这样无法使用我提供给的函数库。我提供给博客的方案是在浏览网页的时候,即时渲染易学公式。\n\n比如我之前用了 \"hexo-renderer-markdown-it-plus\" 渲染器就是强制使用 Katex 数学渲染的。\n\n```shell\nnpm un hexo-renderer-markdown-it-plus --save // 卸载\nnpm i hexo-renderer-markdown-it --save // 更换\n```\n\n然后将下列代码添加到文件模版就可以了。使用 swig 模版的是在 `/layout/_custom/header.swig` 或者 `/layout/index.swig` 。而使用 ejs 模版的是文件 `/layout/layout.ejs`\n\n```html\n\n\n\n\n\n\n\n\n\n\n```\n\n> 注意搜索 _config.yml 文件,\"math\", \"katex\", \"mathjax\" 等字样,发现有的话把他们禁用。\n\n\n\n#### Gitbook\n\n最新的安装教程请参考[华鹤易学平台文档](https://maiernte.gitee.io/huahedocument/chapter6/libinstall.html)\n\n\n\n### API 参数\n\n使用易学函数库非常简单,在经过改装的Markdown编辑器中,输入易学公式,并用两个 `$` 符号将公式前后围起来即可。MD语言一般默认两个 `$` 符号之间的文本是数学公式,它会调用MathJax对公式进行渲染。否则,它会认为这是普通文本,而不会做任何动作。\n\n#### 易学通用\n\n**命令:纳音** `\\nayin{干支名称}`\n\n【干支名称】 :就是甲子、己卯等六十甲子。\n\n例子1:`\\nayin{戊午}` --> $\\nayin{戊午}$\n\n**命令:干支日历** `\\timegz{时间参数}{年月日}`\n\n【时间参数】 :例如 2020-02-21。\n\n【年月日】 :省略时默认为`111`,即显示年月日。`0`表示不显示,`1`表示显示。\n\n例子1:`\\timegz{2020-02-21}` --> $\\timegz{2020-02-21}$\n\n例子2:`\\timegz{2020-02-21}{011}` --> $\\timegz{2020-02-21}{011}$\n\n\n#### 六爻\n\n**命令:爻符** `\\yao{爻名}`\n\n【爻名】:laoyin, laoyang,shaoyin,shaoyang, x, o, =, -, 交,重,阴,阳,0,1,2,3\n\n例子2:`\\yao{x}` --> $\\yao{x}$\n\n例子3:`\\yao{shaoyin}` --> $\\yao{shaoyin}$\n\n例子4:`\\yao{重}` --> $\\yao{重}$\n\n\n\n **命令:六爻排盘** `\\paigua{时令}{卦辞}{标识}`\n\n其中 【时令】、【卦辞】这两个参数是必须的,**【标识】**参数可以省略。\n\n【时令】允许的格式为:“1980-1-3 08:15”、“2019年3月4日”、“申月戊寅日”\n\n【卦辞】允许的格式为:“解之师”、“离为火”、“--==x-”、“0121100”、“阴阳阴交阴阳”\n\n【标识】由三部分组成:ID号、简排、字符大小。格式为:`guadi/s/5`\n\n- 「ID号」:随便一串字符,空白则默认为“gua1”。:x:不允许只有数字,因为会与参数「字符大小」混淆。如果一个文本出现多个六爻卦,则每个卦都需要指定一个ID号。否则下面的命令[卦爻细节](#guayao)不知道具体指向哪一个卦本。\n- 「简排」:只允许`s` 和 `l`两个英文字符的其中一个。`s` 表示只显示短名,如“妻财”显示为“财”,“青龙”显示为“龙”。`l` 则显示完整名称。留白则按照用户全局设定来显示。(参阅[用户设定](#code2))\n- 「字符大小」:允许 0 - 9 档。数字越大文字越大。默认大小为`5`或者用户的[全局设定](#code2)。\n\n例子5: `$\\paigua{1978年7月1日}{101201}{gua1}$` 效果\n$$\\paigua{1978年7月1日}{101201}{gua1}$$\n\n:pencil2: 如果文章很长,需要在指定位置重新显示一遍卦本,则可以使用重排命令。即让【时令】和【卦辞】两个参数留白,只给出【ID号】。如 `\\paigua{}{}{gua1}` 。留白的参数,仍然需要用大括号括起来,否则解释器会出错。\n\n\n\n **命令:卦爻细节** `\\guayao{标识}{位置}`\n\n使用前提:当前文本中已经排出至少一支六爻卦。\n\n【标识】:与排盘命令的「标识」参数等同。由ID号、简排、字符大小三个部分组成。其中「ID号」标识已经存在的六爻盘。\n\n【位置】:格式为 “ben1”、“fu3”、“bian5” 等,分别表示「本卦初爻」、「伏卦3爻」、「变卦5爻」\n\n\n\n例子6:`\\guayao{gua1}{ben4}` --> $\\guayao{gua1}{ben4}$\n\n> 例子6 中给出的「ID号」为例子5中指定的ID号 “gua1”,并要求显示本卦4爻的具体信息。\n\n\n\n#### 八字\n\n **命令:八字排盘** `\\paibazi{时间}{性别}{标识}[细节]`\n\n【时间】和【性别】参数必填,【标识】和【细节】参数可选。(如果要第二次显示已有的八字盘,则【时间】和【性别】参数可留白,只给定【标识】参数中的「ID号」)\n\n【时间】:允许格式 “1980-1-3 08:15”、“2019年3月4日 6时3分” \n\n【性别】:允许格式 “m”、“f”、“男”、“女”、“乾”、“坤”、\n\n【标识】:与排盘命令的「标识」参数等同。由ID号、简排、字符大小三个部分组成。\n\n【细节】:允许“藏干”、“长生”、“纳音”这三个中的一个或者多个,也可以留白。格式为 `藏干/纳音/长生`\n\n例子7:`\\paibazi{1990年5月1日 6:45}{男}{小明/s/5}`\n\n$\\paibazi{1990年5月1日 6:45}{男}{小明/5}$\n\n例子8:重排例子7的八字盘 `\\paibazi{}{}{小明/s/5}[纳音/藏干/长生]` ,并要求显示藏干和纳音等信息。\n\n$\\paibazi{}{}{小明/s/5}[纳音/藏干/长生]$\n\n\n\n **命令:八字细节** `\\bazi{标识}{类别}[细节]`\n\n使用前提:当前文本中已经排出至少一个八字盘。\n\n【标识】:与排盘命令的「标识」参数等同。由ID号、简排、字符大小三个部分组成。其中「ID号」标识已经存在的八字命盘。\n\n【类别】:支持 “神煞”、“大运”、“流年”、“小运” 四个选项。\n\n【细节】:具体含义视【类别】而定。\n\n- 类别为「神煞」时:「细节」为 1~ 9 的数字,表示每行列数。\n- 类别为「大运」时:` 1-9 纳音/藏干/长生/神煞` 前面的数字表示第几步大运,限定 1 到 10\n- 类别为「流年」和「小运」时: `2015 - 2019 纳音/藏干/长生/神煞` 前面的数字表示年份,注意不要超过命盘的生命周期,否则会出错。「纳音/藏干/长生/神煞」可以留白,也可只显示一两项。\n\n\n\n例子9: `\\bazi{小明}{神煞}[6]` 显示小明命盘的神煞,每行6列。\n\n$\\bazi{小明}{神煞}[6]$\n\n\n\n例子10: `\\bazi{小明}{大运}[2-3 ]` 显示小明的第二到第三步大运\n\n$\\bazi{小明}{大运}[2-3]$\n\n\n\n例子11: `\\bazi{小明}{流年}[2017-2019 纳音/藏干/长生/神煞]` 显示小明的2017到2019年的流年信息。\n\n$\\bazi{小明}{流年}[2017-2019 纳音/藏干/长生/神煞]$\n\n\n\n### 未来与展望\n\n我知道这篇文章介绍的工具,并非所有人都能使用。所以在不久的将来,还是要制作一个独立易学软件,以便易友在PC端和移动端都能按照传统的方式使用。但由于时间和精力原因,我无法保证完成时间。\n\n\n\n不断完善易学函数,提供更丰富的应用细节。在用户更为广泛的MD编辑器中实现此方式。比如有道云笔记、为知笔记、印象笔记等。并争取介绍移动端(Android & iOS)实现此方式。也希望在Gitbook中实现。\n\n\n\n希望能将师父的六爻和八字讲义,『增删卜易』等著作制作成Gitbook,将精彩的卦例和名人八字建成易学数据库。这样就可以通过我的易学函数直接获取, 比如 `\\paibazi{蒋介石}`。\n\n\n\n### 附录: \n\n#### 命令列表\n\n[纳音](#nayin)\n\n[爻符](#yao)\n\n[排卦](#paigua)\n\n[卦爻细节](#guayao)\n\n[排八字](#paibazi)\n\n[八字细节](#bazi)\n\n#### 发布\n\n脚本文件的[原始路径](https://github.com/maiernte/img/raw/master/libs/bundle.js)是`https://github.com/maiernte/img/raw/master/libs/bundle.js`。因为涉及到跨域问题,要通过 [Gitkack](https://raw.githack.com/) 重链接,把上述路径输入到 Githack 的地址框,会得到「应用地址」和「开发地址」。\n\n[应用地址](https://rawcdn.githack.com/maiernte/img/bb3c42dc26b0866a142bb905d1753ac483e0a474/libs/bundle.js):\n\n`https://rawcdn.githack.com/maiernte/img/11a1bb572a6875dbf434a7fc457ea2fdd329f7db/libs/bundle.js`\n\n[开发地址](https://raw.githack.com/maiernte/img/master/libs/bundle.js):\n\n`https://raw.githack.com/maiernte/img/master/libs/bundle.js`\n\n#### 查看当前易学函数库版本\n\n在 chrome 浏览其中打开此博文,Mac 系统中按 `⌘+⌥+I` ,Windows 系统 `Ctr+⇧+I`,或者 Chrome 菜单栏调出 “开发者工具”,选择 Console 页面,即可显示当前易学库版本和时间。","source":"_posts/IT/skill/MathJax用于易学领域.md","raw":"---\ntitle: MathJax用于易学领域\ndate: 2019-08-30 10:15:28\nurlname: mathjax-yixue-usage\ntoc: true\ntags: [工具]\ncategories: [IT, skill]\nmathjax: true\n---\n\n关于利用 `MathJax` 和 `Katex` 数学公式解释器,实现易学上排六爻盘和八字盘个功能。今天实现了易学上的核心功能。有望将来能添加更多的函数,以便利各位同门以及广大易友。\n\n\n\n### 效果与演示\n\n\n无法观看油管的朋友请移步B站:[使用MathJax渲染六爻和八字盘](https://www.bilibili.com/video/av66317810/)\n\n\n\n\n### 安装和使用\n\n首先,你需要一个支持 Markdown (简称MD) 语言格式的文本编辑器。如果不知道什么是MD的话,请参阅以下介绍:\n\n- [Markdown介绍及使用教程](https://www.jianshu.com/p/7771794c88a1)\n\n- [Markdown - 简单的世界](https://wizardforcel.gitbooks.io/markdown-simple-world/index.html)\n\n- [认识与入门 Markdown](https://sspai.com/post/25137)\n\n\n\nMarkdown 语言**简约而优美**,可以自由转换成pdf、word、Html 等等各种其它格式的文本。可以推送到博客、微信公众号等等。虽然算卦是一个传统的行业,我们仍然不宜**固步自封**。MD语言支持MathJax和Katex书写Latex数学公式,可以写出非常漂亮的数学、物理、化学方面的公式。正式的科技刊物都要求用Latex格式。\n\n\n\n这个易学解决方案是对 MathJax 进行扩展,加入指定的易学公式,让 MathJax 解释器去完成公式渲染。它并不是一个独立的程序。需要构建在已有的MD文本编辑器之上。我使用一个文件夹存放所有的关于易学方面的MD文件,并将这个文件夹同步到 [坚果云](https://www.jianguoyun.com/#/),这样就可以实现多台电脑和移动端之间的同步,而不太需要一个独立的易学软件。甚至可以将MD文件导出为HTML文件,放到我的HEXO博客上(您正在阅读的这篇博文即是例子)。\n\n\n\n理论上所有支持Markdown语言和MathJax的文本编辑器,都可以改装。改装过程需要两段代码和一个库文件。\n\n#### 文本编辑器\n\n##### Typora \n\nTypora 是我个人最钟爱的MD编辑器,因此这里着重介绍。如果你喜欢用别的MD编辑器,比如iAWrte等,理论上可以用同样的方式改装。(无法百分百保证) 有需要的朋友可以私下联系我。\n\n最新的安装教程请参考[华鹤易学平台文档](https://maiernte.gitee.io/huahedocument/chapter6/libinstall.html)\n\n##### VSCode\n\n同样请移步[华鹤易学平台文档](https://maiernte.gitee.io/huahedocument/chapter6/libinstall.html)。那里有详细描述。\n\n\n\n#### Hexo博客\n\n🔔 注意:首先要检查自己的 Hexo 博客使用的渲染器是否默认开启了Katex或者MathJax数学插件。如果有的话需要卸载或者禁用数学插件,如果不能禁用,就必须更换Markdown渲染器。\n\n> 因为系统使用的数学插件会在网页生成之前就改动数学表达,这样无法使用我提供给的函数库。我提供给博客的方案是在浏览网页的时候,即时渲染易学公式。\n\n比如我之前用了 \"hexo-renderer-markdown-it-plus\" 渲染器就是强制使用 Katex 数学渲染的。\n\n```shell\nnpm un hexo-renderer-markdown-it-plus --save // 卸载\nnpm i hexo-renderer-markdown-it --save // 更换\n```\n\n然后将下列代码添加到文件模版就可以了。使用 swig 模版的是在 `/layout/_custom/header.swig` 或者 `/layout/index.swig` 。而使用 ejs 模版的是文件 `/layout/layout.ejs`\n\n```html\n\n\n\n\n\n\n\n\n\n\n```\n\n> 注意搜索 _config.yml 文件,\"math\", \"katex\", \"mathjax\" 等字样,发现有的话把他们禁用。\n\n\n\n#### Gitbook\n\n最新的安装教程请参考[华鹤易学平台文档](https://maiernte.gitee.io/huahedocument/chapter6/libinstall.html)\n\n\n\n### API 参数\n\n使用易学函数库非常简单,在经过改装的Markdown编辑器中,输入易学公式,并用两个 `$` 符号将公式前后围起来即可。MD语言一般默认两个 `$` 符号之间的文本是数学公式,它会调用MathJax对公式进行渲染。否则,它会认为这是普通文本,而不会做任何动作。\n\n#### 易学通用\n\n**命令:纳音** `\\nayin{干支名称}`\n\n【干支名称】 :就是甲子、己卯等六十甲子。\n\n例子1:`\\nayin{戊午}` --> $\\nayin{戊午}$\n\n**命令:干支日历** `\\timegz{时间参数}{年月日}`\n\n【时间参数】 :例如 2020-02-21。\n\n【年月日】 :省略时默认为`111`,即显示年月日。`0`表示不显示,`1`表示显示。\n\n例子1:`\\timegz{2020-02-21}` --> $\\timegz{2020-02-21}$\n\n例子2:`\\timegz{2020-02-21}{011}` --> $\\timegz{2020-02-21}{011}$\n\n\n#### 六爻\n\n**命令:爻符** `\\yao{爻名}`\n\n【爻名】:laoyin, laoyang,shaoyin,shaoyang, x, o, =, -, 交,重,阴,阳,0,1,2,3\n\n例子2:`\\yao{x}` --> $\\yao{x}$\n\n例子3:`\\yao{shaoyin}` --> $\\yao{shaoyin}$\n\n例子4:`\\yao{重}` --> $\\yao{重}$\n\n\n\n **命令:六爻排盘** `\\paigua{时令}{卦辞}{标识}`\n\n其中 【时令】、【卦辞】这两个参数是必须的,**【标识】**参数可以省略。\n\n【时令】允许的格式为:“1980-1-3 08:15”、“2019年3月4日”、“申月戊寅日”\n\n【卦辞】允许的格式为:“解之师”、“离为火”、“--==x-”、“0121100”、“阴阳阴交阴阳”\n\n【标识】由三部分组成:ID号、简排、字符大小。格式为:`guadi/s/5`\n\n- 「ID号」:随便一串字符,空白则默认为“gua1”。:x:不允许只有数字,因为会与参数「字符大小」混淆。如果一个文本出现多个六爻卦,则每个卦都需要指定一个ID号。否则下面的命令[卦爻细节](#guayao)不知道具体指向哪一个卦本。\n- 「简排」:只允许`s` 和 `l`两个英文字符的其中一个。`s` 表示只显示短名,如“妻财”显示为“财”,“青龙”显示为“龙”。`l` 则显示完整名称。留白则按照用户全局设定来显示。(参阅[用户设定](#code2))\n- 「字符大小」:允许 0 - 9 档。数字越大文字越大。默认大小为`5`或者用户的[全局设定](#code2)。\n\n例子5: `$\\paigua{1978年7月1日}{101201}{gua1}$` 效果\n$$\\paigua{1978年7月1日}{101201}{gua1}$$\n\n:pencil2: 如果文章很长,需要在指定位置重新显示一遍卦本,则可以使用重排命令。即让【时令】和【卦辞】两个参数留白,只给出【ID号】。如 `\\paigua{}{}{gua1}` 。留白的参数,仍然需要用大括号括起来,否则解释器会出错。\n\n\n\n **命令:卦爻细节** `\\guayao{标识}{位置}`\n\n使用前提:当前文本中已经排出至少一支六爻卦。\n\n【标识】:与排盘命令的「标识」参数等同。由ID号、简排、字符大小三个部分组成。其中「ID号」标识已经存在的六爻盘。\n\n【位置】:格式为 “ben1”、“fu3”、“bian5” 等,分别表示「本卦初爻」、「伏卦3爻」、「变卦5爻」\n\n\n\n例子6:`\\guayao{gua1}{ben4}` --> $\\guayao{gua1}{ben4}$\n\n> 例子6 中给出的「ID号」为例子5中指定的ID号 “gua1”,并要求显示本卦4爻的具体信息。\n\n\n\n#### 八字\n\n **命令:八字排盘** `\\paibazi{时间}{性别}{标识}[细节]`\n\n【时间】和【性别】参数必填,【标识】和【细节】参数可选。(如果要第二次显示已有的八字盘,则【时间】和【性别】参数可留白,只给定【标识】参数中的「ID号」)\n\n【时间】:允许格式 “1980-1-3 08:15”、“2019年3月4日 6时3分” \n\n【性别】:允许格式 “m”、“f”、“男”、“女”、“乾”、“坤”、\n\n【标识】:与排盘命令的「标识」参数等同。由ID号、简排、字符大小三个部分组成。\n\n【细节】:允许“藏干”、“长生”、“纳音”这三个中的一个或者多个,也可以留白。格式为 `藏干/纳音/长生`\n\n例子7:`\\paibazi{1990年5月1日 6:45}{男}{小明/s/5}`\n\n$\\paibazi{1990年5月1日 6:45}{男}{小明/5}$\n\n例子8:重排例子7的八字盘 `\\paibazi{}{}{小明/s/5}[纳音/藏干/长生]` ,并要求显示藏干和纳音等信息。\n\n$\\paibazi{}{}{小明/s/5}[纳音/藏干/长生]$\n\n\n\n **命令:八字细节** `\\bazi{标识}{类别}[细节]`\n\n使用前提:当前文本中已经排出至少一个八字盘。\n\n【标识】:与排盘命令的「标识」参数等同。由ID号、简排、字符大小三个部分组成。其中「ID号」标识已经存在的八字命盘。\n\n【类别】:支持 “神煞”、“大运”、“流年”、“小运” 四个选项。\n\n【细节】:具体含义视【类别】而定。\n\n- 类别为「神煞」时:「细节」为 1~ 9 的数字,表示每行列数。\n- 类别为「大运」时:` 1-9 纳音/藏干/长生/神煞` 前面的数字表示第几步大运,限定 1 到 10\n- 类别为「流年」和「小运」时: `2015 - 2019 纳音/藏干/长生/神煞` 前面的数字表示年份,注意不要超过命盘的生命周期,否则会出错。「纳音/藏干/长生/神煞」可以留白,也可只显示一两项。\n\n\n\n例子9: `\\bazi{小明}{神煞}[6]` 显示小明命盘的神煞,每行6列。\n\n$\\bazi{小明}{神煞}[6]$\n\n\n\n例子10: `\\bazi{小明}{大运}[2-3 ]` 显示小明的第二到第三步大运\n\n$\\bazi{小明}{大运}[2-3]$\n\n\n\n例子11: `\\bazi{小明}{流年}[2017-2019 纳音/藏干/长生/神煞]` 显示小明的2017到2019年的流年信息。\n\n$\\bazi{小明}{流年}[2017-2019 纳音/藏干/长生/神煞]$\n\n\n\n### 未来与展望\n\n我知道这篇文章介绍的工具,并非所有人都能使用。所以在不久的将来,还是要制作一个独立易学软件,以便易友在PC端和移动端都能按照传统的方式使用。但由于时间和精力原因,我无法保证完成时间。\n\n\n\n不断完善易学函数,提供更丰富的应用细节。在用户更为广泛的MD编辑器中实现此方式。比如有道云笔记、为知笔记、印象笔记等。并争取介绍移动端(Android & iOS)实现此方式。也希望在Gitbook中实现。\n\n\n\n希望能将师父的六爻和八字讲义,『增删卜易』等著作制作成Gitbook,将精彩的卦例和名人八字建成易学数据库。这样就可以通过我的易学函数直接获取, 比如 `\\paibazi{蒋介石}`。\n\n\n\n### 附录: \n\n#### 命令列表\n\n[纳音](#nayin)\n\n[爻符](#yao)\n\n[排卦](#paigua)\n\n[卦爻细节](#guayao)\n\n[排八字](#paibazi)\n\n[八字细节](#bazi)\n\n#### 发布\n\n脚本文件的[原始路径](https://github.com/maiernte/img/raw/master/libs/bundle.js)是`https://github.com/maiernte/img/raw/master/libs/bundle.js`。因为涉及到跨域问题,要通过 [Gitkack](https://raw.githack.com/) 重链接,把上述路径输入到 Githack 的地址框,会得到「应用地址」和「开发地址」。\n\n[应用地址](https://rawcdn.githack.com/maiernte/img/bb3c42dc26b0866a142bb905d1753ac483e0a474/libs/bundle.js):\n\n`https://rawcdn.githack.com/maiernte/img/11a1bb572a6875dbf434a7fc457ea2fdd329f7db/libs/bundle.js`\n\n[开发地址](https://raw.githack.com/maiernte/img/master/libs/bundle.js):\n\n`https://raw.githack.com/maiernte/img/master/libs/bundle.js`\n\n#### 查看当前易学函数库版本\n\n在 chrome 浏览其中打开此博文,Mac 系统中按 `⌘+⌥+I` ,Windows 系统 `Ctr+⇧+I`,或者 Chrome 菜单栏调出 “开发者工具”,选择 Console 页面,即可显示当前易学库版本和时间。","slug":"IT/skill/MathJax用于易学领域","published":1,"updated":"2020-05-08T09:38:08.489Z","_id":"cka1y599q004l4huuz9r1vgbn","comments":1,"layout":"post","photos":[],"link":"","content":"

关于利用 MathJaxKatex 数学公式解释器,实现易学上排六爻盘和八字盘个功能。今天实现了易学上的核心功能。有望将来能添加更多的函数,以便利各位同门以及广大易友。

\n\n

效果与演示

\n\n无法观看油管的朋友请移步B站:[使用MathJax渲染六爻和八字盘](https://www.bilibili.com/video/av66317810/)\n

安装和使用

\n

首先,你需要一个支持 Markdown (简称MD) 语言格式的文本编辑器。如果不知道什么是MD的话,请参阅以下介绍:

\n\n

Markdown 语言简约而优美,可以自由转换成pdf、word、Html 等等各种其它格式的文本。可以推送到博客、微信公众号等等。虽然算卦是一个传统的行业,我们仍然不宜固步自封。MD语言支持MathJax和Katex书写Latex数学公式,可以写出非常漂亮的数学、物理、化学方面的公式。正式的科技刊物都要求用Latex格式。

\n

这个易学解决方案是对 MathJax 进行扩展,加入指定的易学公式,让 MathJax 解释器去完成公式渲染。它并不是一个独立的程序。需要构建在已有的MD文本编辑器之上。我使用一个文件夹存放所有的关于易学方面的MD文件,并将这个文件夹同步到 坚果云,这样就可以实现多台电脑和移动端之间的同步,而不太需要一个独立的易学软件。甚至可以将MD文件导出为HTML文件,放到我的HEXO博客上(您正在阅读的这篇博文即是例子)。

\n

理论上所有支持Markdown语言和MathJax的文本编辑器,都可以改装。改装过程需要两段代码和一个库文件。

\n

文本编辑器

\n
Typora
\n

Typora 是我个人最钟爱的MD编辑器,因此这里着重介绍。如果你喜欢用别的MD编辑器,比如iAWrte等,理论上可以用同样的方式改装。(无法百分百保证) 有需要的朋友可以私下联系我。

\n

最新的安装教程请参考华鹤易学平台文档

\n
VSCode
\n

同样请移步华鹤易学平台文档。那里有详细描述。

\n

Hexo博客

\n

🔔 注意:首先要检查自己的 Hexo 博客使用的渲染器是否默认开启了Katex或者MathJax数学插件。如果有的话需要卸载或者禁用数学插件,如果不能禁用,就必须更换Markdown渲染器。

\n
\n

因为系统使用的数学插件会在网页生成之前就改动数学表达,这样无法使用我提供给的函数库。我提供给博客的方案是在浏览网页的时候,即时渲染易学公式。

\n
\n

比如我之前用了 “hexo-renderer-markdown-it-plus” 渲染器就是强制使用 Katex 数学渲染的。

\n
1
2
npm un hexo-renderer-markdown-it-plus --save // 卸载
npm i hexo-renderer-markdown-it --save // 更换
\n

然后将下列代码添加到文件模版就可以了。使用 swig 模版的是在 <your thems>/layout/_custom/header.swig 或者 <your thems>/layout/index.swig 。而使用 ejs 模版的是文件 <your thems>/layout/layout.ejs

\n
1
2
3
4
5
6
7
8
9
<!--前三行最好添加到 <header></header> 头区块中-->

<link rel=\"stylesheet\" href=\"https://cdn.jsdelivr.net/npm/katex@0.11.0/dist/katex.min.css\" >
<script defer src=\"https://cdn.jsdelivr.net/npm/katex@0.11.0/dist/katex.min.js\" ></script>
<script defer src=\"https://cdn.jsdelivr.net/npm/katex@0.11.0/dist/contrib/auto-render.min.js\"></script>


<script src=\"https://raw.githack.com/maiernte/img/master/libs/katexYixue.js\"></script>
<script src=\"https://raw.githack.com/maiernte/img/master/libs/bundle.js\"></script>
\n
\n

注意搜索 _config.yml 文件,“math”, “katex”, “mathjax” 等字样,发现有的话把他们禁用。

\n
\n

Gitbook

\n

最新的安装教程请参考华鹤易学平台文档

\n

API 参数

\n

使用易学函数库非常简单,在经过改装的Markdown编辑器中,输入易学公式,并用两个 $ 符号将公式前后围起来即可。MD语言一般默认两个 $ 符号之间的文本是数学公式,它会调用MathJax对公式进行渲染。否则,它会认为这是普通文本,而不会做任何动作。

\n

易学通用

\n

命令:纳音 \\nayin{干支名称}

\n

【干支名称】 :就是甲子、己卯等六十甲子。

\n

例子1:\\nayin{戊午} --> $\\nayin{戊午}$

\n

命令:干支日历 \\timegz{时间参数}{年月日}

\n

【时间参数】 :例如 2020-02-21。

\n

【年月日】 :省略时默认为111,即显示年月日。0表示不显示,1表示显示。

\n

例子1:\\timegz{2020-02-21} --> $\\timegz{2020-02-21}$

\n

例子2:\\timegz{2020-02-21}{011} --> $\\timegz{2020-02-21}{011}$

\n

六爻

\n

命令:爻符 \\yao{爻名}

\n

【爻名】:laoyin, laoyang,shaoyin,shaoyang, x, o, =, -, 交,重,阴,阳,0,1,2,3

\n

例子2:\\yao{x} --> $\\yao{x}$

\n

例子3:\\yao{shaoyin} --> $\\yao{shaoyin}$

\n

例子4:\\yao{重} --> $\\yao{重}$

\n

命令:六爻排盘 \\paigua{时令}{卦辞}{标识}

\n

其中 【时令】、【卦辞】这两个参数是必须的,**【标识】**参数可以省略。

\n

【时令】允许的格式为:“1980-1-3 08:15”、“2019年3月4日”、“申月戊寅日”

\n

【卦辞】允许的格式为:“解之师”、“离为火”、“–==x-”、“0121100”、“阴阳阴交阴阳”

\n

【标识】由三部分组成:ID号、简排、字符大小。格式为:guadi/s/5

\n
    \n
  • 「ID号」:随便一串字符,空白则默认为“gua1”。:x:不允许只有数字,因为会与参数「字符大小」混淆。如果一个文本出现多个六爻卦,则每个卦都需要指定一个ID号。否则下面的命令卦爻细节不知道具体指向哪一个卦本。
  • \n
  • 「简排」:只允许sl两个英文字符的其中一个。s 表示只显示短名,如“妻财”显示为“财”,“青龙”显示为“龙”。l 则显示完整名称。留白则按照用户全局设定来显示。(参阅用户设定
  • \n
  • 「字符大小」:允许 0 - 9 档。数字越大文字越大。默认大小为5或者用户的全局设定
  • \n
\n

例子5: $\\paigua{1978年7月1日}{101201}{gua1}$ 效果
\n$$\\paigua{1978年7月1日}{101201}{gua1}$$

\n

:pencil2: 如果文章很长,需要在指定位置重新显示一遍卦本,则可以使用重排命令。即让【时令】和【卦辞】两个参数留白,只给出【ID号】。如 \\paigua{}{}{gua1} 。留白的参数,仍然需要用大括号括起来,否则解释器会出错。

\n

命令:卦爻细节 \\guayao{标识}{位置}

\n

使用前提:当前文本中已经排出至少一支六爻卦。

\n

【标识】:与排盘命令的「标识」参数等同。由ID号、简排、字符大小三个部分组成。其中「ID号」标识已经存在的六爻盘。

\n

【位置】:格式为 “ben1”、“fu3”、“bian5” 等,分别表示「本卦初爻」、「伏卦3爻」、「变卦5爻」

\n

例子6:\\guayao{gua1}{ben4} --> $\\guayao{gua1}{ben4}$

\n
\n

例子6 中给出的「ID号」为例子5中指定的ID号 “gua1”,并要求显示本卦4爻的具体信息。

\n
\n

八字

\n

命令:八字排盘 \\paibazi{时间}{性别}{标识}[细节]

\n

【时间】和【性别】参数必填,【标识】和【细节】参数可选。(如果要第二次显示已有的八字盘,则【时间】和【性别】参数可留白,只给定【标识】参数中的「ID号」)

\n

【时间】:允许格式 “1980-1-3 08:15”、“2019年3月4日 6时3分”

\n

【性别】:允许格式 “m”、“f”、“男”、“女”、“乾”、“坤”、

\n

【标识】:与排盘命令的「标识」参数等同。由ID号、简排、字符大小三个部分组成。

\n

【细节】:允许“藏干”、“长生”、“纳音”这三个中的一个或者多个,也可以留白。格式为 藏干/纳音/长生

\n

例子7:\\paibazi{1990年5月1日 6:45}{男}{小明/s/5}

\n

$\\paibazi{1990年5月1日 6:45}{男}{小明/5}$

\n

例子8:重排例子7的八字盘 \\paibazi{}{}{小明/s/5}[纳音/藏干/长生] ,并要求显示藏干和纳音等信息。

\n

$\\paibazi{}{}{小明/s/5}[纳音/藏干/长生]$

\n

命令:八字细节 \\bazi{标识}{类别}[细节]

\n

使用前提:当前文本中已经排出至少一个八字盘。

\n

【标识】:与排盘命令的「标识」参数等同。由ID号、简排、字符大小三个部分组成。其中「ID号」标识已经存在的八字命盘。

\n

【类别】:支持 “神煞”、“大运”、“流年”、“小运” 四个选项。

\n

【细节】:具体含义视【类别】而定。

\n
    \n
  • 类别为「神煞」时:「细节」为 1~ 9 的数字,表示每行列数。
  • \n
  • 类别为「大运」时: 1-9 纳音/藏干/长生/神煞 前面的数字表示第几步大运,限定 1 到 10
  • \n
  • 类别为「流年」和「小运」时: 2015 - 2019 纳音/藏干/长生/神煞 前面的数字表示年份,注意不要超过命盘的生命周期,否则会出错。「纳音/藏干/长生/神煞」可以留白,也可只显示一两项。
  • \n
\n

例子9: \\bazi{小明}{神煞}[6] 显示小明命盘的神煞,每行6列。

\n

$\\bazi{小明}{神煞}[6]$

\n

例子10: \\bazi{小明}{大运}[2-3 ] 显示小明的第二到第三步大运

\n

$\\bazi{小明}{大运}[2-3]$

\n

例子11: \\bazi{小明}{流年}[2017-2019 纳音/藏干/长生/神煞] 显示小明的2017到2019年的流年信息。

\n

$\\bazi{小明}{流年}[2017-2019 纳音/藏干/长生/神煞]$

\n

未来与展望

\n

我知道这篇文章介绍的工具,并非所有人都能使用。所以在不久的将来,还是要制作一个独立易学软件,以便易友在PC端和移动端都能按照传统的方式使用。但由于时间和精力原因,我无法保证完成时间。

\n

不断完善易学函数,提供更丰富的应用细节。在用户更为广泛的MD编辑器中实现此方式。比如有道云笔记、为知笔记、印象笔记等。并争取介绍移动端(Android & iOS)实现此方式。也希望在Gitbook中实现。

\n

希望能将师父的六爻和八字讲义,『增删卜易』等著作制作成Gitbook,将精彩的卦例和名人八字建成易学数据库。这样就可以通过我的易学函数直接获取, 比如 \\paibazi{蒋介石}

\n

附录:

\n

命令列表

\n

纳音

\n

爻符

\n

排卦

\n

卦爻细节

\n

排八字

\n

八字细节

\n

发布

\n

脚本文件的原始路径https://github.com/maiernte/img/raw/master/libs/bundle.js。因为涉及到跨域问题,要通过 Gitkack 重链接,把上述路径输入到 Githack 的地址框,会得到「应用地址」和「开发地址」。

\n

应用地址

\n

https://rawcdn.githack.com/maiernte/img/11a1bb572a6875dbf434a7fc457ea2fdd329f7db/libs/bundle.js

\n

开发地址

\n

https://raw.githack.com/maiernte/img/master/libs/bundle.js

\n

查看当前易学函数库版本

\n

在 chrome 浏览其中打开此博文,Mac 系统中按 ⌘+⌥+I ,Windows 系统 Ctr+⇧+I,或者 Chrome 菜单栏调出 “开发者工具”,选择 Console 页面,即可显示当前易学库版本和时间。

\n","site":{"data":{}},"excerpt":"

关于利用 MathJaxKatex 数学公式解释器,实现易学上排六爻盘和八字盘个功能。今天实现了易学上的核心功能。有望将来能添加更多的函数,以便利各位同门以及广大易友。

","more":"

效果与演示

\n\n无法观看油管的朋友请移步B站:[使用MathJax渲染六爻和八字盘](https://www.bilibili.com/video/av66317810/)\n

安装和使用

\n

首先,你需要一个支持 Markdown (简称MD) 语言格式的文本编辑器。如果不知道什么是MD的话,请参阅以下介绍:

\n\n

Markdown 语言简约而优美,可以自由转换成pdf、word、Html 等等各种其它格式的文本。可以推送到博客、微信公众号等等。虽然算卦是一个传统的行业,我们仍然不宜固步自封。MD语言支持MathJax和Katex书写Latex数学公式,可以写出非常漂亮的数学、物理、化学方面的公式。正式的科技刊物都要求用Latex格式。

\n

这个易学解决方案是对 MathJax 进行扩展,加入指定的易学公式,让 MathJax 解释器去完成公式渲染。它并不是一个独立的程序。需要构建在已有的MD文本编辑器之上。我使用一个文件夹存放所有的关于易学方面的MD文件,并将这个文件夹同步到 坚果云,这样就可以实现多台电脑和移动端之间的同步,而不太需要一个独立的易学软件。甚至可以将MD文件导出为HTML文件,放到我的HEXO博客上(您正在阅读的这篇博文即是例子)。

\n

理论上所有支持Markdown语言和MathJax的文本编辑器,都可以改装。改装过程需要两段代码和一个库文件。

\n

文本编辑器

\n
Typora
\n

Typora 是我个人最钟爱的MD编辑器,因此这里着重介绍。如果你喜欢用别的MD编辑器,比如iAWrte等,理论上可以用同样的方式改装。(无法百分百保证) 有需要的朋友可以私下联系我。

\n

最新的安装教程请参考华鹤易学平台文档

\n
VSCode
\n

同样请移步华鹤易学平台文档。那里有详细描述。

\n

Hexo博客

\n

🔔 注意:首先要检查自己的 Hexo 博客使用的渲染器是否默认开启了Katex或者MathJax数学插件。如果有的话需要卸载或者禁用数学插件,如果不能禁用,就必须更换Markdown渲染器。

\n
\n

因为系统使用的数学插件会在网页生成之前就改动数学表达,这样无法使用我提供给的函数库。我提供给博客的方案是在浏览网页的时候,即时渲染易学公式。

\n
\n

比如我之前用了 “hexo-renderer-markdown-it-plus” 渲染器就是强制使用 Katex 数学渲染的。

\n\n

然后将下列代码添加到文件模版就可以了。使用 swig 模版的是在 <your thems>/layout/_custom/header.swig 或者 <your thems>/layout/index.swig 。而使用 ejs 模版的是文件 <your thems>/layout/layout.ejs

\n\n
\n

注意搜索 _config.yml 文件,“math”, “katex”, “mathjax” 等字样,发现有的话把他们禁用。

\n
\n

Gitbook

\n

最新的安装教程请参考华鹤易学平台文档

\n

API 参数

\n

使用易学函数库非常简单,在经过改装的Markdown编辑器中,输入易学公式,并用两个 $ 符号将公式前后围起来即可。MD语言一般默认两个 $ 符号之间的文本是数学公式,它会调用MathJax对公式进行渲染。否则,它会认为这是普通文本,而不会做任何动作。

\n

易学通用

\n

命令:纳音 \\nayin{干支名称}

\n

【干支名称】 :就是甲子、己卯等六十甲子。

\n

例子1:\\nayin{戊午} --> $\\nayin{戊午}$

\n

命令:干支日历 \\timegz{时间参数}{年月日}

\n

【时间参数】 :例如 2020-02-21。

\n

【年月日】 :省略时默认为111,即显示年月日。0表示不显示,1表示显示。

\n

例子1:\\timegz{2020-02-21} --> $\\timegz{2020-02-21}$

\n

例子2:\\timegz{2020-02-21}{011} --> $\\timegz{2020-02-21}{011}$

\n

六爻

\n

命令:爻符 \\yao{爻名}

\n

【爻名】:laoyin, laoyang,shaoyin,shaoyang, x, o, =, -, 交,重,阴,阳,0,1,2,3

\n

例子2:\\yao{x} --> $\\yao{x}$

\n

例子3:\\yao{shaoyin} --> $\\yao{shaoyin}$

\n

例子4:\\yao{重} --> $\\yao{重}$

\n

命令:六爻排盘 \\paigua{时令}{卦辞}{标识}

\n

其中 【时令】、【卦辞】这两个参数是必须的,**【标识】**参数可以省略。

\n

【时令】允许的格式为:“1980-1-3 08:15”、“2019年3月4日”、“申月戊寅日”

\n

【卦辞】允许的格式为:“解之师”、“离为火”、“–==x-”、“0121100”、“阴阳阴交阴阳”

\n

【标识】由三部分组成:ID号、简排、字符大小。格式为:guadi/s/5

\n
    \n
  • 「ID号」:随便一串字符,空白则默认为“gua1”。:x:不允许只有数字,因为会与参数「字符大小」混淆。如果一个文本出现多个六爻卦,则每个卦都需要指定一个ID号。否则下面的命令卦爻细节不知道具体指向哪一个卦本。
  • \n
  • 「简排」:只允许sl两个英文字符的其中一个。s 表示只显示短名,如“妻财”显示为“财”,“青龙”显示为“龙”。l 则显示完整名称。留白则按照用户全局设定来显示。(参阅用户设定
  • \n
  • 「字符大小」:允许 0 - 9 档。数字越大文字越大。默认大小为5或者用户的全局设定
  • \n
\n

例子5: $\\paigua{1978年7月1日}{101201}{gua1}$ 效果
\n$$\\paigua{1978年7月1日}{101201}{gua1}$$

\n

:pencil2: 如果文章很长,需要在指定位置重新显示一遍卦本,则可以使用重排命令。即让【时令】和【卦辞】两个参数留白,只给出【ID号】。如 \\paigua{}{}{gua1} 。留白的参数,仍然需要用大括号括起来,否则解释器会出错。

\n

命令:卦爻细节 \\guayao{标识}{位置}

\n

使用前提:当前文本中已经排出至少一支六爻卦。

\n

【标识】:与排盘命令的「标识」参数等同。由ID号、简排、字符大小三个部分组成。其中「ID号」标识已经存在的六爻盘。

\n

【位置】:格式为 “ben1”、“fu3”、“bian5” 等,分别表示「本卦初爻」、「伏卦3爻」、「变卦5爻」

\n

例子6:\\guayao{gua1}{ben4} --> $\\guayao{gua1}{ben4}$

\n
\n

例子6 中给出的「ID号」为例子5中指定的ID号 “gua1”,并要求显示本卦4爻的具体信息。

\n
\n

八字

\n

命令:八字排盘 \\paibazi{时间}{性别}{标识}[细节]

\n

【时间】和【性别】参数必填,【标识】和【细节】参数可选。(如果要第二次显示已有的八字盘,则【时间】和【性别】参数可留白,只给定【标识】参数中的「ID号」)

\n

【时间】:允许格式 “1980-1-3 08:15”、“2019年3月4日 6时3分”

\n

【性别】:允许格式 “m”、“f”、“男”、“女”、“乾”、“坤”、

\n

【标识】:与排盘命令的「标识」参数等同。由ID号、简排、字符大小三个部分组成。

\n

【细节】:允许“藏干”、“长生”、“纳音”这三个中的一个或者多个,也可以留白。格式为 藏干/纳音/长生

\n

例子7:\\paibazi{1990年5月1日 6:45}{男}{小明/s/5}

\n

$\\paibazi{1990年5月1日 6:45}{男}{小明/5}$

\n

例子8:重排例子7的八字盘 \\paibazi{}{}{小明/s/5}[纳音/藏干/长生] ,并要求显示藏干和纳音等信息。

\n

$\\paibazi{}{}{小明/s/5}[纳音/藏干/长生]$

\n

命令:八字细节 \\bazi{标识}{类别}[细节]

\n

使用前提:当前文本中已经排出至少一个八字盘。

\n

【标识】:与排盘命令的「标识」参数等同。由ID号、简排、字符大小三个部分组成。其中「ID号」标识已经存在的八字命盘。

\n

【类别】:支持 “神煞”、“大运”、“流年”、“小运” 四个选项。

\n

【细节】:具体含义视【类别】而定。

\n
    \n
  • 类别为「神煞」时:「细节」为 1~ 9 的数字,表示每行列数。
  • \n
  • 类别为「大运」时: 1-9 纳音/藏干/长生/神煞 前面的数字表示第几步大运,限定 1 到 10
  • \n
  • 类别为「流年」和「小运」时: 2015 - 2019 纳音/藏干/长生/神煞 前面的数字表示年份,注意不要超过命盘的生命周期,否则会出错。「纳音/藏干/长生/神煞」可以留白,也可只显示一两项。
  • \n
\n

例子9: \\bazi{小明}{神煞}[6] 显示小明命盘的神煞,每行6列。

\n

$\\bazi{小明}{神煞}[6]$

\n

例子10: \\bazi{小明}{大运}[2-3 ] 显示小明的第二到第三步大运

\n

$\\bazi{小明}{大运}[2-3]$

\n

例子11: \\bazi{小明}{流年}[2017-2019 纳音/藏干/长生/神煞] 显示小明的2017到2019年的流年信息。

\n

$\\bazi{小明}{流年}[2017-2019 纳音/藏干/长生/神煞]$

\n

未来与展望

\n

我知道这篇文章介绍的工具,并非所有人都能使用。所以在不久的将来,还是要制作一个独立易学软件,以便易友在PC端和移动端都能按照传统的方式使用。但由于时间和精力原因,我无法保证完成时间。

\n

不断完善易学函数,提供更丰富的应用细节。在用户更为广泛的MD编辑器中实现此方式。比如有道云笔记、为知笔记、印象笔记等。并争取介绍移动端(Android & iOS)实现此方式。也希望在Gitbook中实现。

\n

希望能将师父的六爻和八字讲义,『增删卜易』等著作制作成Gitbook,将精彩的卦例和名人八字建成易学数据库。这样就可以通过我的易学函数直接获取, 比如 \\paibazi{蒋介石}

\n

附录:

\n

命令列表

\n

纳音

\n

爻符

\n

排卦

\n

卦爻细节

\n

排八字

\n

八字细节

\n

发布

\n

脚本文件的原始路径https://github.com/maiernte/img/raw/master/libs/bundle.js。因为涉及到跨域问题,要通过 Gitkack 重链接,把上述路径输入到 Githack 的地址框,会得到「应用地址」和「开发地址」。

\n

应用地址

\n

https://rawcdn.githack.com/maiernte/img/11a1bb572a6875dbf434a7fc457ea2fdd329f7db/libs/bundle.js

\n

开发地址

\n

https://raw.githack.com/maiernte/img/master/libs/bundle.js

\n

查看当前易学函数库版本

\n

在 chrome 浏览其中打开此博文,Mac 系统中按 ⌘+⌥+I ,Windows 系统 Ctr+⇧+I,或者 Chrome 菜单栏调出 “开发者工具”,选择 Console 页面,即可显示当前易学库版本和时间。

"},{"title":"搭建Hexo博客的流水账","date":"2019-07-25T03:49:15.000Z","urlname":"how-build-my-hexo-blog","toc":true,"notshow":false,"_content":"\n\n\n建网过程中的一些流水账。以备将来查询。\n\n\n\n# 建立网站\n\n## Github配置\n\n输入命令 `ssh-keygen -t rsa -b 4096 -C \"myname@gmail.com\"`。\n\n\n\n密码 `T1`。(下列展开后复制)\n\n> 将文件 ~/.ssh/id_rsa.pub 中的内容复制到 Github 的SSH-Key 内就可以了。(备份文件已上传百度网盘)\n\n3. 在Github上新建SSH-Key名称为`gmail`\n\n[具体步骤参阅此文章](https://gavinlee1.github.io/2017/02/25/十步之内轻松搞定-Hexo-GitHub搭建个人博客/)\n\n```\nssh-keygen -t rsa -b 4096 -C \"username@gmail.com\"\n[Enter]\n[password T..1]\n\neval \"$(ssh-agent -s)\"\nssh-add -K ~/.ssh/id_rsa\n\ncd ~\ncd .ssh\nls\nvim id_rsa.pub\n(然后复制钥匙串)\n```\n4. 测试公匙\n\n```\n$ ssh -T git@github.com\n\nHi username! You've successfully authenticated, but GitHub does not provide shell access.\n```\n\n## 安装Hexo\n\n参考资料[^1] [^7]。\n1. 安装node.js 因为以前已经安装过,所以跳过。\n2. 安装 Hexo `$ npm install hexo-cli -g` \n3. 创建网站\n```command\nmkdir mywiki\ncd mywiki\nhexo init\nnpm install\n```\n4. 生成静态页面 `hexo g` or `hexo generate`\n5. 启动本地网站服务 `hexo s` or `hexo server`\n> 网站一般会运行在 http://localhost:4000/\n> Press Ctrl+C to stop.\n\n6. 用pow做服务本地运行\n\n**Install**\n\n```\n$ curl get.pow.cx | sh\n```\n\n**Setup**\n\nSymlink the folder into `~/.pow`\n\n```\n$ cd ~/.pow\n$ ln -s /path/to/test\n```\n\n## 发布到Github\n\n终于搭建好站点部署环境啦,那么要怎么样将我们本地生成预览好的页面发布到github上呢?很简单,Follow!\n\n首先,打开blog目录下的`_config.yml`,找到deploy段,配置成这样\n\n> deploy:\n> type: git\n> repository: git@github.com:yourname/yourname.github.io.git\n> branch: master\n\n注意将代码里面的yourname换成你账号的username。\n\n设置git身份信息\n\n> git config --global user.name \"你的用户名\"\n> git config --global user.email \"你的邮箱\" \n\n执行以下指令进行部署\n\n`hexo d -g `\n\n如果提示没找到git,请先执行以下指令\n\n`cnpm install hexo-deployer-git --save` \n\n再次部署后,浏览器打开 [https://yourname.github.io](https://yourname.github.io/) 就可以看到刚才本地预览页面。\n\n## 网站基本配置\n\n### Next 主题\n\n主题配置文件说明\n\n{% fold 点击显/隐内容 %}\n\n```ini\n# Hexo 站点配置文件\n## Docs: https://hexo.io/docs/configuration.html\n## Source: https://github.com/hexojs/hexo/\n\n# 网站配置\ntitle: Hexo # 网站标题\nsubtitle: # 网站副标题\ndescription: # 网站描述\nauthor: John Doe # 你的昵称\nlanguage: # 网站使用的语言(英文:en, 简体中文:zh-Hans,繁体中文:zh-tw)\ntimezone: # 网站时区,用于生成页面时填充相关时间,默认使用电脑时区,一般不用改\n\n# URL\n## 如果你的站点要放入子目录, 请将url设置为'http://yoursite.com/child' 并将根目录设置为'/child/'\nurl: http://yoursite.com # 站点网址\nroot: / # 网站根目录\npermalink: :year/:month/:day/:title/ #文单的永久链接格式\npermalink_defaults: # 永久链接中各部分的默认值\n\n# 目录\nsource_dir: source # 资源文件夹,这个文件夹用来存放博客内容\npublic_dir: public # 公共文件夹,这个文件夹用来存放生成的站点静态文件\ntag_dir: tags # 标签文件夹\narchive_dir: archives # 归档文件夹\ncategory_dir: categories # 分类文件夹\ncode_dir: downloads/code # Include code文件夹\ni18n_dir: :lang # 国际化文件夹,存放各种语言定义\nskip_render: # 跳过指定文件的渲染\n\n# 写作\nnew_post_name: :title.md # 新文章的文件名称\ndefault_layout: post # 预设布局\ntitlecase: false # 把标题转换为 title case\nexternal_link: true # 在新标签中打开链接\nfilename_case: 0 # 把文件名称转换为 (1) 小写或 (2) 大写\nrender_drafts: false # 显示草稿\npost_asset_folder: false # 启动 Asset 文件夹\nrelative_link: false # 把链接改为与根目录的相对位址\nfuture: true # 显示未来的文章\nhighlight: # 代码块的设置\n enable: true\n line_number: true\n auto_detect: false\n tab_replace:\n\n# 分类 & 标签\ndefault_category: uncategorized # 默认分类\ncategory_map: # 分类别名\ntag_map: # 标签别名\n\n# 日期 / 时间格式\n## Hexo 使用 Moment.js 来解析和显示时间\n## http://momentjs.com/docs/#/displaying/format/\ndate_format: YYYY-MM-DD # 日期格式\ntime_format: HH:mm:ss # 时间格式\n\n# 分页\n## 每页显示的文章量 (0 = 关闭分页功能)\nper_page: 10\npagination_dir: page\n\n# 扩展\n## Plugins: https://hexo.io/plugins/\n## Themes: https://hexo.io/themes/\ntheme: landscape # 主题\n\n# 部署\n## Docs: https://hexo.io/docs/deployment.html\ndeploy:\n type:\n```\n\n{% endfold %}\n\n### Wikitten主题\n\n具体配置参考[开发者说明](https://github.com/zthxxx/hexo-theme-Wikitten/blob/master/README_zh-CN.md),更详细的描述参阅[hexo-theme-icarus](https://github.com/ppoffice/hexo-theme-icarus/wiki)。为了与主题Next不冲突,作以下修改。\n\n1. 自行修改 `tags`, `about`,`categories` 等`index.md`,而不能从主题复制,覆盖站点原有设置。\n2. `languages\\zh-CN.yml` 重命名为 `zh-Hans.yml`\n3. `_config.yml` 菜单作以下更改\n\n```ini\nmenu:\n 首页: /\n 归档: /archives/\n 分类: /categories/\n 标签: /tags/\n 关于: /about/\n```\n\n4. `thumbnail: true` 使得每个post在快速列表里,显示图标。但就是每个帖子都要设定,很麻烦。\n5. post 中的 toc 要设置为 true,如果需要显示目录的话。\n\n### 同时部署两个项目\n\n第一个项目使用 Github 上面默认的 Github Pages,即 `username.github.io` 。在站点配置文件中如下:\n\n```\nurl: http://username.github.io\nroot: /\n...\n...\ndeploy:\n type: git\n repository: git@github.com:username/username.github.io.git\n branch: master\n\n```\n\n\n第二个站点开通一个 普通的repository,添加名为`gh-pages` 的Branch,并将gh-pages` 设为默认Branch。我将第二个仓库命名为 wiki ,那第二个站点就运行在 `https://username.github.io/wiki`次级目录下面。\n\n站点配置文件更改如下:\n\n```\nurl: http://username.github.io/wiki\nroot: /wiki/\n...\n...\ndeploy:\n type: git\n repository: git@github.com:username/wiki.git\n branch: gh-pages\n```\n\n同样用 `hexo d -g` 部署命令发布,两个站点就都运行起来了。\n\n为了使得两个项目使用同一个笔记资源,将站点中的 source 文件夹移到项目意外,将配置文件里的 `source_dir: source` 改为 `source_dir: ../source`(这里使用了相对目录)。\n\n[参考文章][multipages] (细节已经失效,但思路值得参考)\n\n### 站内搜索\n\n1. 安装插件\n\n```shell\nnpm install hexo-generator-search --save\nnpm install hexo-generator-searchdb --save\n```\n\n2. 配置hexo站点主配置文件``_config.yml``, 添加\n\n```ini\nsearch:\n path: search.xml\n field: post\n format: html\n limit: 10000\n```\n\n3. 修改next主题配置文件`_config.yml`,启用 `local_search`\n\n```ini\nlocal_search:\n\tenable: true\n\ttrigger: auto\n\ttop_n_per_article: 1\n```\n\n4. 生成`search.xml`文件以及发布\n\n```shell\nhexo g\nhexo d -g # 本地运行 hexo s\n```\n\n### 去除主题字样\n\n关于添加头像、标签、分类、「关于」等具体的修改,跟着参考资料[^2]里面的步骤做就好了。最后说说如何去掉底部强力驱动及主题字样。\n\n1. 找到 `\\themes\\next\\layout_partials\\`下面的`footer.swig`文件,打开:\n\n```html\n
\n {{ __('footer.powered', 'Hexo') }}\n
\n
\n {{ __('footer.theme') }} -\n \n NexT.{{ theme.scheme }}\n \n
\n```\n\n第一条是“由Hexo驱动” 的Hexo链接,把xml段删除,只留两个单引号''。\n\n第二条是“主题-Next.XX”,将xml段都删掉,不留引号。\n\n```html\n
\n {{ __('footer.powered', '') }}\n
\n
\n {{ __('footer.theme') }}\n
\n```\n\n2. 找到这个地方`\\themes\\next\\languages\\ `下面的语言文件`zh-Hans.yml`(以中文为例):\n\n```ini\nfooter:\n powered: \"由 %s 强力驱动\"\n theme: 主题\n```\n\n将上面的文字改成自己想要的即可。\n\n## 添加评论功能\n\n#### Gitment\n\n**此项目已经终止!**改为Disqus,以及其它评论服务。\n\n1. 安装功能模块。在项目的根目录:\n\n```shell\nnpm i --save gitment\n```\n\n2. 在Github申请应用。`settings -> Developer Settings -> OAuth Apps`\n\n```ini\nApplication name:随便写\nHomepage URL:这个也可以随意写,就写你的博客地址就行\nApplication description:描述,也可以随意写\nAuthorization callback URL:这个必须写你的博客地址\n```\n\n申请好之后点注册,然后就可以看到两个东西`ClientID`和`Client Secret`,后面会用到。\n\n3. 配置Gitment,打开`themes/next/_config.yml`:\n\n```javascript\n# Gitment\n# Introduction: https://imsun.net/posts/gitment-introduction/\ngitment:\n enable: true\n mint: true # RECOMMEND, A mint on Gitment, to support count, language and proxy_gateway\n count: true # Show comments count in post meta area\n lazy: false # Comments lazy loading with a button\n cleanly: false # Hide 'Powered by ...' on footer, and more\n language: # Force language, or auto switch by theme\n github_user: {you github user id}\n github_repo: 随便写一个你的公开的git仓库就行,到时候评论会作为那个项目的issue\n client_id: {刚才申请的ClientID}\n client_secret: {刚才申请的Client Secret}\n proxy_gateway: # Address of api proxy, See: https://github.com/aimingoo/intersect\n redirect_protocol: # Protocol of redirect_uri with force_redirect_protocol when mint enabled\n```\n\n注意到这里基本上已经OK了,再看你的博客应该可以显示评论了.不过每篇博客都需要你手动初始化评论功能(如果你的历史博客很多那就一篇一篇去点吧,不过貌似有人写了批量处理脚本,没试过哈).\n\n而由于 github 中 `Issues` 的 `label` 长度限制为最大 `50` 个字符,当 文章标题长度过长时,该label就会生成失败,而导致初始化错误,弹出 `Validation Failed` 的提示。\n\n通过网上的搜索,发现可以使用文章创建时的时间来代替文章标题,作为这个唯一的label标签。\n\n找到giment的配置:`/themes/next/layout/_third-party/comments/gitment.swig` 文件, 并找到如下部分:\n\n```javascript\nvar gitment = new {{CommentsClass}}({\n id: window.location.pathname,\n owner: '{{ theme.gitment.github_user }}',\n repo: '{{ theme.gitment.github_repo }}',\n ...\n```\n\n将`id`后面的路径值修改为 'itfanr\\_blog\\_\\{{ date(page.date, \"YYYYMMDDhhmmss\") \\}}' 就可以了。\n\n#### Disqus\n\n目前只开通[Disqus](https://disqus.com/)的评论。\n\n1. 开通Disqus账号,并添加一个点 应用。具体步骤参看[Hexo搭建博客系列:(六)Hexo添加Disqus评论](https://www.jianshu.com/p/d68de067ea74)。\n2. 在`主题配置文件`(_config.yml)文件中找到以下代码,添加你Disqus设置的Website Name在shortname。\n\n```json\n# Disqus\ndisqus:\n enable: true\n shortname: tian-ya-de-zhi-fu\n count: true\n```\n\n更详细请参阅网上。\n\n\n\n## 新文章命名规则\n\n发表新文章后系统崩溃。\n\n在根目录的配置文件中找到类似的:\n\n```\n# Writing\nnew_post_name: 新文章.md # File name of new posts\ndefault_layout: post\n...\n```\n\n将其改为由时间和题目组成:\n\n```\n# Writing\nnew_post_name: year-:month-:day-:title.md # File name of new posts\ndefault_layout: post\n...\n```\n\n\n\n# 进阶设置\n\n## 显示\n\n### 首页文章显示预览\n\n默认设定下。首页的文章每一篇都显示全文,不方便浏览。需要到主题的配置文件里将`auto_excerpt` 的 `enable` 改为 `true`。而`length` 字节表示文章预览的长度。\n\n```\n# Automatically Excerpt. Not recommand.\nauto_excerpt:\n\tenable: true\n\tlength: 300\n```\n\n### 永久链接\n\n新文章的名字采用了中文([见上](#id_new_post_name)),中文出现在地址栏上不美观。也不利于SEO,以及增加了博文URL的层数。解决办法是给每篇文章制定链接地址。\n\n1. 修改网站的配置文件中永久地址的设定:\n\n```ini\npermalink: :urlname.html\n```\n\n2. 给每篇文章指定 `urlname`\n\n```ini\ntitle: 《少有人走的路》笔记\ndate: 2019-07-21 00:14:37\nurlname: road-less-traveled-summary\ntags:\n - 心理学\ncategories: 读书笔记\n```\n\n编译后新的地址为 `http://mywiki.test/road-less-traveled-summary.html`。看起来就清爽多了。\n\n### 图片链接\n\n1. 开通[资源文件夹](https://hexo.io/zh-cn/docs/asset-folders),创建新文章的时候会自动建立一个与文章同名的文件夹。可以将图片或者其它资源文件放到里面(*打算将思维导图放到这里*)。因为自定义了[文件名的方式](#id_new_post_name),所以根据官方描述无效。\n2. 安装第三方插件`hexo-asset-image`\n\n```bash\nnpm install hexo-asset-image --save\n```\n\n在文章中图片的链,可以省略路径,直接引用图片名:\n\n```markdown\n![mypicture](mypicture.jpg)\n```\n\n3. 修改插件代码\n\n我在使用永久链接的时候在每篇文章的实际地址都加上了`.html`。文章的地址显示如下\n\n```http\nhttp://mywebsite.com/my-articel-url.html\n```\n\n而插件生成的图片地址如下:\n\n```\nhttp://mywebsite.com/my-articel-url.htm/mypicture.jpg\n```\n\n多出了 `.htm` 这几个字符,而实际图片的地址应该是:\n\n```http\nhttp://mywebsite.com/my-articel-url/mypicture.jpg\n```\n\n找到 `node_modules/hexo-asset-imge` 目录下的 `index.js` 文件,将以下代码中的 `1` 改成 `5`,就可以正常显示图片了。\n\n```javascript\nvar endPos = link.length - 1\n```\n\n考虑到将来项目膨胀,应该将图片放到图床,比如七牛。\n\n### 站内链接\n\n导航到站内别的文章使用以下方式就可以。\n\n链接方式 `[文章名](urlname.html)`\n\n\n\n### 设定代码区的高度\n\nHexo自身的式样暂时还没找到。其实也不太需要。如果代码不长直接显示全部就好了。太长的话不如放到$Gits$,通过限制gist的高度实现。**Net**主题修改 `next/themes/next/source/css/_custom/custom.styl` ,Wikitten主题则在文件 `wikitten/themes/Wikitten/source/css/_partial/article.styl` 中修改。\n\n```CSS\n.gist \n.gist-file\n.gist-data {\n max-height: 450px;\n}\n```\n\n\n\n### 添加注脚支持\n\n[插件项目](https://github.com/LouisBarranqueiro/hexo-footnotes)\n\n1. 安装插件 `npm install hexo-footnotes --save`\n2. **项目配置文件** 添加\n\n```ini\n# 注意第二行的前面没有 \"-\" 符号,官方说明有. 但是会导致无法编译.\nplugins:\n hexo-footnotes\n```\n\n\n\n### 更换Markdown渲染\n\n[Markdown-it-plus](https://github.com/CHENXCHEN/hexo-renderer-markdown-it-plus)\n\n如果更换了这个渲染,就无需上面那个注脚插件, 因为已经支持了. 首先卸载掉旧的渲染, 然后安装新的.\n\n```sh\nnpm un hexo-renderer-marked --save\nnpm i hexo-renderer-markdown-it-plus --save\n# 查看是否已经安装\nnpm ls hexo-renderer-markdown-it-plus\n```\n\n然后在项目配置文件, 添加下面文字. 更深入的设置, 参看 markdown-it-plus 项目的说明文档.\n\n```ini\nmarkdown_it_plus:\n highlight: true\n html: true\n xhtmlOut: true\n breaks: true\n langPrefix:\n linkify: true\n typographer:\n quotes: “”‘’\n plugins:\n```\n\n\n\n## 辅助功能\n\n### 本地运行服务\n\n在Mac中可以用本地服务[Pow](http://pow.cx)运行网站,不用每次更改重启服务器`hexo s`。\n\n1. 安装Pow\n\n```bash\n$ curl get.pow.cx | sh\n```\n\n2. 建立项目链接,`myapp` 是项目的名字。比如真实路径`~/Project/mywiki`\n\n```bash\n$ cd ~/.pow\n$ ln -s /path/to/myapp\n```\n\n3. 执行完以上步骤后在浏览器打开链接 ``http://myapp.test/`` 就能看到网站。更改内容后要执行==生成== 命令才能看到更新`hexo generate` or `hexo g` 。\n4. 不想运行,直接把项目文件夹删除就可以。\n\n### 绑定个人域名\n\n1. 在万网买一个顶级域名,开通后添加两个域名解释\n\n```ini\n#记录名 主机记录 记录值\nCNAME www username.github.io\nCNAME @ username.github.io\n```\n\n2. 在项目的根目录添加一个名为 `CNAME` 的文件,然后填入万网注册的域名, 这里是 `goldentianya.pub` 。第一次我是手动添加的。添加后进入 repository 的 setting, 往下混动到 Custom domain ,可以看到系统已经自动把用户域名加进去了。\n3. 将来不希望用这个域名,域名重定向后,在浏览器输入 username.github.io 后 Chrome 会一直转向 goldentianya.pub 。需要打开`开发者工具`,选中 `disable cache` ,再刷新一遍地址就好了。\n4. `next` 项目要将 `CNAME` 文件复制到 `/themes/next/source` 目录下个,编译的时候会拷贝到 `public` 目录。`wikitten` 项目不需要,域名定向以后能找到 `goldentianya/wiki` 站点,十分神奇。\n\n### 隐藏文章\n\n#### 全隐藏\n\n根据插件`hext-sage-posts` 作者的博文[^9]中描述,安装插件\n\n```bash\nnpm install hexo-sage-posts --save\n```\n\n并将初创时的`Hello-world.md` 文章的Metadata中加入`sage: true`,文章就从网站上消失了。但在别的文章下面导航栏中,通过“下一篇”或者“上一篇”还是能被找到。被隐藏的文章其地址仍旧没有改变,只是不不出现在首页导航,和分类中而已。\n\n#### 从首页隐藏\n\n为了不让太琐碎的文章充斥首页,但又可以在分类中找到。可以采用这种方式。\n\n1. 在文章的Metadata部分添加关键字 `notshow: true`。\n2. 找到 `Hexo\\themes\\next\\layout\\index.swig` 文件中以下部分:\n\n```html\n{% block content %}\n
\n {% for post in page.posts %}\n {{ post_template.render(post, true) }} \n {% endfor %}\n
\n\n {% include '_partials/pagination.swig' %}\n{% endblock %}\n```\n\n将以上代码第四行修改为\n\n```html\n{% if post.notshow != true %}\n\t{{ post_template.render(post, true) }}\n{% endif %}\n```\n\n\n\n#### 文章加密\n\n1. 安装插件 `hexo-blog-encrypt`\n\n```\nnpm install --save hexo-blog-encrypt\n```\n\n并在**站点配置**文件中启用该插件:\n\n```json\nencrypt:\n enable: true\n```\n\n2. 然后在文章的头部添加上对应的字段\n\n```ini\n---\ntitle: 文章加密\ndate: 2019-01-04T22:20:13.000Z\ncategory: 教程\ntags:\n - 博客\n - Hexo\nkeywords: 博客文章密码\npassword: TloveY\nabstract: 此文章含有敏感内容。\nmessage: 输入密码,查看文章\n---\n```\n\n- password: 是该博客加密使用的密码\n\n- abstract: 是该博客的摘要,会显示在博客的列表页\n\n- message: 这个是博客查看时,密码输入框上面的描述性文字\n\n\n\n### Hexo Admin\n\n安装后台管理插件 `hexo-damin`\n\n```bash\nnpm install --save hexo-admin\nhexo server -d\nopen http://localhost:4000/admin/\n```\n\n初次运行后,设置管理账户。\n\n```\nadmin:\n username: maiernte\n password_hash: $2a$10$QeeWfDwIxbJ94h8EDfplDe9aLB0uaNrjMeVGhaYnfF0BBDosDze0S\n secret: NamoAmitabha!\n```\n\n### 访问量统计\n\n[介绍文章](https://bjtu-hxs.github.io/2018/06/12/leancloud-config/) (*有图*)\n\n[原文(有代码)](https://notes.doublemine.me/2015-10-21-%E4%B8%BANexT%E4%B8%BB%E9%A2%98%E6%B7%BB%E5%8A%A0%E6%96%87%E7%AB%A0%E9%98%85%E8%AF%BB%E9%87%8F%E7%BB%9F%E8%AE%A1%E5%8A%9F%E8%83%BD.html#%E9%85%8D%E7%BD%AELeanCloud)\n\n1. 第一步, 到Lean Cloud增添一个应用,并创建类似Counter 的类。设置成 $ 所有人可读可写 $\n2. 在安全中心添加 **Web 安全域名**, 添加Blog域名,防止有人Hack我们的数据库。\n\n3. 按上面的文章修改 Hexo 以及主题配置。\n\n\n\n### 在线交流\n\n使用 [道客](https://www.daovoice.io/) Daovoice\n\n接入方式\n\n1. 将下面代码粘贴在页面的 之前。\n\n```\n\n```\n\n2. 调用下面的 JavaScript 与注册用户沟通\n\n```\ndaovoice('init', {\n app_id: \"5e5fa370\",\n user_id: \"NO_89757\", // 必填: 该用户在您系统上的唯一ID\n email: \"daovoice@example.com\", // 选填: 该用户在您系统上的主邮箱\n name: \"道客船长\", // 选填: 用户名\n signed_up: 1449821660 // 选填: 用户的注册时间,用Unix时间戳表示\n});\ndaovoice('update');\n```\n\n3. 调用下面的 JavaScript 与匿名访客沟通\n\n```\ndaovoice('init', {\n app_id: \"5e5fa370\"\n});\ndaovoice('update');\n```\n\n完成代码粘贴后,检测是否成功接入: Ping 一下\n\n\n\n### 待解决问题\n\n- [x] 文章评论\n- [x] 在线编辑?\n- [x] 使用七牛图床\n- [ ] 脑图摆放 ([官方文档/数据文件](https://hexo.io/zh-cn/docs/data-files))\n- [x] 文件下载(可能还是要靠七牛)\n- [x] 用submodule管理主题 [在 hexo 中使用 git submodules 管理主题](https://juejin.im/post/5c2e22fcf265da615d72c596)\n- [ ] SEO\n- [ ] 访问量统计\n- [ ] 加速 [Github Pages + CDN全站加速](https://www.jianshu.com/p/ccc0cc8c14a0)\n\n- [ ] [在vps上部署hexo博客的那些事](https://segmentfault.com/a/1190000019104144)\n\n# 有趣插件\n\n- [x] [短地址 & 指定摘要](https://www.jianshu.com/p/805bd0b65d98) \n\n- [ ] [农历/很好的学习做插件的例子](https://github.com/inchei/hexo-lunar-calendar)\n\n- [ ] [插入pdf](https://github.com/superalsrk/hexo-pdf/) 可以学习如何插入epub\n\n- [ ] [hexo-include](https://github.com/pirtleshell/hexo-include) 加载文本内容, html, js, text\n\n- [x] [Hexo-NexT给文章添加结束语](https://wangc1993.github.io/2019/01/10/6/)\n\n- [x] [Hexo-NexT接入网页在线联系功能](https://wangc1993.github.io/2019/01/10/5/)\n\n- [ ] [include markdown](https://github.com/tea3/hexo-include-markdown)\n\n\n\n### ---\n\n\n\n[^1]: [Hexo博客搭建全攻略(一):基于Hexo+Github环境搭建](https://blog.annieyu.com/posts/207737771.html)\n[^2]: [Hexo博客搭建全攻略(二):NexT主题配置](https://blog.annieyu.com/posts/976961586.html)\n[^3]: [Hexo博客搭建全攻略(三):三方服务集成](https://blog.annieyu.com/posts/1209152972.html)\n[^4]: [Hexo博客搭建全攻略(四):高级应用](https://blog.annieyu.com/posts/3333782006.html)\n[^5]: [Hexo博客搭建全攻略(五):基于Github Issue搭建评论系统](https://blog.annieyu.com/posts/a341668e.html)\n[^6]: [Hexo博客搭建全攻略(六):博文图片处理](https://www.jianshu.com/p/2bb87ae49ff6)\n[^7]: [十步之内轻松搞定 Hexo + GitHub搭建个人博客](https://gavinlee1.github.io/2017/02/25/%E5%8D%81%E6%AD%A5%E4%B9%8B%E5%86%85%E8%BD%BB%E6%9D%BE%E6%90%9E%E5%AE%9A-Hexo-GitHub%E6%90%AD%E5%BB%BA%E4%B8%AA%E4%BA%BA%E5%8D%9A%E5%AE%A2/) ​​\n[^8]: [如何优雅的 隐藏博客](https://vanchchen.github.io/p/7587.html)\n[^9]: [为 Hexo 博客添加隐藏文章 / 限定公开功能](https://blessing.studio/hexo-plugin-to-make-posts-sage-unlisted/)\n[^10]: [Hexo 中文文档](https://hexo.io/zh-cn/docs/index.html)\n\n[multipages]: ttp://chitanda.me/2015/11/03/multiple-git-pages-in-one-github-account/\n\n[讲解详细的博客](https://binglumeng.github.io/2017/03/21/Hexo学习笔记/) \n\n[这个也不错](http://yearito.cn/posts/hexo-advanced-settings.html)\n\n\n","source":"_posts/IT/Web/搭建Hexo博客的流水账.md","raw":"---\ntitle: 搭建Hexo博客的流水账\ndate: 2019-07-25 05:49:15\nurlname: how-build-my-hexo-blog\ntoc: true\ntags: [Hexo]\ncategories: [IT, Web]\nnotshow: false\n\n---\n\n\n\n建网过程中的一些流水账。以备将来查询。\n\n\n\n# 建立网站\n\n## Github配置\n\n输入命令 `ssh-keygen -t rsa -b 4096 -C \"myname@gmail.com\"`。\n\n\n\n密码 `T1`。(下列展开后复制)\n\n> 将文件 ~/.ssh/id_rsa.pub 中的内容复制到 Github 的SSH-Key 内就可以了。(备份文件已上传百度网盘)\n\n3. 在Github上新建SSH-Key名称为`gmail`\n\n[具体步骤参阅此文章](https://gavinlee1.github.io/2017/02/25/十步之内轻松搞定-Hexo-GitHub搭建个人博客/)\n\n```\nssh-keygen -t rsa -b 4096 -C \"username@gmail.com\"\n[Enter]\n[password T..1]\n\neval \"$(ssh-agent -s)\"\nssh-add -K ~/.ssh/id_rsa\n\ncd ~\ncd .ssh\nls\nvim id_rsa.pub\n(然后复制钥匙串)\n```\n4. 测试公匙\n\n```\n$ ssh -T git@github.com\n\nHi username! You've successfully authenticated, but GitHub does not provide shell access.\n```\n\n## 安装Hexo\n\n参考资料[^1] [^7]。\n1. 安装node.js 因为以前已经安装过,所以跳过。\n2. 安装 Hexo `$ npm install hexo-cli -g` \n3. 创建网站\n```command\nmkdir mywiki\ncd mywiki\nhexo init\nnpm install\n```\n4. 生成静态页面 `hexo g` or `hexo generate`\n5. 启动本地网站服务 `hexo s` or `hexo server`\n> 网站一般会运行在 http://localhost:4000/\n> Press Ctrl+C to stop.\n\n6. 用pow做服务本地运行\n\n**Install**\n\n```\n$ curl get.pow.cx | sh\n```\n\n**Setup**\n\nSymlink the folder into `~/.pow`\n\n```\n$ cd ~/.pow\n$ ln -s /path/to/test\n```\n\n## 发布到Github\n\n终于搭建好站点部署环境啦,那么要怎么样将我们本地生成预览好的页面发布到github上呢?很简单,Follow!\n\n首先,打开blog目录下的`_config.yml`,找到deploy段,配置成这样\n\n> deploy:\n> type: git\n> repository: git@github.com:yourname/yourname.github.io.git\n> branch: master\n\n注意将代码里面的yourname换成你账号的username。\n\n设置git身份信息\n\n> git config --global user.name \"你的用户名\"\n> git config --global user.email \"你的邮箱\" \n\n执行以下指令进行部署\n\n`hexo d -g `\n\n如果提示没找到git,请先执行以下指令\n\n`cnpm install hexo-deployer-git --save` \n\n再次部署后,浏览器打开 [https://yourname.github.io](https://yourname.github.io/) 就可以看到刚才本地预览页面。\n\n## 网站基本配置\n\n### Next 主题\n\n主题配置文件说明\n\n{% fold 点击显/隐内容 %}\n\n```ini\n# Hexo 站点配置文件\n## Docs: https://hexo.io/docs/configuration.html\n## Source: https://github.com/hexojs/hexo/\n\n# 网站配置\ntitle: Hexo # 网站标题\nsubtitle: # 网站副标题\ndescription: # 网站描述\nauthor: John Doe # 你的昵称\nlanguage: # 网站使用的语言(英文:en, 简体中文:zh-Hans,繁体中文:zh-tw)\ntimezone: # 网站时区,用于生成页面时填充相关时间,默认使用电脑时区,一般不用改\n\n# URL\n## 如果你的站点要放入子目录, 请将url设置为'http://yoursite.com/child' 并将根目录设置为'/child/'\nurl: http://yoursite.com # 站点网址\nroot: / # 网站根目录\npermalink: :year/:month/:day/:title/ #文单的永久链接格式\npermalink_defaults: # 永久链接中各部分的默认值\n\n# 目录\nsource_dir: source # 资源文件夹,这个文件夹用来存放博客内容\npublic_dir: public # 公共文件夹,这个文件夹用来存放生成的站点静态文件\ntag_dir: tags # 标签文件夹\narchive_dir: archives # 归档文件夹\ncategory_dir: categories # 分类文件夹\ncode_dir: downloads/code # Include code文件夹\ni18n_dir: :lang # 国际化文件夹,存放各种语言定义\nskip_render: # 跳过指定文件的渲染\n\n# 写作\nnew_post_name: :title.md # 新文章的文件名称\ndefault_layout: post # 预设布局\ntitlecase: false # 把标题转换为 title case\nexternal_link: true # 在新标签中打开链接\nfilename_case: 0 # 把文件名称转换为 (1) 小写或 (2) 大写\nrender_drafts: false # 显示草稿\npost_asset_folder: false # 启动 Asset 文件夹\nrelative_link: false # 把链接改为与根目录的相对位址\nfuture: true # 显示未来的文章\nhighlight: # 代码块的设置\n enable: true\n line_number: true\n auto_detect: false\n tab_replace:\n\n# 分类 & 标签\ndefault_category: uncategorized # 默认分类\ncategory_map: # 分类别名\ntag_map: # 标签别名\n\n# 日期 / 时间格式\n## Hexo 使用 Moment.js 来解析和显示时间\n## http://momentjs.com/docs/#/displaying/format/\ndate_format: YYYY-MM-DD # 日期格式\ntime_format: HH:mm:ss # 时间格式\n\n# 分页\n## 每页显示的文章量 (0 = 关闭分页功能)\nper_page: 10\npagination_dir: page\n\n# 扩展\n## Plugins: https://hexo.io/plugins/\n## Themes: https://hexo.io/themes/\ntheme: landscape # 主题\n\n# 部署\n## Docs: https://hexo.io/docs/deployment.html\ndeploy:\n type:\n```\n\n{% endfold %}\n\n### Wikitten主题\n\n具体配置参考[开发者说明](https://github.com/zthxxx/hexo-theme-Wikitten/blob/master/README_zh-CN.md),更详细的描述参阅[hexo-theme-icarus](https://github.com/ppoffice/hexo-theme-icarus/wiki)。为了与主题Next不冲突,作以下修改。\n\n1. 自行修改 `tags`, `about`,`categories` 等`index.md`,而不能从主题复制,覆盖站点原有设置。\n2. `languages\\zh-CN.yml` 重命名为 `zh-Hans.yml`\n3. `_config.yml` 菜单作以下更改\n\n```ini\nmenu:\n 首页: /\n 归档: /archives/\n 分类: /categories/\n 标签: /tags/\n 关于: /about/\n```\n\n4. `thumbnail: true` 使得每个post在快速列表里,显示图标。但就是每个帖子都要设定,很麻烦。\n5. post 中的 toc 要设置为 true,如果需要显示目录的话。\n\n### 同时部署两个项目\n\n第一个项目使用 Github 上面默认的 Github Pages,即 `username.github.io` 。在站点配置文件中如下:\n\n```\nurl: http://username.github.io\nroot: /\n...\n...\ndeploy:\n type: git\n repository: git@github.com:username/username.github.io.git\n branch: master\n\n```\n\n\n第二个站点开通一个 普通的repository,添加名为`gh-pages` 的Branch,并将gh-pages` 设为默认Branch。我将第二个仓库命名为 wiki ,那第二个站点就运行在 `https://username.github.io/wiki`次级目录下面。\n\n站点配置文件更改如下:\n\n```\nurl: http://username.github.io/wiki\nroot: /wiki/\n...\n...\ndeploy:\n type: git\n repository: git@github.com:username/wiki.git\n branch: gh-pages\n```\n\n同样用 `hexo d -g` 部署命令发布,两个站点就都运行起来了。\n\n为了使得两个项目使用同一个笔记资源,将站点中的 source 文件夹移到项目意外,将配置文件里的 `source_dir: source` 改为 `source_dir: ../source`(这里使用了相对目录)。\n\n[参考文章][multipages] (细节已经失效,但思路值得参考)\n\n### 站内搜索\n\n1. 安装插件\n\n```shell\nnpm install hexo-generator-search --save\nnpm install hexo-generator-searchdb --save\n```\n\n2. 配置hexo站点主配置文件``_config.yml``, 添加\n\n```ini\nsearch:\n path: search.xml\n field: post\n format: html\n limit: 10000\n```\n\n3. 修改next主题配置文件`_config.yml`,启用 `local_search`\n\n```ini\nlocal_search:\n\tenable: true\n\ttrigger: auto\n\ttop_n_per_article: 1\n```\n\n4. 生成`search.xml`文件以及发布\n\n```shell\nhexo g\nhexo d -g # 本地运行 hexo s\n```\n\n### 去除主题字样\n\n关于添加头像、标签、分类、「关于」等具体的修改,跟着参考资料[^2]里面的步骤做就好了。最后说说如何去掉底部强力驱动及主题字样。\n\n1. 找到 `\\themes\\next\\layout_partials\\`下面的`footer.swig`文件,打开:\n\n```html\n
\n {{ __('footer.powered', 'Hexo') }}\n
\n
\n {{ __('footer.theme') }} -\n \n NexT.{{ theme.scheme }}\n \n
\n```\n\n第一条是“由Hexo驱动” 的Hexo链接,把xml段删除,只留两个单引号''。\n\n第二条是“主题-Next.XX”,将xml段都删掉,不留引号。\n\n```html\n
\n {{ __('footer.powered', '') }}\n
\n
\n {{ __('footer.theme') }}\n
\n```\n\n2. 找到这个地方`\\themes\\next\\languages\\ `下面的语言文件`zh-Hans.yml`(以中文为例):\n\n```ini\nfooter:\n powered: \"由 %s 强力驱动\"\n theme: 主题\n```\n\n将上面的文字改成自己想要的即可。\n\n## 添加评论功能\n\n#### Gitment\n\n**此项目已经终止!**改为Disqus,以及其它评论服务。\n\n1. 安装功能模块。在项目的根目录:\n\n```shell\nnpm i --save gitment\n```\n\n2. 在Github申请应用。`settings -> Developer Settings -> OAuth Apps`\n\n```ini\nApplication name:随便写\nHomepage URL:这个也可以随意写,就写你的博客地址就行\nApplication description:描述,也可以随意写\nAuthorization callback URL:这个必须写你的博客地址\n```\n\n申请好之后点注册,然后就可以看到两个东西`ClientID`和`Client Secret`,后面会用到。\n\n3. 配置Gitment,打开`themes/next/_config.yml`:\n\n```javascript\n# Gitment\n# Introduction: https://imsun.net/posts/gitment-introduction/\ngitment:\n enable: true\n mint: true # RECOMMEND, A mint on Gitment, to support count, language and proxy_gateway\n count: true # Show comments count in post meta area\n lazy: false # Comments lazy loading with a button\n cleanly: false # Hide 'Powered by ...' on footer, and more\n language: # Force language, or auto switch by theme\n github_user: {you github user id}\n github_repo: 随便写一个你的公开的git仓库就行,到时候评论会作为那个项目的issue\n client_id: {刚才申请的ClientID}\n client_secret: {刚才申请的Client Secret}\n proxy_gateway: # Address of api proxy, See: https://github.com/aimingoo/intersect\n redirect_protocol: # Protocol of redirect_uri with force_redirect_protocol when mint enabled\n```\n\n注意到这里基本上已经OK了,再看你的博客应该可以显示评论了.不过每篇博客都需要你手动初始化评论功能(如果你的历史博客很多那就一篇一篇去点吧,不过貌似有人写了批量处理脚本,没试过哈).\n\n而由于 github 中 `Issues` 的 `label` 长度限制为最大 `50` 个字符,当 文章标题长度过长时,该label就会生成失败,而导致初始化错误,弹出 `Validation Failed` 的提示。\n\n通过网上的搜索,发现可以使用文章创建时的时间来代替文章标题,作为这个唯一的label标签。\n\n找到giment的配置:`/themes/next/layout/_third-party/comments/gitment.swig` 文件, 并找到如下部分:\n\n```javascript\nvar gitment = new {{CommentsClass}}({\n id: window.location.pathname,\n owner: '{{ theme.gitment.github_user }}',\n repo: '{{ theme.gitment.github_repo }}',\n ...\n```\n\n将`id`后面的路径值修改为 'itfanr\\_blog\\_\\{{ date(page.date, \"YYYYMMDDhhmmss\") \\}}' 就可以了。\n\n#### Disqus\n\n目前只开通[Disqus](https://disqus.com/)的评论。\n\n1. 开通Disqus账号,并添加一个点 应用。具体步骤参看[Hexo搭建博客系列:(六)Hexo添加Disqus评论](https://www.jianshu.com/p/d68de067ea74)。\n2. 在`主题配置文件`(_config.yml)文件中找到以下代码,添加你Disqus设置的Website Name在shortname。\n\n```json\n# Disqus\ndisqus:\n enable: true\n shortname: tian-ya-de-zhi-fu\n count: true\n```\n\n更详细请参阅网上。\n\n\n\n## 新文章命名规则\n\n发表新文章后系统崩溃。\n\n在根目录的配置文件中找到类似的:\n\n```\n# Writing\nnew_post_name: 新文章.md # File name of new posts\ndefault_layout: post\n...\n```\n\n将其改为由时间和题目组成:\n\n```\n# Writing\nnew_post_name: year-:month-:day-:title.md # File name of new posts\ndefault_layout: post\n...\n```\n\n\n\n# 进阶设置\n\n## 显示\n\n### 首页文章显示预览\n\n默认设定下。首页的文章每一篇都显示全文,不方便浏览。需要到主题的配置文件里将`auto_excerpt` 的 `enable` 改为 `true`。而`length` 字节表示文章预览的长度。\n\n```\n# Automatically Excerpt. Not recommand.\nauto_excerpt:\n\tenable: true\n\tlength: 300\n```\n\n### 永久链接\n\n新文章的名字采用了中文([见上](#id_new_post_name)),中文出现在地址栏上不美观。也不利于SEO,以及增加了博文URL的层数。解决办法是给每篇文章制定链接地址。\n\n1. 修改网站的配置文件中永久地址的设定:\n\n```ini\npermalink: :urlname.html\n```\n\n2. 给每篇文章指定 `urlname`\n\n```ini\ntitle: 《少有人走的路》笔记\ndate: 2019-07-21 00:14:37\nurlname: road-less-traveled-summary\ntags:\n - 心理学\ncategories: 读书笔记\n```\n\n编译后新的地址为 `http://mywiki.test/road-less-traveled-summary.html`。看起来就清爽多了。\n\n### 图片链接\n\n1. 开通[资源文件夹](https://hexo.io/zh-cn/docs/asset-folders),创建新文章的时候会自动建立一个与文章同名的文件夹。可以将图片或者其它资源文件放到里面(*打算将思维导图放到这里*)。因为自定义了[文件名的方式](#id_new_post_name),所以根据官方描述无效。\n2. 安装第三方插件`hexo-asset-image`\n\n```bash\nnpm install hexo-asset-image --save\n```\n\n在文章中图片的链,可以省略路径,直接引用图片名:\n\n```markdown\n![mypicture](mypicture.jpg)\n```\n\n3. 修改插件代码\n\n我在使用永久链接的时候在每篇文章的实际地址都加上了`.html`。文章的地址显示如下\n\n```http\nhttp://mywebsite.com/my-articel-url.html\n```\n\n而插件生成的图片地址如下:\n\n```\nhttp://mywebsite.com/my-articel-url.htm/mypicture.jpg\n```\n\n多出了 `.htm` 这几个字符,而实际图片的地址应该是:\n\n```http\nhttp://mywebsite.com/my-articel-url/mypicture.jpg\n```\n\n找到 `node_modules/hexo-asset-imge` 目录下的 `index.js` 文件,将以下代码中的 `1` 改成 `5`,就可以正常显示图片了。\n\n```javascript\nvar endPos = link.length - 1\n```\n\n考虑到将来项目膨胀,应该将图片放到图床,比如七牛。\n\n### 站内链接\n\n导航到站内别的文章使用以下方式就可以。\n\n链接方式 `[文章名](urlname.html)`\n\n\n\n### 设定代码区的高度\n\nHexo自身的式样暂时还没找到。其实也不太需要。如果代码不长直接显示全部就好了。太长的话不如放到$Gits$,通过限制gist的高度实现。**Net**主题修改 `next/themes/next/source/css/_custom/custom.styl` ,Wikitten主题则在文件 `wikitten/themes/Wikitten/source/css/_partial/article.styl` 中修改。\n\n```CSS\n.gist \n.gist-file\n.gist-data {\n max-height: 450px;\n}\n```\n\n\n\n### 添加注脚支持\n\n[插件项目](https://github.com/LouisBarranqueiro/hexo-footnotes)\n\n1. 安装插件 `npm install hexo-footnotes --save`\n2. **项目配置文件** 添加\n\n```ini\n# 注意第二行的前面没有 \"-\" 符号,官方说明有. 但是会导致无法编译.\nplugins:\n hexo-footnotes\n```\n\n\n\n### 更换Markdown渲染\n\n[Markdown-it-plus](https://github.com/CHENXCHEN/hexo-renderer-markdown-it-plus)\n\n如果更换了这个渲染,就无需上面那个注脚插件, 因为已经支持了. 首先卸载掉旧的渲染, 然后安装新的.\n\n```sh\nnpm un hexo-renderer-marked --save\nnpm i hexo-renderer-markdown-it-plus --save\n# 查看是否已经安装\nnpm ls hexo-renderer-markdown-it-plus\n```\n\n然后在项目配置文件, 添加下面文字. 更深入的设置, 参看 markdown-it-plus 项目的说明文档.\n\n```ini\nmarkdown_it_plus:\n highlight: true\n html: true\n xhtmlOut: true\n breaks: true\n langPrefix:\n linkify: true\n typographer:\n quotes: “”‘’\n plugins:\n```\n\n\n\n## 辅助功能\n\n### 本地运行服务\n\n在Mac中可以用本地服务[Pow](http://pow.cx)运行网站,不用每次更改重启服务器`hexo s`。\n\n1. 安装Pow\n\n```bash\n$ curl get.pow.cx | sh\n```\n\n2. 建立项目链接,`myapp` 是项目的名字。比如真实路径`~/Project/mywiki`\n\n```bash\n$ cd ~/.pow\n$ ln -s /path/to/myapp\n```\n\n3. 执行完以上步骤后在浏览器打开链接 ``http://myapp.test/`` 就能看到网站。更改内容后要执行==生成== 命令才能看到更新`hexo generate` or `hexo g` 。\n4. 不想运行,直接把项目文件夹删除就可以。\n\n### 绑定个人域名\n\n1. 在万网买一个顶级域名,开通后添加两个域名解释\n\n```ini\n#记录名 主机记录 记录值\nCNAME www username.github.io\nCNAME @ username.github.io\n```\n\n2. 在项目的根目录添加一个名为 `CNAME` 的文件,然后填入万网注册的域名, 这里是 `goldentianya.pub` 。第一次我是手动添加的。添加后进入 repository 的 setting, 往下混动到 Custom domain ,可以看到系统已经自动把用户域名加进去了。\n3. 将来不希望用这个域名,域名重定向后,在浏览器输入 username.github.io 后 Chrome 会一直转向 goldentianya.pub 。需要打开`开发者工具`,选中 `disable cache` ,再刷新一遍地址就好了。\n4. `next` 项目要将 `CNAME` 文件复制到 `/themes/next/source` 目录下个,编译的时候会拷贝到 `public` 目录。`wikitten` 项目不需要,域名定向以后能找到 `goldentianya/wiki` 站点,十分神奇。\n\n### 隐藏文章\n\n#### 全隐藏\n\n根据插件`hext-sage-posts` 作者的博文[^9]中描述,安装插件\n\n```bash\nnpm install hexo-sage-posts --save\n```\n\n并将初创时的`Hello-world.md` 文章的Metadata中加入`sage: true`,文章就从网站上消失了。但在别的文章下面导航栏中,通过“下一篇”或者“上一篇”还是能被找到。被隐藏的文章其地址仍旧没有改变,只是不不出现在首页导航,和分类中而已。\n\n#### 从首页隐藏\n\n为了不让太琐碎的文章充斥首页,但又可以在分类中找到。可以采用这种方式。\n\n1. 在文章的Metadata部分添加关键字 `notshow: true`。\n2. 找到 `Hexo\\themes\\next\\layout\\index.swig` 文件中以下部分:\n\n```html\n{% block content %}\n
\n {% for post in page.posts %}\n {{ post_template.render(post, true) }} \n {% endfor %}\n
\n\n {% include '_partials/pagination.swig' %}\n{% endblock %}\n```\n\n将以上代码第四行修改为\n\n```html\n{% if post.notshow != true %}\n\t{{ post_template.render(post, true) }}\n{% endif %}\n```\n\n\n\n#### 文章加密\n\n1. 安装插件 `hexo-blog-encrypt`\n\n```\nnpm install --save hexo-blog-encrypt\n```\n\n并在**站点配置**文件中启用该插件:\n\n```json\nencrypt:\n enable: true\n```\n\n2. 然后在文章的头部添加上对应的字段\n\n```ini\n---\ntitle: 文章加密\ndate: 2019-01-04T22:20:13.000Z\ncategory: 教程\ntags:\n - 博客\n - Hexo\nkeywords: 博客文章密码\npassword: TloveY\nabstract: 此文章含有敏感内容。\nmessage: 输入密码,查看文章\n---\n```\n\n- password: 是该博客加密使用的密码\n\n- abstract: 是该博客的摘要,会显示在博客的列表页\n\n- message: 这个是博客查看时,密码输入框上面的描述性文字\n\n\n\n### Hexo Admin\n\n安装后台管理插件 `hexo-damin`\n\n```bash\nnpm install --save hexo-admin\nhexo server -d\nopen http://localhost:4000/admin/\n```\n\n初次运行后,设置管理账户。\n\n```\nadmin:\n username: maiernte\n password_hash: $2a$10$QeeWfDwIxbJ94h8EDfplDe9aLB0uaNrjMeVGhaYnfF0BBDosDze0S\n secret: NamoAmitabha!\n```\n\n### 访问量统计\n\n[介绍文章](https://bjtu-hxs.github.io/2018/06/12/leancloud-config/) (*有图*)\n\n[原文(有代码)](https://notes.doublemine.me/2015-10-21-%E4%B8%BANexT%E4%B8%BB%E9%A2%98%E6%B7%BB%E5%8A%A0%E6%96%87%E7%AB%A0%E9%98%85%E8%AF%BB%E9%87%8F%E7%BB%9F%E8%AE%A1%E5%8A%9F%E8%83%BD.html#%E9%85%8D%E7%BD%AELeanCloud)\n\n1. 第一步, 到Lean Cloud增添一个应用,并创建类似Counter 的类。设置成 $ 所有人可读可写 $\n2. 在安全中心添加 **Web 安全域名**, 添加Blog域名,防止有人Hack我们的数据库。\n\n3. 按上面的文章修改 Hexo 以及主题配置。\n\n\n\n### 在线交流\n\n使用 [道客](https://www.daovoice.io/) Daovoice\n\n接入方式\n\n1. 将下面代码粘贴在页面的 之前。\n\n```\n\n```\n\n2. 调用下面的 JavaScript 与注册用户沟通\n\n```\ndaovoice('init', {\n app_id: \"5e5fa370\",\n user_id: \"NO_89757\", // 必填: 该用户在您系统上的唯一ID\n email: \"daovoice@example.com\", // 选填: 该用户在您系统上的主邮箱\n name: \"道客船长\", // 选填: 用户名\n signed_up: 1449821660 // 选填: 用户的注册时间,用Unix时间戳表示\n});\ndaovoice('update');\n```\n\n3. 调用下面的 JavaScript 与匿名访客沟通\n\n```\ndaovoice('init', {\n app_id: \"5e5fa370\"\n});\ndaovoice('update');\n```\n\n完成代码粘贴后,检测是否成功接入: Ping 一下\n\n\n\n### 待解决问题\n\n- [x] 文章评论\n- [x] 在线编辑?\n- [x] 使用七牛图床\n- [ ] 脑图摆放 ([官方文档/数据文件](https://hexo.io/zh-cn/docs/data-files))\n- [x] 文件下载(可能还是要靠七牛)\n- [x] 用submodule管理主题 [在 hexo 中使用 git submodules 管理主题](https://juejin.im/post/5c2e22fcf265da615d72c596)\n- [ ] SEO\n- [ ] 访问量统计\n- [ ] 加速 [Github Pages + CDN全站加速](https://www.jianshu.com/p/ccc0cc8c14a0)\n\n- [ ] [在vps上部署hexo博客的那些事](https://segmentfault.com/a/1190000019104144)\n\n# 有趣插件\n\n- [x] [短地址 & 指定摘要](https://www.jianshu.com/p/805bd0b65d98) \n\n- [ ] [农历/很好的学习做插件的例子](https://github.com/inchei/hexo-lunar-calendar)\n\n- [ ] [插入pdf](https://github.com/superalsrk/hexo-pdf/) 可以学习如何插入epub\n\n- [ ] [hexo-include](https://github.com/pirtleshell/hexo-include) 加载文本内容, html, js, text\n\n- [x] [Hexo-NexT给文章添加结束语](https://wangc1993.github.io/2019/01/10/6/)\n\n- [x] [Hexo-NexT接入网页在线联系功能](https://wangc1993.github.io/2019/01/10/5/)\n\n- [ ] [include markdown](https://github.com/tea3/hexo-include-markdown)\n\n\n\n### ---\n\n\n\n[^1]: [Hexo博客搭建全攻略(一):基于Hexo+Github环境搭建](https://blog.annieyu.com/posts/207737771.html)\n[^2]: [Hexo博客搭建全攻略(二):NexT主题配置](https://blog.annieyu.com/posts/976961586.html)\n[^3]: [Hexo博客搭建全攻略(三):三方服务集成](https://blog.annieyu.com/posts/1209152972.html)\n[^4]: [Hexo博客搭建全攻略(四):高级应用](https://blog.annieyu.com/posts/3333782006.html)\n[^5]: [Hexo博客搭建全攻略(五):基于Github Issue搭建评论系统](https://blog.annieyu.com/posts/a341668e.html)\n[^6]: [Hexo博客搭建全攻略(六):博文图片处理](https://www.jianshu.com/p/2bb87ae49ff6)\n[^7]: [十步之内轻松搞定 Hexo + GitHub搭建个人博客](https://gavinlee1.github.io/2017/02/25/%E5%8D%81%E6%AD%A5%E4%B9%8B%E5%86%85%E8%BD%BB%E6%9D%BE%E6%90%9E%E5%AE%9A-Hexo-GitHub%E6%90%AD%E5%BB%BA%E4%B8%AA%E4%BA%BA%E5%8D%9A%E5%AE%A2/) ​​\n[^8]: [如何优雅的 隐藏博客](https://vanchchen.github.io/p/7587.html)\n[^9]: [为 Hexo 博客添加隐藏文章 / 限定公开功能](https://blessing.studio/hexo-plugin-to-make-posts-sage-unlisted/)\n[^10]: [Hexo 中文文档](https://hexo.io/zh-cn/docs/index.html)\n\n[multipages]: ttp://chitanda.me/2015/11/03/multiple-git-pages-in-one-github-account/\n\n[讲解详细的博客](https://binglumeng.github.io/2017/03/21/Hexo学习笔记/) \n\n[这个也不错](http://yearito.cn/posts/hexo-advanced-settings.html)\n\n\n","slug":"IT/Web/搭建Hexo博客的流水账","published":1,"updated":"2019-08-15T10:44:25.000Z","_id":"cka1y59a2004u4huur56brcea","comments":1,"layout":"post","photos":[],"link":"","content":"

建立网站

\n

Github配置

\n

输入命令 ssh-keygen -t rsa -b 4096 -C "myname@gmail.com"

\n

密码 T1。(下列展开后复制)

\n
\n

将文件 ~/.ssh/id_rsa.pub 中的内容复制到 Github 的SSH-Key 内就可以了。(备份文件已上传百度网盘)

\n
\n
    \n
  1. 在Github上新建SSH-Key名称为gmail
  2. \n
\n

具体步骤参阅此文章

\n
1
2
3
4
5
6
7
8
9
10
11
12
ssh-keygen -t rsa -b 4096 -C "username@gmail.com"
[Enter]
[password T..1]

eval "$(ssh-agent -s)"
ssh-add -K ~/.ssh/id_rsa

cd ~
cd .ssh
ls
vim id_rsa.pub
(然后复制钥匙串)
\n
    \n
  1. 测试公匙
  2. \n
\n
1
2
3
$ ssh -T git@github.com

Hi username! You've successfully authenticated, but GitHub does not provide shell access.
\n

安装Hexo

\n

参考资料1 7

\n
    \n
  1. 安装node.js 因为以前已经安装过,所以跳过。
  2. \n
  3. 安装 Hexo $ npm install hexo-cli -g
  4. \n
  5. 创建网站
  6. \n
\n
1
2
3
4
mkdir mywiki
cd mywiki
hexo init
npm install
\n
    \n
  1. 生成静态页面 hexo g or hexo generate
  2. \n
  3. 启动本地网站服务 hexo s or hexo server
  4. \n
\n
\n

网站一般会运行在 http://localhost:4000/
\nPress Ctrl+C to stop.

\n
\n
    \n
  1. 用pow做服务本地运行
  2. \n
\n

Install

\n
1
$ curl get.pow.cx | sh
\n

Setup

\n

Symlink the folder into ~/.pow

\n
1
2
$ cd ~/.pow
$ ln -s /path/to/test
\n

发布到Github

\n

终于搭建好站点部署环境啦,那么要怎么样将我们本地生成预览好的页面发布到github上呢?很简单,Follow!

\n

首先,打开blog目录下的_config.yml,找到deploy段,配置成这样

\n
\n

deploy:
\ntype: git
\nrepository: git@github.com:yourname/yourname.github.io.git
\nbranch: master

\n
\n

注意将代码里面的yourname换成你账号的username。

\n

设置git身份信息

\n
\n

git config --global user.name “你的用户名”
\ngit config --global user.email “你的邮箱”

\n
\n

执行以下指令进行部署

\n

hexo d -g

\n

如果提示没找到git,请先执行以下指令

\n

cnpm install hexo-deployer-git --save

\n

再次部署后,浏览器打开 https://yourname.github.io 就可以看到刚才本地预览页面。

\n

网站基本配置

\n

Next 主题

\n

主题配置文件说明

\n
点击显/隐内容
\n
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
# Hexo 站点配置文件
## Docs: https://hexo.io/docs/configuration.html
## Source: https://github.com/hexojs/hexo/

# 网站配置
title: Hexo # 网站标题
subtitle: # 网站副标题
description: # 网站描述
author: John Doe # 你的昵称
language: # 网站使用的语言(英文:en, 简体中文:zh-Hans,繁体中文:zh-tw)
timezone: # 网站时区,用于生成页面时填充相关时间,默认使用电脑时区,一般不用改

# URL
## 如果你的站点要放入子目录, 请将url设置为'http://yoursite.com/child' 并将根目录设置为'/child/'
url: http://yoursite.com # 站点网址
root: / # 网站根目录
permalink: :year/:month/:day/:title/ #文单的永久链接格式
permalink_defaults: # 永久链接中各部分的默认值

# 目录
source_dir: source # 资源文件夹,这个文件夹用来存放博客内容
public_dir: public # 公共文件夹,这个文件夹用来存放生成的站点静态文件
tag_dir: tags # 标签文件夹
archive_dir: archives # 归档文件夹
category_dir: categories # 分类文件夹
code_dir: downloads/code # Include code文件夹
i18n_dir: :lang # 国际化文件夹,存放各种语言定义
skip_render: # 跳过指定文件的渲染

# 写作
new_post_name: :title.md # 新文章的文件名称
default_layout: post # 预设布局
titlecase: false # 把标题转换为 title case
external_link: true # 在新标签中打开链接
filename_case: 0 # 把文件名称转换为 (1) 小写或 (2) 大写
render_drafts: false # 显示草稿
post_asset_folder: false # 启动 Asset 文件夹
relative_link: false # 把链接改为与根目录的相对位址
future: true # 显示未来的文章
highlight: # 代码块的设置
enable: true
line_number: true
auto_detect: false
tab_replace:

# 分类 & 标签
default_category: uncategorized # 默认分类
category_map: # 分类别名
tag_map: # 标签别名

# 日期 / 时间格式
## Hexo 使用 Moment.js 来解析和显示时间
## http://momentjs.com/docs/#/displaying/format/
date_format: YYYY-MM-DD # 日期格式
time_format: HH:mm:ss # 时间格式

# 分页
## 每页显示的文章量 (0 = 关闭分页功能)
per_page: 10
pagination_dir: page

# 扩展
## Plugins: https://hexo.io/plugins/
## Themes: https://hexo.io/themes/
theme: landscape # 主题

# 部署
## Docs: https://hexo.io/docs/deployment.html
deploy:
type:
\n\n
\n

Wikitten主题

\n

具体配置参考开发者说明,更详细的描述参阅hexo-theme-icarus。为了与主题Next不冲突,作以下修改。

\n
    \n
  1. 自行修改 tags, about,categoriesindex.md,而不能从主题复制,覆盖站点原有设置。
  2. \n
  3. languages\\zh-CN.yml 重命名为 zh-Hans.yml
  4. \n
  5. _config.yml 菜单作以下更改
  6. \n
\n
1
2
3
4
5
6
menu:
首页: /
归档: /archives/
分类: /categories/
标签: /tags/
关于: /about/
\n
    \n
  1. thumbnail: true 使得每个post在快速列表里,显示图标。但就是每个帖子都要设定,很麻烦。
  2. \n
  3. post 中的 toc 要设置为 true,如果需要显示目录的话。
  4. \n
\n

同时部署两个项目

\n

第一个项目使用 Github 上面默认的 Github Pages,即 username.github.io 。在站点配置文件中如下:

\n
1
2
3
4
5
6
7
8
url: http://username.github.io
root: /
...
...
deploy:
type: git
repository: git@github.com:username/username.github.io.git
branch: master
\n

第二个站点开通一个 普通的repository,添加名为gh-pages 的Branch,并将gh-pages设为默认Branch。我将第二个仓库命名为 wiki ,那第二个站点就运行在https://username.github.io/wiki`次级目录下面。

\n

站点配置文件更改如下:

\n
1
2
3
4
5
6
7
8
url: http://username.github.io/wiki
root: /wiki/
...
...
deploy:
type: git
repository: git@github.com:username/wiki.git
branch: gh-pages
\n

同样用 hexo d -g 部署命令发布,两个站点就都运行起来了。

\n

为了使得两个项目使用同一个笔记资源,将站点中的 source 文件夹移到项目意外,将配置文件里的 source_dir: source 改为 source_dir: ../source(这里使用了相对目录)。

\n

参考文章 (细节已经失效,但思路值得参考)

\n

站内搜索

\n
    \n
  1. 安装插件
  2. \n
\n
1
2
npm install hexo-generator-search --save
npm install hexo-generator-searchdb --save
\n
    \n
  1. 配置hexo站点主配置文件_config.yml, 添加
  2. \n
\n
1
2
3
4
5
search:
path: search.xml
field: post
format: html
limit: 10000
\n
    \n
  1. 修改next主题配置文件_config.yml,启用 local_search
  2. \n
\n
1
2
3
4
local_search:
\tenable: true
\ttrigger: auto
\ttop_n_per_article: 1
\n
    \n
  1. 生成search.xml文件以及发布
  2. \n
\n
1
2
hexo g
hexo d -g # 本地运行 hexo s
\n

去除主题字样

\n

关于添加头像、标签、分类、「关于」等具体的修改,跟着参考资料2里面的步骤做就好了。最后说说如何去掉底部强力驱动及主题字样。

\n
    \n
  1. 找到 \\themes\\next\\layout_partials\\下面的footer.swig文件,打开:
  2. \n
\n
1
2
3
4
5
6
7
8
9
<div class=\"powered-by\">
{{ __('footer.powered', '<a class=\"theme-link\" href=\"https://hexo.io\">Hexo</a>') }}
</div>
<div class=\"theme-info\">
{{ __('footer.theme') }} -
<a class=\"theme-link\" href=\"https://github.com/iissnan/hexo-theme-next\">
NexT.{{ theme.scheme }}
</a>
</div>
\n

第一条是“由Hexo驱动” 的Hexo链接,把xml段删除,只留两个单引号’’。

\n

第二条是“主题-Next.XX”,将xml段都删掉,不留引号。

\n
1
2
3
4
5
6
<div class=\"powered-by\">
{{ __('footer.powered', '') }}
</div>
<div class=\"theme-info\">
{{ __('footer.theme') }}
</div>
\n
    \n
  1. 找到这个地方\\themes\\next\\languages\\ 下面的语言文件zh-Hans.yml(以中文为例):
  2. \n
\n
1
2
3
footer:
powered: \"由 %s 强力驱动\"
theme: 主题
\n

将上面的文字改成自己想要的即可。

\n

添加评论功能

\n

Gitment

\n

**此项目已经终止!**改为Disqus,以及其它评论服务。

\n
    \n
  1. 安装功能模块。在项目的根目录:
  2. \n
\n
1
npm i --save gitment
\n
    \n
  1. 在Github申请应用。settings -> Developer Settings -> OAuth Apps
  2. \n
\n
1
2
3
4
Application name:随便写
Homepage URL:这个也可以随意写,就写你的博客地址就行
Application description:描述,也可以随意写
Authorization callback URL:这个必须写你的博客地址
\n

申请好之后点注册,然后就可以看到两个东西ClientIDClient Secret,后面会用到。

\n
    \n
  1. 配置Gitment,打开themes/next/_config.yml:
  2. \n
\n
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
# Gitment
# Introduction: https://imsun.net/posts/gitment-introduction/
gitment:
enable: true
mint: true # RECOMMEND, A mint on Gitment, to support count, language and proxy_gateway
count: true # Show comments count in post meta area
lazy: false # Comments lazy loading with a button
cleanly: false # Hide 'Powered by ...' on footer, and more
language: # Force language, or auto switch by theme
github_user: {you github user id}
github_repo: 随便写一个你的公开的git仓库就行,到时候评论会作为那个项目的issue
client_id: {刚才申请的ClientID}
client_secret: {刚才申请的Client Secret}
proxy_gateway: # Address of api proxy, See: https://github.com/aimingoo/intersect
redirect_protocol: # Protocol of redirect_uri with force_redirect_protocol when mint enabled
\n

注意到这里基本上已经OK了,再看你的博客应该可以显示评论了.不过每篇博客都需要你手动初始化评论功能(如果你的历史博客很多那就一篇一篇去点吧,不过貌似有人写了批量处理脚本,没试过哈).

\n

而由于 github 中 Issueslabel 长度限制为最大 50 个字符,当 文章标题长度过长时,该label就会生成失败,而导致初始化错误,弹出 Validation Failed 的提示。

\n

通过网上的搜索,发现可以使用文章创建时的时间来代替文章标题,作为这个唯一的label标签。

\n

找到giment的配置:/themes/next/layout/_third-party/comments/gitment.swig 文件, 并找到如下部分:

\n
1
2
3
4
5
var gitment = new {{CommentsClass}}({
id: window.location.pathname,
owner: '{{ theme.gitment.github_user }}',
repo: '{{ theme.gitment.github_repo }}',
...
\n

id后面的路径值修改为 ‘itfanr_blog_<!–1–>’ 就可以了。

\n

Disqus

\n

目前只开通Disqus的评论。

\n
    \n
  1. 开通Disqus账号,并添加一个点 应用。具体步骤参看Hexo搭建博客系列:(六)Hexo添加Disqus评论
  2. \n
  3. 主题配置文件(_config.yml)文件中找到以下代码,添加你Disqus设置的Website Name在shortname。
  4. \n
\n
1
2
3
4
5
# Disqus
disqus:
enable: true
shortname: tian-ya-de-zhi-fu
count: true
\n

更详细请参阅网上。

\n

新文章命名规则

\n

发表新文章后系统崩溃。

\n

在根目录的配置文件中找到类似的:

\n
1
2
3
4
# Writing
new_post_name: 新文章.md # File name of new posts
default_layout: post
...
\n

将其改为由时间和题目组成:

\n
1
2
3
4
# Writing
new_post_name: year-:month-:day-:title.md # File name of new posts
default_layout: post
...
\n

进阶设置

\n

显示

\n

首页文章显示预览

\n

默认设定下。首页的文章每一篇都显示全文,不方便浏览。需要到主题的配置文件里将auto_excerptenable 改为 true。而length 字节表示文章预览的长度。

\n
1
2
3
4
# Automatically Excerpt. Not recommand.
auto_excerpt:
\tenable: true
\tlength: 300
\n

永久链接

\n

新文章的名字采用了中文(见上),中文出现在地址栏上不美观。也不利于SEO,以及增加了博文URL的层数。解决办法是给每篇文章制定链接地址。

\n
    \n
  1. 修改网站的配置文件中永久地址的设定:
  2. \n
\n
1
permalink: :urlname.html
\n
    \n
  1. 给每篇文章指定 urlname
  2. \n
\n
1
2
3
4
5
6
title: 《少有人走的路》笔记
date: 2019-07-21 00:14:37
urlname: road-less-traveled-summary
tags:
- 心理学
categories: 读书笔记
\n

编译后新的地址为 http://mywiki.test/road-less-traveled-summary.html。看起来就清爽多了。

\n

图片链接

\n
    \n
  1. 开通资源文件夹,创建新文章的时候会自动建立一个与文章同名的文件夹。可以将图片或者其它资源文件放到里面(打算将思维导图放到这里)。因为自定义了文件名的方式,所以根据官方描述无效。
  2. \n
  3. 安装第三方插件hexo-asset-image
  4. \n
\n
1
npm install hexo-asset-image --save
\n

在文章中图片的链,可以省略路径,直接引用图片名:

\n
1
![mypicture](mypicture.jpg)
\n
    \n
  1. 修改插件代码
  2. \n
\n

我在使用永久链接的时候在每篇文章的实际地址都加上了.html。文章的地址显示如下

\n
1
http://mywebsite.com/my-articel-url.html
\n

而插件生成的图片地址如下:

\n
1
http://mywebsite.com/my-articel-url.htm/mypicture.jpg
\n

多出了 .htm 这几个字符,而实际图片的地址应该是:

\n
1
http://mywebsite.com/my-articel-url/mypicture.jpg
\n

找到 node_modules/hexo-asset-imge 目录下的 index.js 文件,将以下代码中的 1 改成 5,就可以正常显示图片了。

\n
1
var endPos = link.length - 1
\n

考虑到将来项目膨胀,应该将图片放到图床,比如七牛。

\n

站内链接

\n

导航到站内别的文章使用以下方式就可以。

\n

链接方式 [文章名](urlname.html)

\n

设定代码区的高度

\n

Hexo自身的式样暂时还没找到。其实也不太需要。如果代码不长直接显示全部就好了。太长的话不如放到$Gits$,通过限制gist的高度实现。Net主题修改 next/themes/next/source/css/_custom/custom.styl ,Wikitten主题则在文件 wikitten/themes/Wikitten/source/css/_partial/article.styl 中修改。

\n
1
2
3
4
5
.gist 
.gist-file
.gist-data {
max-height: 450px;
}
\n

添加注脚支持

\n

插件项目

\n
    \n
  1. 安装插件 npm install hexo-footnotes --save
  2. \n
  3. 项目配置文件 添加
  4. \n
\n
1
2
3
# 注意第二行的前面没有 \"-\" 符号,官方说明有. 但是会导致无法编译.
plugins:
hexo-footnotes
\n

更换Markdown渲染

\n

Markdown-it-plus

\n

如果更换了这个渲染,就无需上面那个注脚插件, 因为已经支持了. 首先卸载掉旧的渲染, 然后安装新的.

\n
1
2
3
4
npm un hexo-renderer-marked --save
npm i hexo-renderer-markdown-it-plus --save
# 查看是否已经安装
npm ls hexo-renderer-markdown-it-plus
\n

然后在项目配置文件, 添加下面文字. 更深入的设置, 参看 markdown-it-plus 项目的说明文档.

\n
1
2
3
4
5
6
7
8
9
10
markdown_it_plus:
highlight: true
html: true
xhtmlOut: true
breaks: true
langPrefix:
linkify: true
typographer:
quotes: “”‘’
plugins:
\n

辅助功能

\n

本地运行服务

\n

在Mac中可以用本地服务Pow运行网站,不用每次更改重启服务器hexo s

\n
    \n
  1. 安装Pow
  2. \n
\n
1
$ curl get.pow.cx | sh
\n
    \n
  1. 建立项目链接,myapp 是项目的名字。比如真实路径~/Project/mywiki
  2. \n
\n
1
2
$ cd ~/.pow
$ ln -s /path/to/myapp
\n
    \n
  1. 执行完以上步骤后在浏览器打开链接 http://myapp.test/ 就能看到网站。更改内容后要执行==生成== 命令才能看到更新hexo generate or hexo g
  2. \n
  3. 不想运行,直接把项目文件夹删除就可以。
  4. \n
\n

绑定个人域名

\n
    \n
  1. 在万网买一个顶级域名,开通后添加两个域名解释
  2. \n
\n
1
2
3
#记录名  主机记录  记录值
CNAME www username.github.io
CNAME @ username.github.io
\n
    \n
  1. 在项目的根目录添加一个名为 CNAME 的文件,然后填入万网注册的域名, 这里是 goldentianya.pub 。第一次我是手动添加的。添加后进入 repository 的 setting, 往下混动到 Custom domain ,可以看到系统已经自动把用户域名加进去了。
  2. \n
  3. 将来不希望用这个域名,域名重定向后,在浏览器输入 username.github.io 后 Chrome 会一直转向 goldentianya.pub 。需要打开开发者工具,选中 disable cache ,再刷新一遍地址就好了。
  4. \n
  5. next 项目要将 CNAME 文件复制到 /themes/next/source 目录下个,编译的时候会拷贝到 public 目录。wikitten 项目不需要,域名定向以后能找到 goldentianya/wiki 站点,十分神奇。
  6. \n
\n

隐藏文章

\n

全隐藏

\n

根据插件hext-sage-posts 作者的博文9中描述,安装插件

\n
1
npm install hexo-sage-posts --save
\n

并将初创时的Hello-world.md 文章的Metadata中加入sage: true,文章就从网站上消失了。但在别的文章下面导航栏中,通过“下一篇”或者“上一篇”还是能被找到。被隐藏的文章其地址仍旧没有改变,只是不不出现在首页导航,和分类中而已。

\n

从首页隐藏

\n

为了不让太琐碎的文章充斥首页,但又可以在分类中找到。可以采用这种方式。

\n
    \n
  1. 在文章的Metadata部分添加关键字 notshow: true
  2. \n
  3. 找到 Hexo\\themes\\next\\layout\\index.swig 文件中以下部分:
  4. \n
\n
1
2
3
4
5
6
7
8
9
{% block content %}
<section id=\"posts\" class=\"posts-expand\">
{% for post in page.posts %}
{{ post_template.render(post, true) }} <!--修改此行-->
{% endfor %}
</section>

{% include '_partials/pagination.swig' %}
{% endblock %}
\n

将以上代码第四行修改为

\n
1
2
3
{% if post.notshow != true %}
\t{{ post_template.render(post, true) }}
{% endif %}
\n

文章加密

\n
    \n
  1. 安装插件 hexo-blog-encrypt
  2. \n
\n
1
npm install --save hexo-blog-encrypt
\n

并在站点配置文件中启用该插件:

\n
1
2
encrypt:
enable: true
\n
    \n
  1. 然后在文章的头部添加上对应的字段
  2. \n
\n
1
2
3
4
5
6
7
8
9
10
11
12
---
title: 文章加密
date: 2019-01-04T22:20:13.000Z
category: 教程
tags:
- 博客
- Hexo
keywords: 博客文章密码
password: TloveY
abstract: 此文章含有敏感内容。
message: 输入密码,查看文章
---
\n
    \n
  • \n

    password: 是该博客加密使用的密码

    \n
  • \n
  • \n

    abstract: 是该博客的摘要,会显示在博客的列表页

    \n
  • \n
  • \n

    message: 这个是博客查看时,密码输入框上面的描述性文字

    \n
  • \n
\n

Hexo Admin

\n

安装后台管理插件 hexo-damin

\n
1
2
3
npm install --save hexo-admin
hexo server -d
open http://localhost:4000/admin/
\n

初次运行后,设置管理账户。

\n
1
2
3
4
admin:
username: maiernte
password_hash: $2a$10$QeeWfDwIxbJ94h8EDfplDe9aLB0uaNrjMeVGhaYnfF0BBDosDze0S
secret: NamoAmitabha!
\n

访问量统计

\n

介绍文章有图

\n

原文(有代码)

\n
    \n
  1. \n

    第一步, 到Lean Cloud增添一个应用,并创建类似Counter 的类。设置成 $ 所有人可读可写 $

    \n
  2. \n
  3. \n

    在安全中心添加 Web 安全域名, 添加Blog域名,防止有人Hack我们的数据库。

    \n
  4. \n
  5. \n

    按上面的文章修改 Hexo 以及主题配置。

    \n
  6. \n
\n

在线交流

\n

使用 道客 Daovoice

\n

接入方式

\n
    \n
  1. 将下面代码粘贴在页面的 之前。
  2. \n
\n
1
<script>(function(i,s,o,g,r,a,m){i["DaoVoiceObject"]=r;i[r]=i[r]||function(){(i[r].q=i[r].q||[]).push(arguments)},i[r].l=1*new Date();a=s.createElement(o),m=s.getElementsByTagName(o)[0];a.async=1;a.src=g;a.charset="utf-8";m.parentNode.insertBefore(a,m)})(window,document,"script",('https:' == document.location.protocol ? 'https:' : 'http:') + "//widget.daovoice.io/widget/5e5fa370.js","daovoice")</script>
\n
    \n
  1. 调用下面的 JavaScript 与注册用户沟通
  2. \n
\n
1
2
3
4
5
6
7
8
daovoice('init', {
app_id: "5e5fa370",
user_id: "NO_89757", // 必填: 该用户在您系统上的唯一ID
email: "daovoice@example.com", // 选填: 该用户在您系统上的主邮箱
name: "道客船长", // 选填: 用户名
signed_up: 1449821660 // 选填: 用户的注册时间,用Unix时间戳表示
});
daovoice('update');
\n
    \n
  1. 调用下面的 JavaScript 与匿名访客沟通
  2. \n
\n
1
2
3
4
daovoice('init', {
app_id: "5e5fa370"
});
daovoice('update');
\n

完成代码粘贴后,检测是否成功接入: Ping 一下

\n

待解决问题

\n\n

有趣插件

\n\n

\n

讲解详细的博客

\n

这个也不错

\n","site":{"data":{}},"excerpt":"

建网过程中的一些流水账。以备将来查询。

","more":"

建立网站

\n

Github配置

\n

输入命令 ssh-keygen -t rsa -b 4096 -C "myname@gmail.com"

\n

密码 T1。(下列展开后复制)

\n
\n

将文件 ~/.ssh/id_rsa.pub 中的内容复制到 Github 的SSH-Key 内就可以了。(备份文件已上传百度网盘)

\n
\n
    \n
  1. 在Github上新建SSH-Key名称为gmail
  2. \n
\n

具体步骤参阅此文章

\n\n
    \n
  1. 测试公匙
  2. \n
\n\n

安装Hexo

\n

参考资料1 7

\n
    \n
  1. 安装node.js 因为以前已经安装过,所以跳过。
  2. \n
  3. 安装 Hexo $ npm install hexo-cli -g
  4. \n
  5. 创建网站
  6. \n
\n\n
    \n
  1. 生成静态页面 hexo g or hexo generate
  2. \n
  3. 启动本地网站服务 hexo s or hexo server
  4. \n
\n
\n

网站一般会运行在 http://localhost:4000/
\nPress Ctrl+C to stop.

\n
\n
    \n
  1. 用pow做服务本地运行
  2. \n
\n

Install

\n\n

Setup

\n

Symlink the folder into ~/.pow

\n\n

发布到Github

\n

终于搭建好站点部署环境啦,那么要怎么样将我们本地生成预览好的页面发布到github上呢?很简单,Follow!

\n

首先,打开blog目录下的_config.yml,找到deploy段,配置成这样

\n
\n

deploy:
\ntype: git
\nrepository: git@github.com:yourname/yourname.github.io.git
\nbranch: master

\n
\n

注意将代码里面的yourname换成你账号的username。

\n

设置git身份信息

\n
\n

git config --global user.name “你的用户名”
\ngit config --global user.email “你的邮箱”

\n
\n

执行以下指令进行部署

\n

hexo d -g

\n

如果提示没找到git,请先执行以下指令

\n

cnpm install hexo-deployer-git --save

\n

再次部署后,浏览器打开 https://yourname.github.io 就可以看到刚才本地预览页面。

\n

网站基本配置

\n

Next 主题

\n

主题配置文件说明

\n
点击显/隐内容
\n\n\n
\n

Wikitten主题

\n

具体配置参考开发者说明,更详细的描述参阅hexo-theme-icarus。为了与主题Next不冲突,作以下修改。

\n
    \n
  1. 自行修改 tags, about,categoriesindex.md,而不能从主题复制,覆盖站点原有设置。
  2. \n
  3. languages\\zh-CN.yml 重命名为 zh-Hans.yml
  4. \n
  5. _config.yml 菜单作以下更改
  6. \n
\n\n
    \n
  1. thumbnail: true 使得每个post在快速列表里,显示图标。但就是每个帖子都要设定,很麻烦。
  2. \n
  3. post 中的 toc 要设置为 true,如果需要显示目录的话。
  4. \n
\n

同时部署两个项目

\n

第一个项目使用 Github 上面默认的 Github Pages,即 username.github.io 。在站点配置文件中如下:

\n\n

第二个站点开通一个 普通的repository,添加名为gh-pages 的Branch,并将gh-pages设为默认Branch。我将第二个仓库命名为 wiki ,那第二个站点就运行在https://username.github.io/wiki`次级目录下面。

\n

站点配置文件更改如下:

\n\n

同样用 hexo d -g 部署命令发布,两个站点就都运行起来了。

\n

为了使得两个项目使用同一个笔记资源,将站点中的 source 文件夹移到项目意外,将配置文件里的 source_dir: source 改为 source_dir: ../source(这里使用了相对目录)。

\n

参考文章 (细节已经失效,但思路值得参考)

\n

站内搜索

\n
    \n
  1. 安装插件
  2. \n
\n\n
    \n
  1. 配置hexo站点主配置文件_config.yml, 添加
  2. \n
\n\n
    \n
  1. 修改next主题配置文件_config.yml,启用 local_search
  2. \n
\n\n
    \n
  1. 生成search.xml文件以及发布
  2. \n
\n\n

去除主题字样

\n

关于添加头像、标签、分类、「关于」等具体的修改,跟着参考资料2里面的步骤做就好了。最后说说如何去掉底部强力驱动及主题字样。

\n
    \n
  1. 找到 \\themes\\next\\layout_partials\\下面的footer.swig文件,打开:
  2. \n
\n\n

第一条是“由Hexo驱动” 的Hexo链接,把xml段删除,只留两个单引号’’。

\n

第二条是“主题-Next.XX”,将xml段都删掉,不留引号。

\n\n
    \n
  1. 找到这个地方\\themes\\next\\languages\\ 下面的语言文件zh-Hans.yml(以中文为例):
  2. \n
\n\n

将上面的文字改成自己想要的即可。

\n

添加评论功能

\n

Gitment

\n

**此项目已经终止!**改为Disqus,以及其它评论服务。

\n
    \n
  1. 安装功能模块。在项目的根目录:
  2. \n
\n\n
    \n
  1. 在Github申请应用。settings -> Developer Settings -> OAuth Apps
  2. \n
\n\n

申请好之后点注册,然后就可以看到两个东西ClientIDClient Secret,后面会用到。

\n
    \n
  1. 配置Gitment,打开themes/next/_config.yml:
  2. \n
\n\n

注意到这里基本上已经OK了,再看你的博客应该可以显示评论了.不过每篇博客都需要你手动初始化评论功能(如果你的历史博客很多那就一篇一篇去点吧,不过貌似有人写了批量处理脚本,没试过哈).

\n

而由于 github 中 Issueslabel 长度限制为最大 50 个字符,当 文章标题长度过长时,该label就会生成失败,而导致初始化错误,弹出 Validation Failed 的提示。

\n

通过网上的搜索,发现可以使用文章创建时的时间来代替文章标题,作为这个唯一的label标签。

\n

找到giment的配置:/themes/next/layout/_third-party/comments/gitment.swig 文件, 并找到如下部分:

\n\n

id后面的路径值修改为 ‘itfanr_blog_<!–1–>’ 就可以了。

\n

Disqus

\n

目前只开通Disqus的评论。

\n
    \n
  1. 开通Disqus账号,并添加一个点 应用。具体步骤参看Hexo搭建博客系列:(六)Hexo添加Disqus评论
  2. \n
  3. 主题配置文件(_config.yml)文件中找到以下代码,添加你Disqus设置的Website Name在shortname。
  4. \n
\n\n

更详细请参阅网上。

\n

新文章命名规则

\n

发表新文章后系统崩溃。

\n

在根目录的配置文件中找到类似的:

\n\n

将其改为由时间和题目组成:

\n\n

进阶设置

\n

显示

\n

首页文章显示预览

\n

默认设定下。首页的文章每一篇都显示全文,不方便浏览。需要到主题的配置文件里将auto_excerptenable 改为 true。而length 字节表示文章预览的长度。

\n\n

永久链接

\n

新文章的名字采用了中文(见上),中文出现在地址栏上不美观。也不利于SEO,以及增加了博文URL的层数。解决办法是给每篇文章制定链接地址。

\n
    \n
  1. 修改网站的配置文件中永久地址的设定:
  2. \n
\n\n
    \n
  1. 给每篇文章指定 urlname
  2. \n
\n\n

编译后新的地址为 http://mywiki.test/road-less-traveled-summary.html。看起来就清爽多了。

\n

图片链接

\n
    \n
  1. 开通资源文件夹,创建新文章的时候会自动建立一个与文章同名的文件夹。可以将图片或者其它资源文件放到里面(打算将思维导图放到这里)。因为自定义了文件名的方式,所以根据官方描述无效。
  2. \n
  3. 安装第三方插件hexo-asset-image
  4. \n
\n\n

在文章中图片的链,可以省略路径,直接引用图片名:

\n\n
    \n
  1. 修改插件代码
  2. \n
\n

我在使用永久链接的时候在每篇文章的实际地址都加上了.html。文章的地址显示如下

\n\n

而插件生成的图片地址如下:

\n\n

多出了 .htm 这几个字符,而实际图片的地址应该是:

\n\n

找到 node_modules/hexo-asset-imge 目录下的 index.js 文件,将以下代码中的 1 改成 5,就可以正常显示图片了。

\n\n

考虑到将来项目膨胀,应该将图片放到图床,比如七牛。

\n

站内链接

\n

导航到站内别的文章使用以下方式就可以。

\n

链接方式 [文章名](urlname.html)

\n

设定代码区的高度

\n

Hexo自身的式样暂时还没找到。其实也不太需要。如果代码不长直接显示全部就好了。太长的话不如放到$Gits$,通过限制gist的高度实现。Net主题修改 next/themes/next/source/css/_custom/custom.styl ,Wikitten主题则在文件 wikitten/themes/Wikitten/source/css/_partial/article.styl 中修改。

\n\n

添加注脚支持

\n

插件项目

\n
    \n
  1. 安装插件 npm install hexo-footnotes --save
  2. \n
  3. 项目配置文件 添加
  4. \n
\n\n

更换Markdown渲染

\n

Markdown-it-plus

\n

如果更换了这个渲染,就无需上面那个注脚插件, 因为已经支持了. 首先卸载掉旧的渲染, 然后安装新的.

\n\n

然后在项目配置文件, 添加下面文字. 更深入的设置, 参看 markdown-it-plus 项目的说明文档.

\n\n

辅助功能

\n

本地运行服务

\n

在Mac中可以用本地服务Pow运行网站,不用每次更改重启服务器hexo s

\n
    \n
  1. 安装Pow
  2. \n
\n\n
    \n
  1. 建立项目链接,myapp 是项目的名字。比如真实路径~/Project/mywiki
  2. \n
\n\n
    \n
  1. 执行完以上步骤后在浏览器打开链接 http://myapp.test/ 就能看到网站。更改内容后要执行==生成== 命令才能看到更新hexo generate or hexo g
  2. \n
  3. 不想运行,直接把项目文件夹删除就可以。
  4. \n
\n

绑定个人域名

\n
    \n
  1. 在万网买一个顶级域名,开通后添加两个域名解释
  2. \n
\n\n
    \n
  1. 在项目的根目录添加一个名为 CNAME 的文件,然后填入万网注册的域名, 这里是 goldentianya.pub 。第一次我是手动添加的。添加后进入 repository 的 setting, 往下混动到 Custom domain ,可以看到系统已经自动把用户域名加进去了。
  2. \n
  3. 将来不希望用这个域名,域名重定向后,在浏览器输入 username.github.io 后 Chrome 会一直转向 goldentianya.pub 。需要打开开发者工具,选中 disable cache ,再刷新一遍地址就好了。
  4. \n
  5. next 项目要将 CNAME 文件复制到 /themes/next/source 目录下个,编译的时候会拷贝到 public 目录。wikitten 项目不需要,域名定向以后能找到 goldentianya/wiki 站点,十分神奇。
  6. \n
\n

隐藏文章

\n

全隐藏

\n

根据插件hext-sage-posts 作者的博文9中描述,安装插件

\n\n

并将初创时的Hello-world.md 文章的Metadata中加入sage: true,文章就从网站上消失了。但在别的文章下面导航栏中,通过“下一篇”或者“上一篇”还是能被找到。被隐藏的文章其地址仍旧没有改变,只是不不出现在首页导航,和分类中而已。

\n

从首页隐藏

\n

为了不让太琐碎的文章充斥首页,但又可以在分类中找到。可以采用这种方式。

\n
    \n
  1. 在文章的Metadata部分添加关键字 notshow: true
  2. \n
  3. 找到 Hexo\\themes\\next\\layout\\index.swig 文件中以下部分:
  4. \n
\n\n

将以上代码第四行修改为

\n\n

文章加密

\n
    \n
  1. 安装插件 hexo-blog-encrypt
  2. \n
\n\n

并在站点配置文件中启用该插件:

\n\n
    \n
  1. 然后在文章的头部添加上对应的字段
  2. \n
\n\n
    \n
  • \n

    password: 是该博客加密使用的密码

    \n
  • \n
  • \n

    abstract: 是该博客的摘要,会显示在博客的列表页

    \n
  • \n
  • \n

    message: 这个是博客查看时,密码输入框上面的描述性文字

    \n
  • \n
\n

Hexo Admin

\n

安装后台管理插件 hexo-damin

\n\n

初次运行后,设置管理账户。

\n\n

访问量统计

\n

介绍文章有图

\n

原文(有代码)

\n
    \n
  1. \n

    第一步, 到Lean Cloud增添一个应用,并创建类似Counter 的类。设置成 $ 所有人可读可写 $

    \n
  2. \n
  3. \n

    在安全中心添加 Web 安全域名, 添加Blog域名,防止有人Hack我们的数据库。

    \n
  4. \n
  5. \n

    按上面的文章修改 Hexo 以及主题配置。

    \n
  6. \n
\n

在线交流

\n

使用 道客 Daovoice

\n

接入方式

\n
    \n
  1. 将下面代码粘贴在页面的 之前。
  2. \n
\n\n
    \n
  1. 调用下面的 JavaScript 与注册用户沟通
  2. \n
\n\n
    \n
  1. 调用下面的 JavaScript 与匿名访客沟通
  2. \n
\n\n

完成代码粘贴后,检测是否成功接入: Ping 一下

\n

待解决问题

\n\n

有趣插件

\n\n

\n

讲解详细的博客

\n

这个也不错

\n"}],"PostAsset":[],"PostCategory":[{"post_id":"cka1y594p00044huusb0xswfi","category_id":"cka1y594t00064huuvvjmyzwy","_id":"cka1y5955000f4huuavh4y5b7"},{"post_id":"cka1y594r00054huunm0reb46","category_id":"cka1y5953000b4huuyyfu5z4d","_id":"cka1y595a000k4huuvsrdkk3n"},{"post_id":"cka1y594x00084huu6k4ch39z","category_id":"cka1y5953000b4huuyyfu5z4d","_id":"cka1y595b000n4huupqz7l7uk"},{"post_id":"cka1y595000094huuoh5kztsj","category_id":"cka1y5959000j4huug5k1h4j7","_id":"cka1y595d000q4huujzi9cbtg"},{"post_id":"cka1y5952000a4huuo6qb7h3o","category_id":"cka1y595b000o4huul85o0vh5","_id":"cka1y595e000r4huudibumejw"},{"post_id":"cka1y596d000s4huu6s41uv14","category_id":"cka1y5953000b4huuyyfu5z4d","_id":"cka1y596h000x4huuewz15l41"},{"post_id":"cka1y596e000t4huuu6ed1frz","category_id":"cka1y596g000v4huufrvfyl7e","_id":"cka1y596j000z4huuep0zhq22"},{"post_id":"cka1y597o00124huu1wtf5iy9","category_id":"cka1y596g000v4huufrvfyl7e","_id":"cka1y597u00174huuuxk19v3o"},{"post_id":"cka1y597q00134huu98tdadd8","category_id":"cka1y596g000v4huufrvfyl7e","_id":"cka1y597v001b4huutjytdbb1"},{"post_id":"cka1y597w001d4huu070sswhu","category_id":"cka1y597u00184huu67j8phqt","_id":"cka1y598e00224huude7qq2nl"},{"post_id":"cka1y597w001d4huu070sswhu","category_id":"cka1y5987001q4huu2h0pcxc7","_id":"cka1y598g00274huuqt9x226m"},{"post_id":"cka1y597r00154huu5w41rgul","category_id":"cka1y597u00184huu67j8phqt","_id":"cka1y598h002a4huuv4qc79od"},{"post_id":"cka1y597r00154huu5w41rgul","category_id":"cka1y598b001w4huu0hxl1aoy","_id":"cka1y598j002f4huuabno4va2"},{"post_id":"cka1y597x001e4huuv3ebsp4j","category_id":"cka1y597u00184huu67j8phqt","_id":"cka1y598o002k4huubdx47g0s"},{"post_id":"cka1y597x001e4huuv3ebsp4j","category_id":"cka1y598e00234huu3y8d3uke","_id":"cka1y598q002o4huuiwbqiz7r"},{"post_id":"cka1y597z001h4huur126uc0a","category_id":"cka1y597u00184huu67j8phqt","_id":"cka1y598s002s4huu123t8obl"},{"post_id":"cka1y597z001h4huur126uc0a","category_id":"cka1y598e00234huu3y8d3uke","_id":"cka1y598t002u4huuuusrp5uf"},{"post_id":"cka1y597t00164huuyti606sh","category_id":"cka1y597u00184huu67j8phqt","_id":"cka1y598u002x4huuvof25rfi"},{"post_id":"cka1y597t00164huuyti606sh","category_id":"cka1y5987001q4huu2h0pcxc7","_id":"cka1y598w002z4huu71gvxwrk"},{"post_id":"cka1y5981001j4huuk1yz6awj","category_id":"cka1y597u00184huu67j8phqt","_id":"cka1y598w00324huuzt7qlork"},{"post_id":"cka1y5981001j4huuk1yz6awj","category_id":"cka1y598e00234huu3y8d3uke","_id":"cka1y598x00344huu11z99kzj"},{"post_id":"cka1y5983001n4huuemw79ybo","category_id":"cka1y597u00184huu67j8phqt","_id":"cka1y598y00374huu7kdrdbh8"},{"post_id":"cka1y5983001n4huuemw79ybo","category_id":"cka1y598e00234huu3y8d3uke","_id":"cka1y598z00394huuyhhgk2zf"},{"post_id":"cka1y597u001a4huuspnhsflr","category_id":"cka1y597u00184huu67j8phqt","_id":"cka1y5990003c4huusbmzttfh"},{"post_id":"cka1y597u001a4huuspnhsflr","category_id":"cka1y598e00234huu3y8d3uke","_id":"cka1y5991003e4huufvyl6wez"},{"post_id":"cka1y5986001p4huuxt1btjua","category_id":"cka1y597u00184huu67j8phqt","_id":"cka1y5991003g4huuhm5iv2oz"},{"post_id":"cka1y5986001p4huuxt1btjua","category_id":"cka1y598e00234huu3y8d3uke","_id":"cka1y5993003j4huuke8eg1wd"},{"post_id":"cka1y5988001t4huux85puqey","category_id":"cka1y597u00184huu67j8phqt","_id":"cka1y5996003m4huui5twjhmb"},{"post_id":"cka1y5988001t4huux85puqey","category_id":"cka1y598z003b4huuyf8flxmz","_id":"cka1y5997003o4huuf2s6yarp"},{"post_id":"cka1y598a001v4huunsgdb908","category_id":"cka1y597u00184huu67j8phqt","_id":"cka1y5997003r4huu1ryhxyt6"},{"post_id":"cka1y598a001v4huunsgdb908","category_id":"cka1y598z003b4huuyf8flxmz","_id":"cka1y5999003t4huutt02fr4i"},{"post_id":"cka1y598b001y4huuppnodfz2","category_id":"cka1y597u00184huu67j8phqt","_id":"cka1y5999003v4huu5g4xan28"},{"post_id":"cka1y598b001y4huuppnodfz2","category_id":"cka1y598z003b4huuyf8flxmz","_id":"cka1y599a003x4huuhgtsb5j8"},{"post_id":"cka1y598d00214huuioh2rw8e","category_id":"cka1y597u00184huu67j8phqt","_id":"cka1y599b003z4huutfrxgwz9"},{"post_id":"cka1y598d00214huuioh2rw8e","category_id":"cka1y5997003q4huuzp1l2yal","_id":"cka1y599b00414huuobbv9nmd"},{"post_id":"cka1y598f00254huufdsy7udi","category_id":"cka1y5953000b4huuyyfu5z4d","_id":"cka1y599c00424huue4frz85l"},{"post_id":"cka1y598f00254huufdsy7udi","category_id":"cka1y599a003w4huuplb2sm25","_id":"cka1y599c00444huu4y9mter5"},{"post_id":"cka1y598g00294huuytpjchoh","category_id":"cka1y5953000b4huuyyfu5z4d","_id":"cka1y599d00464huuuo9u8mcw"},{"post_id":"cka1y598g00294huuytpjchoh","category_id":"cka1y599b00404huu2nbcrdvc","_id":"cka1y599e00474huut3xryk5u"},{"post_id":"cka1y598i002d4huu06onppzf","category_id":"cka1y5953000b4huuyyfu5z4d","_id":"cka1y599e00494huu3mvwk79i"},{"post_id":"cka1y598i002d4huu06onppzf","category_id":"cka1y599a003w4huuplb2sm25","_id":"cka1y599f004a4huuvxibk9ev"},{"post_id":"cka1y598k002h4huuc3fgsb7o","category_id":"cka1y5953000b4huuyyfu5z4d","_id":"cka1y599f004c4huuj9j32oee"},{"post_id":"cka1y598k002h4huuc3fgsb7o","category_id":"cka1y599a003w4huuplb2sm25","_id":"cka1y599g004d4huuxu7lsg0c"},{"post_id":"cka1y598o002l4huuoby01avt","category_id":"cka1y5953000b4huuyyfu5z4d","_id":"cka1y599g004e4huulan4zmb7"},{"post_id":"cka1y598o002l4huuoby01avt","category_id":"cka1y599a003w4huuplb2sm25","_id":"cka1y599h004f4huufhqmspm7"},{"post_id":"cka1y598q002p4huudjt7uk0a","category_id":"cka1y5953000b4huuyyfu5z4d","_id":"cka1y599h004g4huuhwkznvlk"},{"post_id":"cka1y598q002p4huudjt7uk0a","category_id":"cka1y599a003w4huuplb2sm25","_id":"cka1y599h004h4huuzytw6gr0"},{"post_id":"cka1y599o004i4huuvxxo90p7","category_id":"cka1y597u00184huu67j8phqt","_id":"cka1y599s004n4huu9k8s6rm6"},{"post_id":"cka1y599o004i4huuvxxo90p7","category_id":"cka1y598e00234huu3y8d3uke","_id":"cka1y599s004p4huu2rwib2tg"},{"post_id":"cka1y599p004j4huucopvbcs0","category_id":"cka1y597u00184huu67j8phqt","_id":"cka1y599t004q4huulsh7ujtl"},{"post_id":"cka1y599p004j4huucopvbcs0","category_id":"cka1y5997003q4huuzp1l2yal","_id":"cka1y599t004r4huul19yoh59"},{"post_id":"cka1y599q004l4huuz9r1vgbn","category_id":"cka1y597u00184huu67j8phqt","_id":"cka1y599t004s4huupqp5vr9t"},{"post_id":"cka1y599q004l4huuz9r1vgbn","category_id":"cka1y5997003q4huuzp1l2yal","_id":"cka1y599u004t4huuo3k58azn"},{"post_id":"cka1y59a2004u4huur56brcea","category_id":"cka1y597u00184huu67j8phqt","_id":"cka1y59a7004w4huu7wd3n1pk"},{"post_id":"cka1y59a2004u4huur56brcea","category_id":"cka1y598z003b4huuyf8flxmz","_id":"cka1y59a9004x4huu0j3d865x"}],"PostTag":[{"post_id":"cka1y594p00044huusb0xswfi","tag_id":"cka1y594w00074huuttkx39vr","_id":"cka1y5955000d4huu9fo10can"},{"post_id":"cka1y5952000a4huuo6qb7h3o","tag_id":"cka1y594w00074huuttkx39vr","_id":"cka1y5955000e4huu2isd10jc"},{"post_id":"cka1y594r00054huunm0reb46","tag_id":"cka1y5954000c4huurnts5s23","_id":"cka1y5959000i4huupv2tq46c"},{"post_id":"cka1y594x00084huu6k4ch39z","tag_id":"cka1y5956000h4huujc504cfl","_id":"cka1y595b000m4huuyc267a8u"},{"post_id":"cka1y595000094huuoh5kztsj","tag_id":"cka1y595a000l4huu5t4fsi8t","_id":"cka1y595d000p4huubql3yxvf"},{"post_id":"cka1y596d000s4huu6s41uv14","tag_id":"cka1y5954000c4huurnts5s23","_id":"cka1y596g000u4huu4o7prlyh"},{"post_id":"cka1y596e000t4huuu6ed1frz","tag_id":"cka1y596h000w4huu96c70yd8","_id":"cka1y596j00104huu1x6cnerc"},{"post_id":"cka1y596e000t4huuu6ed1frz","tag_id":"cka1y596i000y4huu4e1c2vta","_id":"cka1y596k00114huu4rph259l"},{"post_id":"cka1y597r00154huu5w41rgul","tag_id":"cka1y594w00074huuttkx39vr","_id":"cka1y597u00194huux4g0d800"},{"post_id":"cka1y597o00124huu1wtf5iy9","tag_id":"cka1y597r00144huuuuhayln8","_id":"cka1y5980001i4huutd2uvz1s"},{"post_id":"cka1y597o00124huu1wtf5iy9","tag_id":"cka1y597w001c4huulh745qk4","_id":"cka1y5982001l4huu83cl2dgs"},{"post_id":"cka1y597q00134huu98tdadd8","tag_id":"cka1y597z001g4huuaqzwp1zm","_id":"cka1y5986001o4huuxpz9siof"},{"post_id":"cka1y597q00134huu98tdadd8","tag_id":"cka1y596h000w4huu96c70yd8","_id":"cka1y5987001r4huu4eq0lqut"},{"post_id":"cka1y597t00164huuyti606sh","tag_id":"cka1y5983001m4huuufmyhgoa","_id":"cka1y5989001u4huumst1bdhn"},{"post_id":"cka1y5988001t4huux85puqey","tag_id":"cka1y594w00074huuttkx39vr","_id":"cka1y598b001x4huuvtlgi297"},{"post_id":"cka1y598a001v4huunsgdb908","tag_id":"cka1y594w00074huuttkx39vr","_id":"cka1y598d00204huuqyf5kwkk"},{"post_id":"cka1y598a001v4huunsgdb908","tag_id":"cka1y5983001m4huuufmyhgoa","_id":"cka1y598f00244huu61bh68rw"},{"post_id":"cka1y597u001a4huuspnhsflr","tag_id":"cka1y5987001s4huudyci9yx0","_id":"cka1y598g00284huu6fa44eml"},{"post_id":"cka1y598b001y4huuppnodfz2","tag_id":"cka1y594w00074huuttkx39vr","_id":"cka1y598h002b4huu2q6wen8j"},{"post_id":"cka1y598d00214huuioh2rw8e","tag_id":"cka1y5987001s4huudyci9yx0","_id":"cka1y598j002g4huum7z8unxb"},{"post_id":"cka1y597w001d4huu070sswhu","tag_id":"cka1y5983001m4huuufmyhgoa","_id":"cka1y598n002i4huu4w25jlcw"},{"post_id":"cka1y597x001e4huuv3ebsp4j","tag_id":"cka1y5987001s4huudyci9yx0","_id":"cka1y598q002n4huudhcmzd8l"},{"post_id":"cka1y597z001h4huur126uc0a","tag_id":"cka1y5987001s4huudyci9yx0","_id":"cka1y598r002q4huu534ex9n3"},{"post_id":"cka1y5981001j4huuk1yz6awj","tag_id":"cka1y5987001s4huudyci9yx0","_id":"cka1y598t002v4huupck4woiq"},{"post_id":"cka1y5983001n4huuemw79ybo","tag_id":"cka1y5987001s4huudyci9yx0","_id":"cka1y598w00304huuo1c12ur3"},{"post_id":"cka1y5986001p4huuxt1btjua","tag_id":"cka1y5987001s4huudyci9yx0","_id":"cka1y598y00354huuzezeifpl"},{"post_id":"cka1y598f00254huufdsy7udi","tag_id":"cka1y598x00334huu7wbssbi7","_id":"cka1y598z003a4huuxhbpr7nd"},{"post_id":"cka1y598g00294huuytpjchoh","tag_id":"cka1y598z00384huu1rilsu1z","_id":"cka1y5991003f4huupklqu83q"},{"post_id":"cka1y598i002d4huu06onppzf","tag_id":"cka1y598x00334huu7wbssbi7","_id":"cka1y5994003k4huu5xvxb95n"},{"post_id":"cka1y598k002h4huuc3fgsb7o","tag_id":"cka1y598x00334huu7wbssbi7","_id":"cka1y5997003p4huuyeqchn46"},{"post_id":"cka1y598o002l4huuoby01avt","tag_id":"cka1y598x00334huu7wbssbi7","_id":"cka1y5999003u4huuuqsut2y0"},{"post_id":"cka1y598q002p4huudjt7uk0a","tag_id":"cka1y598x00334huu7wbssbi7","_id":"cka1y599a003y4huuwn5y4qut"},{"post_id":"cka1y599o004i4huuvxxo90p7","tag_id":"cka1y5987001s4huudyci9yx0","_id":"cka1y599q004k4huuco1uino6"},{"post_id":"cka1y599p004j4huucopvbcs0","tag_id":"cka1y5987001s4huudyci9yx0","_id":"cka1y599r004m4huukspe62yo"},{"post_id":"cka1y599q004l4huuz9r1vgbn","tag_id":"cka1y5987001s4huudyci9yx0","_id":"cka1y599s004o4huu1v1cjhvs"},{"post_id":"cka1y59a2004u4huur56brcea","tag_id":"cka1y594w00074huuttkx39vr","_id":"cka1y59a4004v4huufjih59wt"}],"Tag":[{"name":"Hexo","_id":"cka1y594w00074huuttkx39vr"},{"name":"影视","_id":"cka1y5954000c4huurnts5s23"},{"name":"历史政治","_id":"cka1y5956000h4huujc504cfl"},{"name":"工作","_id":"cka1y595a000l4huu5t4fsi8t"},{"name":"成长","_id":"cka1y596h000w4huu96c70yd8"},{"name":"经济","_id":"cka1y596i000y4huu4e1c2vta"},{"name":"哲理","_id":"cka1y597r00144huuuuhayln8"},{"name":"书籍","_id":"cka1y597w001c4huulh745qk4"},{"name":"心理","_id":"cka1y597z001g4huuaqzwp1zm"},{"name":"Mac","_id":"cka1y5983001m4huuufmyhgoa"},{"name":"工具","_id":"cka1y5987001s4huudyci9yx0"},{"name":"文学","_id":"cka1y598x00334huu7wbssbi7"},{"name":"娱乐","_id":"cka1y598z00384huu1rilsu1z"}]}} \ No newline at end of file +{"meta":{"version":1,"warehouse":"2.2.0"},"models":{"Asset":[{"_id":"themes/Wikitten/source/css/style.styl","path":"css/style.styl","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/js/insight.js","path":"js/insight.js","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/images/mobile2.png","path":"images/mobile2.png","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/js/main.js","path":"js/main.js","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/images/mobile1.png","path":"images/mobile1.png","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/css/images/favicon.ico","path":"css/images/favicon.ico","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/css/images/logo.png","path":"css/images/logo.png","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/css/images/thumb-default-small.png","path":"css/images/thumb-default-small.png","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/fonts/glyphicons-halflings-regular.woff2","path":"libs/fonts/glyphicons-halflings-regular.woff2","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/fonts/glyphicons-halflings-regular.woff","path":"libs/fonts/glyphicons-halflings-regular.woff","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/fonts/glyphicons-halflings-regular.ttf","path":"libs/fonts/glyphicons-halflings-regular.ttf","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/justified-gallery/justifiedGallery.min.css","path":"libs/justified-gallery/justifiedGallery.min.css","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/justified-gallery/jquery.justifiedGallery.min.js","path":"libs/justified-gallery/jquery.justifiedGallery.min.js","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/source-code-pro/styles.css","path":"libs/source-code-pro/styles.css","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/open-sans/styles.css","path":"libs/open-sans/styles.css","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/images/SitePreview.png","path":"images/SitePreview.png","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/uploads/road-to-asset-freedom-mindmap.html","path":"uploads/road-to-asset-freedom-mindmap.html","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/fonts/glyphicons-halflings-regular.eot","path":"libs/fonts/glyphicons-halflings-regular.eot","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/fonts/glyphicons-halflings-regular.svg","path":"libs/fonts/glyphicons-halflings-regular.svg","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/font-awesome/css/font-awesome.css","path":"libs/font-awesome/css/font-awesome.css","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/lightgallery/css/lg-fb-comment-box.css","path":"libs/lightgallery/css/lg-fb-comment-box.css","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/font-awesome/css/font-awesome.min.css","path":"libs/font-awesome/css/font-awesome.min.css","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/lightgallery/css/lg-fb-comment-box.css.map","path":"libs/lightgallery/css/lg-fb-comment-box.css.map","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/lightgallery/css/lg-fb-comment-box.min.css","path":"libs/lightgallery/css/lg-fb-comment-box.min.css","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/lightgallery/css/lg-transitions.css","path":"libs/lightgallery/css/lg-transitions.css","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/lightgallery/css/lg-transitions.css.map","path":"libs/lightgallery/css/lg-transitions.css.map","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/lightgallery/css/lg-transitions.min.css","path":"libs/lightgallery/css/lg-transitions.min.css","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/lightgallery/css/lightgallery.css","path":"libs/lightgallery/css/lightgallery.css","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/lightgallery/css/lightgallery.css.map","path":"libs/lightgallery/css/lightgallery.css.map","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/lightgallery/css/lightgallery.min.css","path":"libs/lightgallery/css/lightgallery.min.css","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/lightgallery/fonts/lg.eot","path":"libs/lightgallery/fonts/lg.eot","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/lightgallery/fonts/lg.svg","path":"libs/lightgallery/fonts/lg.svg","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/lightgallery/fonts/lg.woff","path":"libs/lightgallery/fonts/lg.woff","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/lightgallery/js/lg-autoplay.js","path":"libs/lightgallery/js/lg-autoplay.js","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/lightgallery/fonts/lg.ttf","path":"libs/lightgallery/fonts/lg.ttf","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/lightgallery/js/lg-autoplay.min.js","path":"libs/lightgallery/js/lg-autoplay.min.js","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/lightgallery/js/lg-fullscreen.js","path":"libs/lightgallery/js/lg-fullscreen.js","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/lightgallery/js/lg-fullscreen.min.js","path":"libs/lightgallery/js/lg-fullscreen.min.js","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/lightgallery/js/lg-hash.js","path":"libs/lightgallery/js/lg-hash.js","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/lightgallery/js/lg-hash.min.js","path":"libs/lightgallery/js/lg-hash.min.js","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/lightgallery/js/lg-pager.js","path":"libs/lightgallery/js/lg-pager.js","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/lightgallery/js/lg-pager.min.js","path":"libs/lightgallery/js/lg-pager.min.js","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/lightgallery/js/lg-share.js","path":"libs/lightgallery/js/lg-share.js","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/lightgallery/js/lg-share.min.js","path":"libs/lightgallery/js/lg-share.min.js","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/lightgallery/js/lg-thumbnail.js","path":"libs/lightgallery/js/lg-thumbnail.js","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/lightgallery/js/lg-thumbnail.min.js","path":"libs/lightgallery/js/lg-thumbnail.min.js","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/lightgallery/js/lg-video.js","path":"libs/lightgallery/js/lg-video.js","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/lightgallery/js/lg-video.min.js","path":"libs/lightgallery/js/lg-video.min.js","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/lightgallery/js/lg-zoom.js","path":"libs/lightgallery/js/lg-zoom.js","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/lightgallery/js/lg-zoom.min.js","path":"libs/lightgallery/js/lg-zoom.min.js","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/lightgallery/js/lightgallery.js","path":"libs/lightgallery/js/lightgallery.js","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/lightgallery/js/lightgallery.min.js","path":"libs/lightgallery/js/lightgallery.min.js","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/lightgallery/img/loading.gif","path":"libs/lightgallery/img/loading.gif","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/lightgallery/img/video-play.png","path":"libs/lightgallery/img/video-play.png","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/lightgallery/img/vimeo-play.png","path":"libs/lightgallery/img/vimeo-play.png","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/lightgallery/img/youtube-play.png","path":"libs/lightgallery/img/youtube-play.png","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/59ZRklaO5bWGqF5A9baEERJtnKITppOI_IvcXXDNrsc.woff2","path":"libs/open-sans/fonts/59ZRklaO5bWGqF5A9baEERJtnKITppOI_IvcXXDNrsc.woff2","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/K88pR3goAWT7BTt32Z01mxJtnKITppOI_IvcXXDNrsc.woff2","path":"libs/open-sans/fonts/K88pR3goAWT7BTt32Z01mxJtnKITppOI_IvcXXDNrsc.woff2","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/LWCjsQkB6EMdfHrEVqA1KRJtnKITppOI_IvcXXDNrsc.woff2","path":"libs/open-sans/fonts/LWCjsQkB6EMdfHrEVqA1KRJtnKITppOI_IvcXXDNrsc.woff2","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/MTP_ySUJH_bn48VBG8sNShWV49_lSm1NYrwo-zkhivY.woff2","path":"libs/open-sans/fonts/MTP_ySUJH_bn48VBG8sNShWV49_lSm1NYrwo-zkhivY.woff2","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/MTP_ySUJH_bn48VBG8sNSj0LW-43aMEzIO6XUTLjad8.woff2","path":"libs/open-sans/fonts/MTP_ySUJH_bn48VBG8sNSj0LW-43aMEzIO6XUTLjad8.woff2","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/MTP_ySUJH_bn48VBG8sNSpX5f-9o1vgP2EXwfjgl7AY.woff2","path":"libs/open-sans/fonts/MTP_ySUJH_bn48VBG8sNSpX5f-9o1vgP2EXwfjgl7AY.woff2","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/MTP_ySUJH_bn48VBG8sNSq-j2U0lmluP9RWlSytm3ho.woff2","path":"libs/open-sans/fonts/MTP_ySUJH_bn48VBG8sNSq-j2U0lmluP9RWlSytm3ho.woff2","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/MTP_ySUJH_bn48VBG8sNSqaRobkAwv3vxw3jMhVENGA.woff2","path":"libs/open-sans/fonts/MTP_ySUJH_bn48VBG8sNSqaRobkAwv3vxw3jMhVENGA.woff2","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/MTP_ySUJH_bn48VBG8sNSugdm0LZdjqr5-oayXSOefg.woff2","path":"libs/open-sans/fonts/MTP_ySUJH_bn48VBG8sNSugdm0LZdjqr5-oayXSOefg.woff2","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/MTP_ySUJH_bn48VBG8sNSv8zf_FOSsgRmwsS7Aa9k2w.woff2","path":"libs/open-sans/fonts/MTP_ySUJH_bn48VBG8sNSv8zf_FOSsgRmwsS7Aa9k2w.woff2","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/RjgO7rYTmqiVp7vzi-Q5URJtnKITppOI_IvcXXDNrsc.woff2","path":"libs/open-sans/fonts/RjgO7rYTmqiVp7vzi-Q5URJtnKITppOI_IvcXXDNrsc.woff2","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/cJZKeOuBrn4kERxqtaUH3VtXRa8TVwTICgirnJhmVJw.woff2","path":"libs/open-sans/fonts/cJZKeOuBrn4kERxqtaUH3VtXRa8TVwTICgirnJhmVJw.woff2","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/u-WUoqrET9fUeobQW7jkRRJtnKITppOI_IvcXXDNrsc.woff2","path":"libs/open-sans/fonts/u-WUoqrET9fUeobQW7jkRRJtnKITppOI_IvcXXDNrsc.woff2","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/xjAJXh38I15wypJXxuGMBiYE0-AqJ3nfInTTiDXDjU4.woff2","path":"libs/open-sans/fonts/xjAJXh38I15wypJXxuGMBiYE0-AqJ3nfInTTiDXDjU4.woff2","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/xjAJXh38I15wypJXxuGMBjTOQ_MqJVwkKsUn0wKzc2I.woff2","path":"libs/open-sans/fonts/xjAJXh38I15wypJXxuGMBjTOQ_MqJVwkKsUn0wKzc2I.woff2","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/xjAJXh38I15wypJXxuGMBjUj_cnvWIuuBMVgbX098Mw.woff2","path":"libs/open-sans/fonts/xjAJXh38I15wypJXxuGMBjUj_cnvWIuuBMVgbX098Mw.woff2","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/xjAJXh38I15wypJXxuGMBkbcKLIaa1LC45dFaAfauRA.woff2","path":"libs/open-sans/fonts/xjAJXh38I15wypJXxuGMBkbcKLIaa1LC45dFaAfauRA.woff2","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/xjAJXh38I15wypJXxuGMBmo_sUJ8uO4YLWRInS22T3Y.woff2","path":"libs/open-sans/fonts/xjAJXh38I15wypJXxuGMBmo_sUJ8uO4YLWRInS22T3Y.woff2","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/xjAJXh38I15wypJXxuGMBo4P5ICox8Kq3LLUNMylGO4.woff2","path":"libs/open-sans/fonts/xjAJXh38I15wypJXxuGMBo4P5ICox8Kq3LLUNMylGO4.woff2","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/xjAJXh38I15wypJXxuGMBr6up8jxqWt8HVA3mDhkV_0.woff2","path":"libs/open-sans/fonts/xjAJXh38I15wypJXxuGMBr6up8jxqWt8HVA3mDhkV_0.woff2","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/xozscpT2726on7jbcb_pAhJtnKITppOI_IvcXXDNrsc.woff2","path":"libs/open-sans/fonts/xozscpT2726on7jbcb_pAhJtnKITppOI_IvcXXDNrsc.woff2","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/source-code-pro/fonts/mrl8jkM18OlOQN8JLgasD9V_2ngZ8dMf8fLgjYEouxg.woff2","path":"libs/source-code-pro/fonts/mrl8jkM18OlOQN8JLgasD9V_2ngZ8dMf8fLgjYEouxg.woff2","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/source-code-pro/fonts/mrl8jkM18OlOQN8JLgasDy2Q8seG17bfDXYR_jUsrzg.woff2","path":"libs/source-code-pro/fonts/mrl8jkM18OlOQN8JLgasDy2Q8seG17bfDXYR_jUsrzg.woff2","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/font-awesome/fonts/fontawesome-webfont.woff","path":"libs/font-awesome/fonts/fontawesome-webfont.woff","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/font-awesome/fonts/fontawesome-webfont.woff2","path":"libs/font-awesome/fonts/fontawesome-webfont.woff2","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/font-awesome/fonts/FontAwesome.otf","path":"libs/font-awesome/fonts/FontAwesome.otf","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/font-awesome/fonts/fontawesome-webfont.eot","path":"libs/font-awesome/fonts/fontawesome-webfont.eot","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/font-awesome/fonts/fontawesome-webfont.ttf","path":"libs/font-awesome/fonts/fontawesome-webfont.ttf","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/jquery/2.1.3/jquery.min.js","path":"libs/jquery/2.1.3/jquery.min.js","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/jquery/plugins/cookie/1.4.1/jquery.cookie.js","path":"libs/jquery/plugins/cookie/1.4.1/jquery.cookie.js","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/libs/font-awesome/fonts/fontawesome-webfont.svg","path":"libs/font-awesome/fonts/fontawesome-webfont.svg","modified":0,"renderable":1},{"_id":"themes/Wikitten/source/uploads/tianya.png","path":"uploads/tianya.png","modified":0,"renderable":1}],"Cache":[{"_id":"S_Store","hash":"a9cabec0ae931e7048f423a95c704c714780b5e1","modified":1588882647870},{"_id":"themes/Wikitten/LICENSE","hash":"feadcd728a8e828cfc507b4586d7a7ab94b66fe8","modified":1563743114000},{"_id":"themes/Wikitten/.DS_Store","hash":"df2fbeb1400acda0909a32c1cf6bf492f1121e07","modified":1565719634000},{"_id":"themes/Wikitten/README.md","hash":"8c9fc9b9ebdf37c9289a4e1d72ac8aedbe23316c","modified":1563743114000},{"_id":"themes/Wikitten/README_zh-CN.md","hash":"8a4e600ff1f75007df8facf15a9c127aafec5e18","modified":1563743114000},{"_id":"themes/Wikitten/_config.yml","hash":"c9bfc67c810f7a79227daad8af59f57b6ef020b3","modified":1588912541465},{"_id":"themes/Wikitten/package.json","hash":"2b308f996333d1d9def3e536dbf302afcdd8e1f0","modified":1563743114000},{"_id":"arkeditor/file_manager_status.config","hash":"c750fd1fe3f1407005c5d2b5d7b7f9bca54970c3","modified":1564688931000},{"_id":"arkeditor/file_manager_width.config","hash":"2c427b959b7a35c68831d16645d2afde8cb67ddd","modified":1564594162000},{"_id":"rafts/.DS_Store","hash":"df2fbeb1400acda0909a32c1cf6bf492f1121e07","modified":1565728063000},{"_id":"rafts/典故-md.md","hash":"2b33e03ac046894df112a9d45da13a690f621ed2","modified":1563856606000},{"_id":"osts/.DS_Store","hash":"6f8ff578f75eaeb17eeb676dc7e41d9fe37fa6af","modified":1588882832887},{"_id":"out/.DS_Store","hash":"df2fbeb1400acda0909a32c1cf6bf492f1121e07","modified":1565728063000},{"_id":"out/index.md","hash":"282d4c506b467c746d1154f25338d16be6abbb62","modified":1563816667000},{"_id":"tegories/.DS_Store","hash":"df2fbeb1400acda0909a32c1cf6bf492f1121e07","modified":1565728063000},{"_id":"tegories/index.md","hash":"53bbe27e36d98a4a55fdce6a7fd9cac3e6671439","modified":1563766746000},{"_id":"gs/.DS_Store","hash":"df2fbeb1400acda0909a32c1cf6bf492f1121e07","modified":1565728063000},{"_id":"gs/index.md","hash":"163f9d816dac6cc50a48347bf7f93f29fa503736","modified":1563766671000},{"_id":"themes/Wikitten/_scaffolds/embed.md","hash":"0830c3a5b134fbd21a6ddeda141a4de8345cabb1","modified":1563743114000},{"_id":"themes/Wikitten/_scaffolds/post.md","hash":"af892af6f7dafdd617c5aa17ee91e9e445d20fa4","modified":1563743114000},{"_id":"themes/Wikitten/languages/en.yml","hash":"ade241498b85503a8953a1deca963222f47067a7","modified":1563743114000},{"_id":"themes/Wikitten/languages/es.yml","hash":"d7432219be5bee4cb569331378ade61b749688e0","modified":1563743114000},{"_id":"themes/Wikitten/languages/fr.yml","hash":"cb3e597cbec7e8f458858c457bafd1f3a225083d","modified":1563743114000},{"_id":"themes/Wikitten/languages/id.yml","hash":"70ec9ab2ac04cf882e81377ca5ad15bf8adceca8","modified":1563743114000},{"_id":"themes/Wikitten/languages/ja.yml","hash":"ff972961e5f468a695d80d21b62c3e9032cdf561","modified":1563743114000},{"_id":"themes/Wikitten/languages/ko.yml","hash":"7c4ad4577dc0577ad2ca1c0410507f5e5fadf530","modified":1563743114000},{"_id":"themes/Wikitten/languages/pt-BR.yml","hash":"3c5d5293575593705b9a2dfa9d97b017eb4bc8c3","modified":1563743114000},{"_id":"themes/Wikitten/_source/.DS_Store","hash":"df2fbeb1400acda0909a32c1cf6bf492f1121e07","modified":1588912619614},{"_id":"themes/Wikitten/languages/ru.yml","hash":"d1aab2b0c939d0c6020f881d664b660a01ee7327","modified":1563743114000},{"_id":"themes/Wikitten/languages/tr.yml","hash":"8b7eb6aec264db50dbabea89f680acca256f4cd1","modified":1563743114000},{"_id":"themes/Wikitten/languages/zh-Hans.yml","hash":"3dc8ec524805afd090438be717908750da439204","modified":1563743114000},{"_id":"themes/Wikitten/languages/zh-TW.yml","hash":"d8d96a0a17c20af11919ce036e87379a6b163db9","modified":1563743114000},{"_id":"themes/Wikitten/layout/archive.ejs","hash":"34180dcc26b8fcc59f8644ce506aadf7db5f07e5","modified":1563743114000},{"_id":"themes/Wikitten/layout/categories.ejs","hash":"aa95629b770cff8cca9d663aeb6b17928f070de5","modified":1563743114000},{"_id":"themes/Wikitten/layout/category.ejs","hash":"1d407f9176db84e83062c52ad4755aaea9e74401","modified":1563743114000},{"_id":"themes/Wikitten/layout/embed.ejs","hash":"9e4e14d7adf20225e26d3943bdae8d08cf2d0d8b","modified":1563743114000},{"_id":"themes/Wikitten/layout/page.ejs","hash":"50170783bac99946ae8af483920568de9b2d9801","modified":1563743114000},{"_id":"themes/Wikitten/layout/index.ejs","hash":"abda4978fe246ec7f2a240e591d5caaea6de327c","modified":1588913059866},{"_id":"themes/Wikitten/layout/layout.ejs","hash":"b81b084839a6944c99cceedf743422aea4d856fa","modified":1589039520929},{"_id":"themes/Wikitten/layout/post.ejs","hash":"50170783bac99946ae8af483920568de9b2d9801","modified":1563743114000},{"_id":"themes/Wikitten/layout/tag.ejs","hash":"f6c220d4e5c231028bc71ddc11aec97d7b5a9943","modified":1563743114000},{"_id":"themes/Wikitten/layout/tags.ejs","hash":"b0fcea68d7c11e5899bf0375d80997685111653f","modified":1563743114000},{"_id":"themes/Wikitten/scripts/fold.js","hash":"2c8cfa7dac0b2665db9c148882f18a11d7d78957","modified":1563907083000},{"_id":"themes/Wikitten/scripts/.DS_Store","hash":"df2fbeb1400acda0909a32c1cf6bf492f1121e07","modified":1563908768000},{"_id":"themes/Wikitten/scripts/meta.js","hash":"1993754a2f3dffa283fa0538eb8f056385b69ad4","modified":1563743114000},{"_id":"themes/Wikitten/scripts/tags.js","hash":"259bc8f40e9f8eb457c1bdc99744b34d1e8602e8","modified":1563907013000},{"_id":"themes/Wikitten/scripts/thumbnail.js","hash":"e667a611f9baac270281b765832020d50bf8fb7f","modified":1563743114000},{"_id":"themes/Wikitten/source/.DS_Store","hash":"df2fbeb1400acda0909a32c1cf6bf492f1121e07","modified":1581539379000},{"_id":"osts/.markeditor/file_manager_status.config","hash":"26ccad3385b35b5dd4b33232ba36d0da4f190c00","modified":1588848849111},{"_id":"osts/IT/.DS_Store","hash":"f31c5797d3b40ff7f36965331428bf17084dc289","modified":1565813210000},{"_id":"osts/.markeditor/file_manager_width.config","hash":"2c427b959b7a35c68831d16645d2afde8cb67ddd","modified":1588848807781},{"_id":"osts/常用文件/.DS_Store","hash":"df2fbeb1400acda0909a32c1cf6bf492f1121e07","modified":1565728063000},{"_id":"osts/常用文件/Hexo日常管理.md","hash":"48184f3ce76a6679a525e3349ec30ae4608ac5ec","modified":1564718092000},{"_id":"osts/摘录/.DS_Store","hash":"df2fbeb1400acda0909a32c1cf6bf492f1121e07","modified":1565728063000},{"_id":"osts/摘录/《驴得水》影评.md","hash":"dcd7ea1a8643fe06ff14022c5d5577ccf810a33c","modified":1565905736000},{"_id":"osts/摘录/典故.md","hash":"bd9982cfe6eea388c4f99b79d479939974cf0d1e","modified":1564545095000},{"_id":"osts/摘录/爱乐之城——影评.md","hash":"dd74130851f4565e9a4ae2d8b1218e4b74fb9672","modified":1565764310000},{"_id":"osts/文档/RZF-Organisation.md","hash":"37c4c97661f0ac8203e1b0c4f7f1df70dfe2c4a1","modified":1566463161000},{"_id":"osts/读书笔记/.DS_Store","hash":"df2fbeb1400acda0909a32c1cf6bf492f1121e07","modified":1565728063000},{"_id":"osts/读书笔记/《少有人走的路》笔记.md","hash":"5a6ce1a62ddca691e7aa49658a6a1ea8cd8215e3","modified":1564632258000},{"_id":"osts/读书笔记/斯多葛主义手册.md","hash":"a56ce651794cbedea74361202e9f1868a0b10f61","modified":1565764288000},{"_id":"osts/读书笔记/财富自由之路-李笑来.md","hash":"0f1bb3b57fb1b23e38984f0343c31431c0592ab8","modified":1565764569000},{"_id":"osts/随笔/.DS_Store","hash":"df2fbeb1400acda0909a32c1cf6bf492f1121e07","modified":1565728063000},{"_id":"osts/随笔/hello-world.md","hash":"5c562e2b6c5184f490c0ea1b6d820fe50579406b","modified":1564545095000},{"_id":"themes/Wikitten/_source/about/index.md","hash":"3b3e8701e1e68d422641c456dc808bb4a665720c","modified":1563745735000},{"_id":"themes/Wikitten/_source/categories/index.md","hash":"994c1641a9b4b9ef0c604c197dffb6b0ce0513a0","modified":1563745700000},{"_id":"themes/Wikitten/_source/tags/index.md","hash":"b5cea9db4620416c871ea1b14b7eddf23b330779","modified":1563745653000},{"_id":"themes/Wikitten/layout/comment/counter.ejs","hash":"e109d3256b004b027d029bd5bd67feeb72dc5388","modified":1563743114000},{"_id":"themes/Wikitten/layout/comment/disqus.ejs","hash":"1b32a90f400dc580f4b8298de75b94429ca6de68","modified":1563743114000},{"_id":"themes/Wikitten/layout/comment/duoshuo.ejs","hash":"ce46d7410a99b57704da32e9d09071cef6c9fa93","modified":1563743114000},{"_id":"themes/Wikitten/layout/comment/index.ejs","hash":"f0f00cce7a5c37f00dbc4acf49529bdd6a6bdc5d","modified":1563743114000},{"_id":"themes/Wikitten/layout/comment/scripts.ejs","hash":"8a9a20f72ba0923afa776396fb67d8c5d446a666","modified":1563743114000},{"_id":"themes/Wikitten/layout/comment/youyan.ejs","hash":"6fe807992832939caf6c3e7651d052df9520d88e","modified":1563743114000},{"_id":"themes/Wikitten/layout/common/article.ejs","hash":"595a086a42a156dd44d30ee7f9e7189ca370bcf1","modified":1563743114000},{"_id":"themes/Wikitten/layout/common/footer.ejs","hash":"2e5c72b780ac21462976108aec769a215d2f1f45","modified":1563812254000},{"_id":"themes/Wikitten/layout/common/head.ejs","hash":"5f2df8713f0ef723b3bfc79ae580fe8707ea2036","modified":1563743114000},{"_id":"themes/Wikitten/layout/common/header.ejs","hash":"738c6a923b2a6de6a81c4892c8a47e03d8b34f88","modified":1563743114000},{"_id":"themes/Wikitten/layout/common/iframe.ejs","hash":"c3a8e71e1660d58b6ed106a045c6829e77e65881","modified":1563743114000},{"_id":"themes/Wikitten/layout/common/profile.ejs","hash":"0d5a9622d490652599e3ba3e4077a7d6bb2eb38e","modified":1563743114000},{"_id":"themes/Wikitten/layout/common/scripts.ejs","hash":"c0a1a9e53f89440c42c325d5bd8c7234652c8937","modified":1563743114000},{"_id":"themes/Wikitten/layout/common/sidebar.ejs","hash":"6e80fa52d23c9c39bfa357a1e00c26fc8b851b82","modified":1563743114000},{"_id":"themes/Wikitten/layout/common/thumbnail.ejs","hash":"1b70f8a98cd8650b159bda858dbee38dbdb7f0c5","modified":1563743114000},{"_id":"themes/Wikitten/layout/common/timeline.ejs","hash":"6420e34e0332c9b6670011519f341340db989343","modified":1563743114000},{"_id":"themes/Wikitten/layout/plugin/google-analytics.ejs","hash":"349f08b6521a16e79046b1f94f04317ac74f556e","modified":1563743114000},{"_id":"themes/Wikitten/layout/plugin/scripts.ejs","hash":"6e410c120dabac0dccbd8b0c312f261c9566cacb","modified":1563743114000},{"_id":"themes/Wikitten/layout/plugin/baidu-analytics.ejs","hash":"6a7bee18e666e627e62541a5e30906f87ba1bfe8","modified":1563743114000},{"_id":"themes/Wikitten/layout/plugin/mathjax.ejs","hash":"aa644e12c338cd595ae53c37c89b974fa4364966","modified":1588882392716},{"_id":"themes/Wikitten/layout/search/baidu.ejs","hash":"3e603a702d20c53fd3bcbeb570a16a86d54781ce","modified":1563743114000},{"_id":"themes/Wikitten/layout/search/index-mobile.ejs","hash":"50a727ac1dfe3073eb6fa6699ba01e66f4ac41c0","modified":1563743114000},{"_id":"themes/Wikitten/layout/search/index.ejs","hash":"24935e32e61d4706454b174ea3bed0726ae7fb34","modified":1563743114000},{"_id":"themes/Wikitten/layout/search/insight.ejs","hash":"130fe3d33ac71da0b50f7fee6a87979f30938a1b","modified":1563743114000},{"_id":"themes/Wikitten/layout/search/swiftype.ejs","hash":"379e66d2c13526e72e4120c443f95fccf4edef71","modified":1563743114000},{"_id":"themes/Wikitten/layout/share/addtoany.ejs","hash":"ac180c4c84b73a04d61b17e7dc18c257e20bf59f","modified":1563743114000},{"_id":"themes/Wikitten/layout/share/bdshare.ejs","hash":"a1e772c5a6f174d585b0c1e574058f75dc8e2898","modified":1563743114000},{"_id":"themes/Wikitten/layout/share/default.ejs","hash":"ebfb919dc525b3ed61a6a5ee05ee71410eedc541","modified":1563743114000},{"_id":"themes/Wikitten/layout/share/index.ejs","hash":"2a2c0095b95b11e5692bd8ad6a2337aa644189a2","modified":1563743114000},{"_id":"themes/Wikitten/layout/share/jiathis.ejs","hash":"21ebaa51e828cba2cefbeeaccb01514643565755","modified":1563743114000},{"_id":"themes/Wikitten/layout/widget/archive.ejs","hash":"91a4675876990c12bd252f00e13894e0e7e5e50a","modified":1563743114000},{"_id":"themes/Wikitten/layout/widget/category.ejs","hash":"d09317d5e328a9c6ff8fded93604ebe04764cc4c","modified":1563743114000},{"_id":"themes/Wikitten/layout/widget/links.ejs","hash":"0f58cafed5156488f550df6d560814f835a46854","modified":1563743114000},{"_id":"themes/Wikitten/layout/widget/recent_posts.ejs","hash":"dc83051ae67cfae0db0a6d9790c923ff2883ee25","modified":1563743114000},{"_id":"themes/Wikitten/layout/widget/tag.ejs","hash":"5d70b1bf3b1fc977135e458f9a50cb65cff91f17","modified":1563743114000},{"_id":"themes/Wikitten/layout/widget/tagcloud.ejs","hash":"73638a7c91c6d6433e766b35199508719bf27d19","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_extend.styl","hash":"9a5c72663c0da1b32ecb6a75773a5ccfb8c467ca","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_variables.styl","hash":"2eba1250b39115da9f32e8a70d271e04186419c0","modified":1563743114000},{"_id":"themes/Wikitten/source/css/style.styl","hash":"d37d6c7754805c60564c0d9a50b7b058e7f830c9","modified":1563743114000},{"_id":"themes/Wikitten/source/js/insight.js","hash":"c9dfd20ae82a446facad01439b7bb75332e3705b","modified":1563743114000},{"_id":"themes/Wikitten/source/images/mobile2.png","hash":"ba9a7a5464369c4272f6345ef879b5d1c2449de1","modified":1563743114000},{"_id":"themes/Wikitten/source/js/main.js","hash":"d1ab55b8f28037dab5512c40d33553fac966dc39","modified":1563908857000},{"_id":"themes/Wikitten/source/uploads/.DS_Store","hash":"df2fbeb1400acda0909a32c1cf6bf492f1121e07","modified":1563652057000},{"_id":"themes/Wikitten/source/images/mobile1.png","hash":"db83e3ffbf60ff88443cd3b9d1c23666005e88f0","modified":1563743114000},{"_id":"osts/IT/Code/Javascript技术摘要.md","hash":"e949fc3ccd48cfba5e3064c7b39ed5f523553d86","modified":1568660025000},{"_id":"osts/IT/Mac/.DS_Store","hash":"df2fbeb1400acda0909a32c1cf6bf492f1121e07","modified":1588882793782},{"_id":"osts/IT/Mac/Mac使用标签.md","hash":"c28b4fa4701f08fcfe5942ec8f151d7cfd2f8dad","modified":1564545094000},{"_id":"osts/IT/Tools/Gitbook攻略.md","hash":"c78d9b403444239f353b6a4a6ce0f97e6ad0fcd7","modified":1565862378000},{"_id":"osts/IT/Mac/Mac备忘录.md","hash":"5d7fb8ad7a1a59b6dd65df8a6eae0d8cb7b18fd5","modified":1588836517649},{"_id":"osts/IT/Tools/Ubuntu重设root用户密码.md","hash":"b7323a3ac81d57b3c489d97c7da56a991883089f","modified":1565764467000},{"_id":"osts/IT/Tools/使用Github维护知识库.md","hash":"27bf57527ac1d9061b1733540ac9f0b383a8a35f","modified":1565862053000},{"_id":"osts/IT/Tools/坚果云有关.md","hash":"1a966cbc37318b34551bf17be4bccfc16761fa7f","modified":1565820630000},{"_id":"osts/IT/Tools/编辑器工具使用技巧汇总.md","hash":"8103dd1e47e61523c797cf86e82bb26517f54b12","modified":1567357907000},{"_id":"osts/IT/Tools/配置服务器端MySQL.md","hash":"d44b85906db5816259dc4b2128dcac8a0766b447","modified":1565788245000},{"_id":"osts/IT/Web/Next主题添加内容折叠.md","hash":"0c381c884e0c77af522fdbf958536f2c217ceb1b","modified":1564545094000},{"_id":"osts/IT/Web/同步Hexo文章与Mac上原笔记的分类和标签.md","hash":"3af3acc8ed642c8c74ad89b87ee0e98bf0db9865","modified":1564837106000},{"_id":"osts/IT/Web/如何系统化管理Hexo博客.md","hash":"06aeeeb674ebf91cc550732fd7c5f5f30413e791","modified":1565905917000},{"_id":"osts/IT/Tools/有用的shell命令.md","hash":"1e3bffca5cac009d0f91cbd6bb96206076e50cae","modified":1565788356000},{"_id":"osts/IT/skill/用Typescript编写JS函数库.md","hash":"b189a07241dcd4bc6388fb40f92d1ec9b9835669","modified":1566646240000},{"_id":"osts/IT/Web/搭建Hexo博客的流水账.md","hash":"2bc4bf601a7c03ca17acf56806bd8aaf1b2e6f5c","modified":1565865865000},{"_id":"osts/IT/skill/还在用七牛.md","hash":"ee7b98bee940ef09c06ffcdc967b41af8d0752b1","modified":1565852093000},{"_id":"osts/摘录/片段/佛偈集合.md","hash":"fcc94a0d1fbabbd9ff5cc9a607bc07dec6b9fb8b","modified":1565905574000},{"_id":"osts/摘录/片段/名人语录.md","hash":"3c9d34d4393d3276a3ab8ad82ccabc6b3155f39f","modified":1564545095000},{"_id":"osts/摘录/娱乐/搞笑段子.md","hash":"a13e48400bba8b3427b7ac080073ec19fa20bc93","modified":1564545095000},{"_id":"osts/摘录/片段/简短书摘.md","hash":"a2586fd508f831d1631fbc0925c39288ffd23692","modified":1564545095000},{"_id":"osts/IT/skill/MathJax用于易学领域.md","hash":"a199fc359afe19f5ec89c2069defd27990b742f9","modified":1588930688489},{"_id":"osts/摘录/片段/零散句子.md","hash":"c6100208f88c30d1910c03d472cc96e53320c996","modified":1564942528000},{"_id":"osts/摘录/片段/缠中说禅.md","hash":"57bc98bc30aff6804eebbe9b5300af1f673973a3","modified":1564545095000},{"_id":"themes/Wikitten/layout/common/post/banner.ejs","hash":"47ced3f03525698c79c6b1c07b48383fb6c496b2","modified":1563743114000},{"_id":"themes/Wikitten/layout/common/post/category.ejs","hash":"75c9dda2e7ec041943855ca163a6b1c4c8b4f260","modified":1563743114000},{"_id":"themes/Wikitten/layout/common/post/date.ejs","hash":"45cb0bcad461036cdd1fe2e3fbb5f2f19940025c","modified":1563743114000},{"_id":"themes/Wikitten/layout/common/post/gallery.ejs","hash":"659f019761116313169148ec61773e7b84abb739","modified":1563743114000},{"_id":"themes/Wikitten/layout/common/post/nav.ejs","hash":"d7cd611e642327f33dff3963ef869c2b46824a11","modified":1563743114000},{"_id":"themes/Wikitten/layout/common/post/tag.ejs","hash":"2e966216256321aa0c76fe1b9be689601c76ef31","modified":1563743114000},{"_id":"themes/Wikitten/layout/common/post/title.ejs","hash":"669ddb46fefa100856588351a7a2d30ad996b755","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/agate.styl","hash":"601eb70448a16b918df132f6fc41e891ae053653","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/androidstudio.styl","hash":"65d09f1b0e81c6a182f549fd3de51e59823c97ae","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/arduino-light.styl","hash":"15e8572585cd708221c513dea4bdd89d8fe56c10","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/arta.styl","hash":"1a5accc115f41d1b669ed708ac6a29abac876599","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/ascetic.styl","hash":"32cff3bef6fac3760fe78f203096477052a90552","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/atelier-cave-dark.styl","hash":"bc647b2c1d971d7cc947aa1ed66e9fd115261921","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/atelier-cave-light.styl","hash":"a5be0744a7ecf4a08f600ade4cfd555afc67bc15","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/atelier-dune-dark.styl","hash":"df50a85a4b14c7ca6e825d665594b91229d0e460","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/atelier-dune-light.styl","hash":"931435fbc6f974e8ce9e32722680035d248a9dc1","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/atelier-estuary-dark.styl","hash":"d84382bc8298f96730757391d3e761b7e640f406","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/atelier-estuary-light.styl","hash":"344276ca9b27e51d4c907f76afe5d13cf8e60bdf","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/atelier-forest-dark.styl","hash":"57c154c6045a038dc7df0a25927853e10bf48c4a","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/atelier-forest-light.styl","hash":"95228d9f2102fad425536aac44b80b2cba1f5950","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/atelier-heath-dark.styl","hash":"b0cf13b2233e7bc38342032d2d7296591a4c2bcf","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/atelier-lakeside-dark.styl","hash":"bb0a8c4ad0dd8e3e7de7122ddf268fc42aa94acb","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/atelier-lakeside-light.styl","hash":"2c54cb9bdb259ae3b5b29f63ac2469ed34b08578","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/atelier-heath-light.styl","hash":"8c8c2e445abef85273be966d59770e9ced6aac21","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/atelier-plateau-dark.styl","hash":"09c64f1a7052aec9070c36c0431df25216afaea1","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/atelier-plateau-light.styl","hash":"d1a05fdd1ededc9063d181ab25bad55a164aeb4a","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/atelier-savanna-dark.styl","hash":"a16c919a1ccf2f845488078fb341381bec46b1f3","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/atelier-savanna-light.styl","hash":"f8244c93711c7cb59dd79d2df966806b30d171ea","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/atelier-seaside-dark.styl","hash":"ce233a101daea7124cbfcd34add43ccfe2e1e1c7","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/atelier-seaside-light.styl","hash":"0597342da6e2d0c5bdcc7d42dabb07322b1a4177","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/atelier-sulphurpool-dark.styl","hash":"414b0cfc142f70afe359c16450b651e28bf7325a","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/atelier-sulphurpool-light.styl","hash":"efa52713efc468abeeb2b9299704371583b857de","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/brown-paper.styl","hash":"c2326ba20a5020a66ca7895258d18833327d4334","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/brown-papersq.png","hash":"3a1332ede3a75a3d24f60b6ed69035b72da5e182","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/color-brewer.styl","hash":"2a439d6214430e2f45dd4939b4dfe1fe1a20aa0f","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/dark.styl","hash":"71ce56d311cc2f3a605f6e2c495ccd7236878404","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/codepen-embed.styl","hash":"f4dcc84d8e39f9831a5efe80e51923fc3054feb0","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/docco.styl","hash":"b1c176378bb275f2e8caa759f36294e42d614bf1","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/far.styl","hash":"d9928010ffe71e80b97a5afcba1a4975efdd7372","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/darkula.styl","hash":"ad0d5728d21645039c9f199e7a56814170ed3bab","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/foundation.styl","hash":"bf8ddc94b4ad995b8b8805b5a4cf95004553fdac","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/github-gist.styl","hash":"48211a03d33e7f7ada0b261162bea06676155a71","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/github.styl","hash":"3336aeba324c6d34a6fd41fef9b47bc598f7064c","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/googlecode.styl","hash":"bda816beee7b439814b514e6869dc678822be1bc","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/grayscale.styl","hash":"bf37d8b8d1e602126c51526f0cc28807440228ed","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/highlightjs.styl","hash":"0e198b7a59191c7a39b641a4ddd22c948edb9358","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/hopscotch.styl","hash":"b374c6550b89b4751aedc8fbc3cf98d95bd70ead","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/hybrid.styl","hash":"ea8d7ddc258b073308746385f5cb85aabb8bfb83","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/idea.styl","hash":"a02967cb51c16a34e0ee895d33ded2b823d35b21","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/index.styl","hash":"002d5596f6379cc87dbd43d9145bc764aa666be1","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/ir-black.styl","hash":"693078bbd72a2091ed30f506cc55949600b717af","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/kimbie.dark.styl","hash":"45dbb168f22d739d0109745d2decd66b5f94e786","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/kimbie.light.styl","hash":"61f8baed25be05288c8604d5070afbcd9f183f49","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/magula.styl","hash":"16d323f989b1420a0f72ef989242ece9bf17a456","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/mono-blue.styl","hash":"4c89a6ae29de67c0700585af82a60607e85df928","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/monokai-sublime.styl","hash":"25aa2fc1dbe38593e7c7ebe525438a39574d9935","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/monokai.styl","hash":"5a4fe9f957fd7a368c21b62a818403db4270452f","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/obsidian.styl","hash":"55572bbcfee1de6c31ac54681bb00336f5ae826d","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/paraiso-dark.styl","hash":"f1537bd868579fa018ecdbfd2eb922dcf3ba2cac","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/paraiso-light.styl","hash":"d224d1df0eb3395d9eea1344cee945c228af2911","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/pojoaque.jpg","hash":"c5fe6533b88b21f8d90d3d03954c6b29baa67791","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/pojoaque.styl","hash":"77dae9dc41945359d17fe84dbd317f1b40b2ee33","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/railscasts.styl","hash":"acd620f8bb7ff0e3fe5f9a22b4433ceef93a05e6","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/rainbow.styl","hash":"ce73b858fc0aba0e57ef9fb136c083082746bc1d","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/school-book.png","hash":"711ec983c874e093bb89eb77afcbdf6741fa61ee","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/school-book.styl","hash":"d43560fe519a931ce6da7d57416d7aa148441b83","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/solarized-dark.styl","hash":"702b9299a48c90124e3ac1d45f1591042f2beccc","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/solarized-light.styl","hash":"aa0dd3fd25c464183b59c5575c9bee8756b397f2","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/sunburst.styl","hash":"a0b5b5129547a23865d400cfa562ea0ac1ee3958","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/tomorrow-night-blue.styl","hash":"8b3087d4422be6eb800935a22eb11e035341c4ba","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/tomorrow-night-bright.styl","hash":"0ac6af6ecb446b5b60d6226748e4a6532db34f57","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/tomorrow-night-eighties.styl","hash":"fa57b3bb7857a160fc856dbe319b31e30cc5d771","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/tomorrow-night.styl","hash":"19b3080d4b066b40d50d7e7f297472482b5801fd","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/tomorrow.styl","hash":"15779cf6846725c7c35fc56cac39047d7e0aec1c","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/vs.styl","hash":"959a746f4b37aacb5d1d6ff1d57e0c045289d75d","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/xcode.styl","hash":"5e8532ae8366dcf6a4ef5e4813dc3d42ab3d0a50","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_highlight/zenburn.styl","hash":"fc5ec840435dad80964d04519d3f882ddc03746a","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_partial/archive.styl","hash":"146b5a86d6f602232d86e246ea20620ec923cccc","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_partial/article.styl","hash":"55392727ed6a4cc57dca7ed88ae8364d441e65e3","modified":1564810565000},{"_id":"themes/Wikitten/source/css/_partial/comment.styl","hash":"784646796184d4f27918c22395288a2fafbf9554","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_partial/footer.styl","hash":"484776654e4c1691dc844e6e93786a08855c1c99","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_partial/header.styl","hash":"154fcfe17c4a9833903b3a91efb1ddf315e7fcba","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_partial/insight.styl","hash":"d3195723c373a68a05b76d430f8aeb2d2dd1957f","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_partial/profile.styl","hash":"2ecc48d48ad8769556036f19f2769c84c428cbc6","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_partial/sidebar.styl","hash":"4a11aace0de3aeafdd88caef7cd238543ce1cd95","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_util/grid.styl","hash":"93fb6f1e2f40cd7d88ad0d56dd73d3f9a7bc853e","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_partial/timeline.styl","hash":"4ea679287d49f91634dd32ad812746cccc1e6281","modified":1563743114000},{"_id":"themes/Wikitten/source/css/_util/mixin.styl","hash":"c8e1ddfc0fe9108bab592c7a73b73ce9344991fd","modified":1563743114000},{"_id":"themes/Wikitten/source/css/images/favicon.ico","hash":"b37ac89616b9e4c01a35991af59fe6b63e41a48e","modified":1563743114000},{"_id":"themes/Wikitten/source/css/images/logo.png","hash":"8c61e1ec0b7c7200045d7795bac097fce475ef16","modified":1563743114000},{"_id":"themes/Wikitten/source/css/images/thumb-default-small.png","hash":"e8403b97ed9251f9f5207765b0ce796c5000b4ba","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/fonts/glyphicons-halflings-regular.woff2","hash":"ca35b697d99cae4d1b60f2d60fcd37771987eb07","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/fonts/glyphicons-halflings-regular.woff","hash":"278e49a86e634da6f2a02f3b47dd9d2a8f26210f","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/fonts/glyphicons-halflings-regular.ttf","hash":"44bc1850f570972267b169ae18f1cb06b611ffa2","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/justified-gallery/justifiedGallery.min.css","hash":"13fbcba5e97aa88b748d94d3efc4718475279907","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/justified-gallery/jquery.justifiedGallery.min.js","hash":"b2683e7a872bc109b1756a65188a37cef7d0bd5c","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/source-code-pro/styles.css","hash":"93c308012738728f906cd4c5cfdb34189e0c712b","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/open-sans/styles.css","hash":"5ca6e111046232bde112d33201a60532aee7d3c4","modified":1563743114000},{"_id":"themes/Wikitten/source/images/SitePreview.png","hash":"c37c32696828492d6a8a4dfb0f84af98f5fb1306","modified":1563743114000},{"_id":"themes/Wikitten/source/uploads/road-to-asset-freedom-mindmap.html","hash":"eed342d1dd1cac1d8635292caeac2ed90f64cc70","modified":1563735219000},{"_id":"themes/Wikitten/source/libs/fonts/glyphicons-halflings-regular.eot","hash":"86b6f62b7853e67d3e635f6512a5a5efc58ea3c3","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/fonts/glyphicons-halflings-regular.svg","hash":"de51a8494180a6db074af2dee2383f0a363c5b08","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/font-awesome/css/font-awesome.css","hash":"b5020c3860669185ba3f316fa7332cdf5c06f393","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/lightgallery/css/lg-fb-comment-box.css","hash":"844ce27b8488968bccb3e50bb49184ba2aae0625","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/font-awesome/css/font-awesome.min.css","hash":"7cd5a3384333f95c3d37d9488ad82cd6c4b03761","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/lightgallery/css/lg-fb-comment-box.css.map","hash":"51e9df39edf0faa3f38c1bab0c1fa6c922b9edcb","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/lightgallery/css/lg-fb-comment-box.min.css","hash":"05830fadb8454f39dcc98c8686eb4d5c24b71fc0","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/lightgallery/css/lg-transitions.css","hash":"7871c28498d74451d6aa438c8d3a1817810a1e19","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/lightgallery/css/lg-transitions.css.map","hash":"50c3348638b4d82fa08a449c690e8d2bb593005d","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/lightgallery/css/lg-transitions.min.css","hash":"5c22e2073a4c96d6212c72135391b599e8d1359f","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/lightgallery/css/lightgallery.css","hash":"bef55316a32e512d5a8940e5d0bfe8bf7a9c5c61","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/lightgallery/css/lightgallery.css.map","hash":"3175b4107078674d25798979f7666f4daf31e624","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/lightgallery/css/lightgallery.min.css","hash":"c9a2e19c932b56f4a2ce30c98910d10b74edb38a","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/lightgallery/fonts/lg.eot","hash":"54caf05a81e33d7bf04f2e420736ce6f1de5f936","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/lightgallery/fonts/lg.svg","hash":"9a732790adc004b22022cc60fd5f77ec4c8e3e5a","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/lightgallery/fonts/lg.woff","hash":"3048de344dd5cad4624e0127e58eaae4b576f574","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/lightgallery/js/lg-autoplay.js","hash":"426bb78b93acfc39d533ea2bab1cec8dc289cf24","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/lightgallery/fonts/lg.ttf","hash":"f6421c0c397311ae09f9257aa58bcd5e9720f493","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/lightgallery/js/lg-autoplay.min.js","hash":"d845741bcaf961579622880eb2a445257efad1ac","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/lightgallery/js/lg-fullscreen.js","hash":"65c47ac65362854ba44b00a010bb01e3630209d8","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/lightgallery/js/lg-fullscreen.min.js","hash":"b6b9e4022700b7faf2a5a175ba44a3bd938fdd20","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/lightgallery/js/lg-hash.js","hash":"15d16516c5642d3de1566ff8fc9160136ccaa405","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/lightgallery/js/lg-hash.min.js","hash":"43f1e1e720ab0e241c19b83aa26bd6848eab8edc","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/lightgallery/js/lg-pager.js","hash":"8092c692b244bb26343eb03b91bd97deb9dafc9c","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/lightgallery/js/lg-pager.min.js","hash":"25caa6ff65b1c6dee09941e795ae2633bdbab211","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/lightgallery/js/lg-share.js","hash":"b7fb5f6474911060a351b0a6fe9dbb9ac3fb22aa","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/lightgallery/js/lg-share.min.js","hash":"39c615f07c5d3aaa65a2c3068a30fdd6dd5c372d","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/lightgallery/js/lg-thumbnail.js","hash":"3a6476b6df1d2bef4a21861a78776282a7a11ef1","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/lightgallery/js/lg-thumbnail.min.js","hash":"18dd7d2909d1bfd6852f031d03e774b4428c512b","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/lightgallery/js/lg-video.js","hash":"4f99b598f6bb18de9eca8c45c5b4373a03962367","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/lightgallery/js/lg-video.min.js","hash":"032c001ab045a69856f9c3ed4a2a3bf12a8e310f","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/lightgallery/js/lg-zoom.js","hash":"a758e2c8fcf710f9ff761da0eea0ab9321f3484d","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/lightgallery/js/lg-zoom.min.js","hash":"15b49f9728439819ece15e4295cce254c87a4f45","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/lightgallery/js/lightgallery.js","hash":"3cd19b33ba99efd5ba1d167da91720566d274b2c","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/lightgallery/js/lightgallery.min.js","hash":"956ef9b706755318da69ad0b5d7786339d831251","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/lightgallery/img/loading.gif","hash":"607810444094b8619fa4efa6273bc2a7e38dd4b4","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/lightgallery/img/video-play.png","hash":"3ea484cdc04d2e4547f80cbf80001dcf248c94ef","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/lightgallery/img/vimeo-play.png","hash":"6190254f2804904a4a1fa1eb390dfd334e416992","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/lightgallery/img/youtube-play.png","hash":"fea6df9d9d43151f9c9d15f000adb30eb3e26fc4","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/59ZRklaO5bWGqF5A9baEERJtnKITppOI_IvcXXDNrsc.woff2","hash":"c4248ea800bd5608344ce163f5658b57e7ef9410","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/K88pR3goAWT7BTt32Z01mxJtnKITppOI_IvcXXDNrsc.woff2","hash":"e0350190d720a8fec0557ab47b318ec4e4486448","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/LWCjsQkB6EMdfHrEVqA1KRJtnKITppOI_IvcXXDNrsc.woff2","hash":"2c5b039b57f62625e88226a938679ec937431ad1","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/MTP_ySUJH_bn48VBG8sNShWV49_lSm1NYrwo-zkhivY.woff2","hash":"22413bb8bfb78608c1e25aa1ed5c1f38557df79f","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/MTP_ySUJH_bn48VBG8sNSj0LW-43aMEzIO6XUTLjad8.woff2","hash":"63eb74ef040aade256f2274a7f31a914edddb0ea","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/MTP_ySUJH_bn48VBG8sNSpX5f-9o1vgP2EXwfjgl7AY.woff2","hash":"328a22fe3eec71ad9e5ece4d67dd62e79dab6b7f","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/MTP_ySUJH_bn48VBG8sNSq-j2U0lmluP9RWlSytm3ho.woff2","hash":"4dc6d7174ea6d89f4c45e43e1bfc3e03d8ffebaf","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/MTP_ySUJH_bn48VBG8sNSqaRobkAwv3vxw3jMhVENGA.woff2","hash":"415eee05976ab8b2471602a5ddb78a6c58fc21aa","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/MTP_ySUJH_bn48VBG8sNSugdm0LZdjqr5-oayXSOefg.woff2","hash":"a0b0c389cf46d63c850e61fed572485ff0b68183","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/MTP_ySUJH_bn48VBG8sNSv8zf_FOSsgRmwsS7Aa9k2w.woff2","hash":"c5f29fed6632efe0aa83318369f0d8c4061b775b","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/RjgO7rYTmqiVp7vzi-Q5URJtnKITppOI_IvcXXDNrsc.woff2","hash":"be201d32a9aa5d186723ebb3c538be691aa8c53a","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/cJZKeOuBrn4kERxqtaUH3VtXRa8TVwTICgirnJhmVJw.woff2","hash":"afc44700053c9a28f9ab26f6aec4862ac1d0795d","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/u-WUoqrET9fUeobQW7jkRRJtnKITppOI_IvcXXDNrsc.woff2","hash":"113978181dcac77baecef6115a9121d8f6e4fc3a","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/xjAJXh38I15wypJXxuGMBiYE0-AqJ3nfInTTiDXDjU4.woff2","hash":"5067c81462c15422853c94d21a1726865a61634f","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/xjAJXh38I15wypJXxuGMBjTOQ_MqJVwkKsUn0wKzc2I.woff2","hash":"b366f2fda2e524eb5ef50058eefff249a3b96e6c","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/xjAJXh38I15wypJXxuGMBjUj_cnvWIuuBMVgbX098Mw.woff2","hash":"d22904914469be735490e3c8cb093c7862896dd5","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/xjAJXh38I15wypJXxuGMBkbcKLIaa1LC45dFaAfauRA.woff2","hash":"ae80fb3cd16339aa7b5da280ab53975523dcaac2","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/xjAJXh38I15wypJXxuGMBmo_sUJ8uO4YLWRInS22T3Y.woff2","hash":"b85efde42fa3a03c32b1d31c6cd74c622fc7916c","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/xjAJXh38I15wypJXxuGMBo4P5ICox8Kq3LLUNMylGO4.woff2","hash":"e75607ba1417181397c700775b84303d5a2957b9","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/xjAJXh38I15wypJXxuGMBr6up8jxqWt8HVA3mDhkV_0.woff2","hash":"d0b40a7848703556c6631f24e961a98ca5829255","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/open-sans/fonts/xozscpT2726on7jbcb_pAhJtnKITppOI_IvcXXDNrsc.woff2","hash":"be365eca44760ce3fc9b377c43d4634958479c69","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/source-code-pro/fonts/mrl8jkM18OlOQN8JLgasD9V_2ngZ8dMf8fLgjYEouxg.woff2","hash":"942addaec4d3a60af33947a84a3d85f926015947","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/source-code-pro/fonts/mrl8jkM18OlOQN8JLgasDy2Q8seG17bfDXYR_jUsrzg.woff2","hash":"b0e0bb5ef78db8b15d430d0b9be9d4329289a310","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/font-awesome/fonts/fontawesome-webfont.woff","hash":"6d7e6a5fc802b13694d8820fc0138037c0977d2e","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/font-awesome/fonts/fontawesome-webfont.woff2","hash":"97e438cc545714309882fbceadbf344fcaddcec5","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/font-awesome/fonts/FontAwesome.otf","hash":"1b22f17fdc38070de50e6d1ab3a32da71aa2d819","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/font-awesome/fonts/fontawesome-webfont.eot","hash":"965ce8f688fedbeed504efd498bc9c1622d12362","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/font-awesome/fonts/fontawesome-webfont.ttf","hash":"61d8d967807ef12598d81582fa95b9f600c3ee01","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/jquery/2.1.3/jquery.min.js","hash":"41b4bfbaa96be6d1440db6e78004ade1c134e276","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/jquery/plugins/cookie/1.4.1/jquery.cookie.js","hash":"31e1bcc4cf805a2c2fee21f48ded1e598f64a2a8","modified":1563743114000},{"_id":"themes/Wikitten/source/libs/font-awesome/fonts/fontawesome-webfont.svg","hash":"c0522272bbaef2acb3d341912754d6ea2d0ecfc0","modified":1563743114000},{"_id":"themes/Wikitten/source/uploads/tianya.png","hash":"2d392e6eb508d31f7328d0c21492f3970f0ee213","modified":1563651881000},{"_id":"source/.DS_Store","hash":"a9cabec0ae931e7048f423a95c704c714780b5e1","modified":1588882647870},{"_id":"source/.markeditor/file_manager_status.config","hash":"c750fd1fe3f1407005c5d2b5d7b7f9bca54970c3","modified":1564688931000},{"_id":"source/.markeditor/file_manager_width.config","hash":"2c427b959b7a35c68831d16645d2afde8cb67ddd","modified":1564594162000},{"_id":"source/_drafts/.DS_Store","hash":"df2fbeb1400acda0909a32c1cf6bf492f1121e07","modified":1565728063000},{"_id":"source/_drafts/典故-md.md","hash":"2b33e03ac046894df112a9d45da13a690f621ed2","modified":1563856606000},{"_id":"source/_posts/.DS_Store","hash":"6f8ff578f75eaeb17eeb676dc7e41d9fe37fa6af","modified":1588882832887},{"_id":"source/about/index.md","hash":"282d4c506b467c746d1154f25338d16be6abbb62","modified":1563816667000},{"_id":"source/categories/.DS_Store","hash":"df2fbeb1400acda0909a32c1cf6bf492f1121e07","modified":1565728063000},{"_id":"source/about/.DS_Store","hash":"df2fbeb1400acda0909a32c1cf6bf492f1121e07","modified":1565728063000},{"_id":"source/categories/index.md","hash":"53bbe27e36d98a4a55fdce6a7fd9cac3e6671439","modified":1563766746000},{"_id":"source/tags/.DS_Store","hash":"df2fbeb1400acda0909a32c1cf6bf492f1121e07","modified":1565728063000},{"_id":"source/tags/index.md","hash":"163f9d816dac6cc50a48347bf7f93f29fa503736","modified":1563766671000},{"_id":"source/_posts/.markeditor/file_manager_status.config","hash":"26ccad3385b35b5dd4b33232ba36d0da4f190c00","modified":1588848849111},{"_id":"source/_posts/.markeditor/file_manager_width.config","hash":"2c427b959b7a35c68831d16645d2afde8cb67ddd","modified":1588848807781},{"_id":"source/_posts/IT/.DS_Store","hash":"f31c5797d3b40ff7f36965331428bf17084dc289","modified":1565813210000},{"_id":"source/_posts/常用文件/Hexo日常管理.md","hash":"48184f3ce76a6679a525e3349ec30ae4608ac5ec","modified":1564718092000},{"_id":"source/_posts/常用文件/.DS_Store","hash":"df2fbeb1400acda0909a32c1cf6bf492f1121e07","modified":1565728063000},{"_id":"source/_posts/摘录/.DS_Store","hash":"df2fbeb1400acda0909a32c1cf6bf492f1121e07","modified":1565728063000},{"_id":"source/_posts/摘录/《驴得水》影评.md","hash":"dcd7ea1a8643fe06ff14022c5d5577ccf810a33c","modified":1565905736000},{"_id":"source/_posts/摘录/典故.md","hash":"bd9982cfe6eea388c4f99b79d479939974cf0d1e","modified":1564545095000},{"_id":"source/_posts/摘录/爱乐之城——影评.md","hash":"dd74130851f4565e9a4ae2d8b1218e4b74fb9672","modified":1565764310000},{"_id":"source/_posts/文档/RZF-Organisation.md","hash":"37c4c97661f0ac8203e1b0c4f7f1df70dfe2c4a1","modified":1566463161000},{"_id":"source/_posts/读书笔记/.DS_Store","hash":"df2fbeb1400acda0909a32c1cf6bf492f1121e07","modified":1565728063000},{"_id":"source/_posts/读书笔记/《少有人走的路》笔记.md","hash":"5a6ce1a62ddca691e7aa49658a6a1ea8cd8215e3","modified":1564632258000},{"_id":"source/_posts/读书笔记/斯多葛主义手册.md","hash":"a56ce651794cbedea74361202e9f1868a0b10f61","modified":1565764288000},{"_id":"source/_posts/读书笔记/财富自由之路-李笑来.md","hash":"0f1bb3b57fb1b23e38984f0343c31431c0592ab8","modified":1565764569000},{"_id":"source/_posts/随笔/.DS_Store","hash":"df2fbeb1400acda0909a32c1cf6bf492f1121e07","modified":1565728063000},{"_id":"source/_posts/随笔/hello-world.md","hash":"5c562e2b6c5184f490c0ea1b6d820fe50579406b","modified":1564545095000},{"_id":"source/_posts/IT/Code/Javascript技术摘要.md","hash":"e949fc3ccd48cfba5e3064c7b39ed5f523553d86","modified":1589169243957},{"_id":"source/_posts/IT/Mac/.DS_Store","hash":"df2fbeb1400acda0909a32c1cf6bf492f1121e07","modified":1588882793782},{"_id":"source/_posts/IT/Mac/Mac使用标签.md","hash":"c28b4fa4701f08fcfe5942ec8f151d7cfd2f8dad","modified":1564545094000},{"_id":"source/_posts/IT/Tools/Ubuntu重设root用户密码.md","hash":"b7323a3ac81d57b3c489d97c7da56a991883089f","modified":1565764467000},{"_id":"source/_posts/IT/Tools/坚果云有关.md","hash":"1a966cbc37318b34551bf17be4bccfc16761fa7f","modified":1565820630000},{"_id":"source/_posts/IT/Tools/Gitbook攻略.md","hash":"c78d9b403444239f353b6a4a6ce0f97e6ad0fcd7","modified":1565862378000},{"_id":"source/_posts/IT/Mac/Mac备忘录.md","hash":"5d7fb8ad7a1a59b6dd65df8a6eae0d8cb7b18fd5","modified":1588836517649},{"_id":"source/_posts/IT/Tools/使用Github维护知识库.md","hash":"27bf57527ac1d9061b1733540ac9f0b383a8a35f","modified":1565862053000},{"_id":"source/_posts/IT/Tools/有用的shell命令.md","hash":"1e3bffca5cac009d0f91cbd6bb96206076e50cae","modified":1565788356000},{"_id":"source/_posts/IT/Tools/编辑器工具使用技巧汇总.md","hash":"8103dd1e47e61523c797cf86e82bb26517f54b12","modified":1567357907000},{"_id":"source/_posts/IT/Tools/配置服务器端MySQL.md","hash":"d44b85906db5816259dc4b2128dcac8a0766b447","modified":1565788245000},{"_id":"source/_posts/IT/Web/Next主题添加内容折叠.md","hash":"0c381c884e0c77af522fdbf958536f2c217ceb1b","modified":1564545094000},{"_id":"source/_posts/IT/Web/同步Hexo文章与Mac上原笔记的分类和标签.md","hash":"3af3acc8ed642c8c74ad89b87ee0e98bf0db9865","modified":1564837106000},{"_id":"source/_posts/IT/Web/如何系统化管理Hexo博客.md","hash":"06aeeeb674ebf91cc550732fd7c5f5f30413e791","modified":1565905917000},{"_id":"source/_posts/IT/Web/搭建Hexo博客的流水账.md","hash":"2bc4bf601a7c03ca17acf56806bd8aaf1b2e6f5c","modified":1565865865000},{"_id":"source/_posts/IT/skill/用Typescript编写JS函数库.md","hash":"b189a07241dcd4bc6388fb40f92d1ec9b9835669","modified":1566646240000},{"_id":"source/_posts/IT/skill/还在用七牛.md","hash":"ee7b98bee940ef09c06ffcdc967b41af8d0752b1","modified":1565852093000},{"_id":"source/_posts/IT/skill/MathJax用于易学领域.md","hash":"a199fc359afe19f5ec89c2069defd27990b742f9","modified":1588930688489},{"_id":"source/_posts/摘录/娱乐/搞笑段子.md","hash":"a13e48400bba8b3427b7ac080073ec19fa20bc93","modified":1564545095000},{"_id":"source/_posts/摘录/片段/佛偈集合.md","hash":"fcc94a0d1fbabbd9ff5cc9a607bc07dec6b9fb8b","modified":1565905574000},{"_id":"source/_posts/摘录/片段/名人语录.md","hash":"3c9d34d4393d3276a3ab8ad82ccabc6b3155f39f","modified":1564545095000},{"_id":"source/_posts/摘录/片段/简短书摘.md","hash":"a2586fd508f831d1631fbc0925c39288ffd23692","modified":1564545095000},{"_id":"source/_posts/摘录/片段/缠中说禅.md","hash":"57bc98bc30aff6804eebbe9b5300af1f673973a3","modified":1564545095000},{"_id":"source/_posts/摘录/片段/零散句子.md","hash":"c6100208f88c30d1910c03d472cc96e53320c996","modified":1564942528000},{"_id":"source/_posts/Hexo在线编辑.md","hash":"b03f87c1a35765cc28fb78885be5a1e8b5e6a2fd","modified":1626645017407},{"_id":"public/atom.xml","hash":"1dab61e5d7041f15e6dcf98490385e4d1cdd85f9","modified":1629304637462},{"_id":"public/search.xml","hash":"0cea8acbee672b1f7ec1b0dc4994f11e075577a2","modified":1629304637463},{"_id":"public/content.json","hash":"d1c2f7c70d9d8805952aa03e0462809bd9108a64","modified":1629304638629},{"_id":"public/sitemap.xml","hash":"ea3510cbf1271cbc3f8b1e4bb6fb7b803842996b","modified":1629304638630},{"_id":"public/about/index.html","hash":"a54a52768395f529850aa40560487cbb9b0c7710","modified":1629304638816},{"_id":"public/categories/index.html","hash":"245ddebd37737855c3069b1e2e2931f006fb59c8","modified":1629304638816},{"_id":"public/tags/index.html","hash":"88fc8af1fb7bfd0261620e2587a1c99c93245bfc","modified":1629304638985},{"_id":"public/javascript-typescript-skills.html","hash":"74acc1048ce1a20cb6a23c7e67c85157c19078c3","modified":1629304638989},{"_id":"public/mathjax-yixue-usage.html","hash":"0945d34847087841944a307d707040ca853b26a6","modified":1629304638989},{"_id":"public/TypeScript-build-JS-Package.html","hash":"4606132b1081f28b64360c869a73a3e32f8093e5","modified":1629304638989},{"_id":"public/still-using-qiniu.html","hash":"1c2e53ca01ebd4800c0a3e729672e5388cacce6f","modified":1629304638989},{"_id":"public/gitbook_with_typora_gh-pages.html","hash":"971377db2104c2f51cc9a69a6127a00cb09230f8","modified":1629304638989},{"_id":"public/config-mysql-access-privileges-on-vps.html","hash":"b03450a9c473dee6c16b89a4c412e6f161dd8b52","modified":1629304638989},{"_id":"public/storic-summary.html","hash":"2f8c489e858d5e99107b538dad22d010a83621ba","modified":1629304638990},{"_id":"public/synchron-the-tag-and-categories-btw-pc-hexo.html","hash":"1cb18bbb111df42f6ea4b7dbfbbac61a816d44cd","modified":1629304638990},{"_id":"public/helpfull-shell-command.html","hash":"7fb41c663257bbd66b84d6477da40527a2c5cfce","modified":1629304638990},{"_id":"public/hexo-blog-alltag-verwalten.html","hash":"a36fac1cb14998fcdad03810ef37ffad1707f834","modified":1629304638990},{"_id":"public/budahlisisch-poeim-collection.html","hash":"0d8d74d10fec65dc1ede109cac2433da177aa3a8","modified":1629304638990},{"_id":"public/brief-notions-collection.html","hash":"1bc67a64e167d3e7b9a03773b906c2c5a526ebb9","modified":1629304638990},{"_id":"public/funny-sloga-collection.html","hash":"d98bea10fc9680cdb63e476730291201c942dd2a","modified":1629304638990},{"_id":"public/old-stories-collection.html","hash":"749632c6b40e93f4836467e99f59a630e37766cf","modified":1629304638990},{"_id":"public/funny-things-collection.html","hash":"02a1c9d9afd3f9700ba3fa45ec72933a048b3a03","modified":1629304638990},{"_id":"public/prominaent-slogen-collection.html","hash":"f38cec12ed5c80f7153d3e99247084e500fe865b","modified":1629304638990},{"_id":"public/how-to-manage-big-hexo-blog.html","hash":"445a1f19ce3386bef5237ccfef7ef2cb32ea35e0","modified":1629304638990},{"_id":"public/lvdeshui-film.html","hash":"e8822b7cdd445c1355d9a876eaf82190c780e54d","modified":1629304638990},{"_id":"public/Editor-Skills-Summary.html","hash":"cd0e23edad8a6ea03be138ad048cfea4d33a10ee","modified":1629304638990},{"_id":"public/ubuntu-reset-root-pw.html","hash":"cd4c71499856a7f2edea67b101b97cb9a02939e3","modified":1629304638991},{"_id":"public/how-build-my-hexo-blog.html","hash":"d9aeb985638e7503b2b33150da9aec281191af75","modified":1629304638991},{"_id":"public/about-jianguoyu.html","hash":"8b538a817cf0c2e06d14c1fa1426da1bcc6993cb","modified":1629304638991},{"_id":"public/use-github-in-wiki.html","hash":"19c01227e80212854a7a3a92cf1b3bdfbd7dc29b","modified":1629304638991},{"_id":"public/next-collapse-block.html","hash":"1d005099642adfba3dc48e14341f3859236f3257","modified":1629304638991},{"_id":"public/rzf-organisation.html","hash":"d60bde6b1987164b62ad87e4b5c7093fe41a5925","modified":1629304638991},{"_id":"public/mac-using-tags.html","hash":"507ffcdb38e580338b28055a7b5599dca5c7d4d1","modified":1629304638991},{"_id":"public/mac-memo.html","hash":"4570b6079be1ca86c99beec32622b236eb7da2fd","modified":1629304638991},{"_id":"public/lalaland-film.html","hash":"6cb00b7e976d76196f4ab0ca8ab0263b4b2ca16e","modified":1629304638991},{"_id":"public/road-to-asset-freedom.html","hash":"fb6e0e97c1588314298e80737d4c9823c0422351","modified":1629304638991},{"_id":"public/road-less-traveled-summary.html","hash":"6844257b35be75063ec52a7471a0bc0b13bfe33b","modified":1629304638991},{"_id":"public/hellow-world.html","hash":"92fe8308b905ae5c8c0f21b22edb636a720eec62","modified":1629304638991},{"_id":"public/categories/常用文件/index.html","hash":"e5302e6327715e542fe053a66c9a7f71fb4264e0","modified":1629304638992},{"_id":"public/categories/摘录/index.html","hash":"c7deebdad249124512a5d599373be838ecfed992","modified":1629304638993},{"_id":"public/categories/文档/index.html","hash":"96c1466482d2f8423e88d3ab85ed317589525b92","modified":1629304638993},{"_id":"public/categories/随笔/index.html","hash":"cba4cc9f2cf91ee606e9777505e866d40621cda3","modified":1629304638993},{"_id":"public/categories/读书笔记/index.html","hash":"58b56a98a8bfd3837093358b58103efd34c9cc69","modified":1629304638993},{"_id":"public/categories/IT/index.html","hash":"98236adcd108f6453559203b3eabac46d727caaa","modified":1629304638993},{"_id":"public/categories/IT/page/2/index.html","hash":"37f1ec3692df8d9a158a28adffb4f65b8912ce37","modified":1629304638993},{"_id":"public/categories/IT/Mac/index.html","hash":"c83b9b4a994d1ddb216125244fad56b14ea12aa3","modified":1629304638993},{"_id":"public/categories/IT/Code/index.html","hash":"1c6eb2b386602ab41a52a95b5022dc852e885ecb","modified":1629304638993},{"_id":"public/categories/IT/Tools/index.html","hash":"e48dcb022150f187adec7b06e5bf5b06fe932e43","modified":1629304638993},{"_id":"public/categories/IT/Web/index.html","hash":"3c0317f5af922dd791ff2819b99463fc772f3193","modified":1629304638993},{"_id":"public/categories/IT/skill/index.html","hash":"979f0e0064ae510e24a626a8b9ac2025069705a5","modified":1629304638993},{"_id":"public/categories/摘录/片段/index.html","hash":"4e8830ec7530dc440dcb977cbf38d6e3c99b6101","modified":1629304638993},{"_id":"public/categories/摘录/娱乐/index.html","hash":"62507be09efc00f6d77d2b874e03d89e28cc6ffb","modified":1629304638993},{"_id":"public/index.html","hash":"658614e82593dfc68a217ce8dbfe94b58df6c4b9","modified":1629304638994},{"_id":"public/page/2/index.html","hash":"9ca83e46a087437cb7bf5e2fad755d0c7f6915ad","modified":1629304638994},{"_id":"public/page/3/index.html","hash":"f5d5f108f46ae99da7f4364c7bd28a1c3d10d815","modified":1629304638994},{"_id":"public/page/4/index.html","hash":"6b91a3390cf554920f944db4e0af97b2c2cff2d4","modified":1629304638994},{"_id":"public/archives/index.html","hash":"3bb49538d2314e8b58ff0c5349d48465bdd4f898","modified":1629304638991},{"_id":"public/archives/page/2/index.html","hash":"d4fe5cbef07e6ffe717a9d21dfcdd36b65c0d6f1","modified":1629304638991},{"_id":"public/archives/page/3/index.html","hash":"334baa255bd09304824ee0d40700da9071de7da5","modified":1629304638992},{"_id":"public/archives/page/4/index.html","hash":"0f885cf071b5913e113c16797b660f8aaf3dd76c","modified":1629304638992},{"_id":"public/archives/2019/index.html","hash":"1765512712650d052b91878101f76f7d50c7af9e","modified":1629304638992},{"_id":"public/archives/2019/page/2/index.html","hash":"78efece11147181979cfbb02e89bb4c082a38593","modified":1629304638992},{"_id":"public/archives/2019/page/3/index.html","hash":"2468f9c301affccfcf502e37a4ea2b82e497836e","modified":1629304638992},{"_id":"public/archives/2019/page/4/index.html","hash":"7374e7c9b3cad4f9c7ae7664d8495b16fee239a7","modified":1629304638992},{"_id":"public/archives/2019/06/index.html","hash":"1e61f3744deafe61419cf93a571fdc9d5fb9b23a","modified":1629304638992},{"_id":"public/archives/2019/07/index.html","hash":"7c8d71e52c3738700087b06f0c7ce72e37b446cb","modified":1629304638992},{"_id":"public/archives/2019/07/page/2/index.html","hash":"ce833a5c68081a5eb46ff07462b37896f7bbdeed","modified":1629304638992},{"_id":"public/archives/2019/07/page/3/index.html","hash":"0dc10690046277e76ed98f0be05839c08fb4fe64","modified":1629304638992},{"_id":"public/archives/2019/08/index.html","hash":"ac57710fd59d5878fb77e541ea8e0b174ec04451","modified":1629304638992},{"_id":"public/archives/2019/09/index.html","hash":"bead3f504a9e8aa9d61c048d8574ce456278190e","modified":1629304638992},{"_id":"public/tags/Hexo/index.html","hash":"9513ea0019d81b5733d0e1c41522e5f8bb6b180d","modified":1629304639016},{"_id":"public/tags/影视/index.html","hash":"5a52b682e520d9613051d15b5febe5a623db65b2","modified":1629304639016},{"_id":"public/tags/历史政治/index.html","hash":"649519206c0911269fab3b260423070fb0628e0f","modified":1629304639016},{"_id":"public/tags/工作/index.html","hash":"32bf422c9de39bd875dbeee979c28b3109bc8b0b","modified":1629304639017},{"_id":"public/tags/成长/index.html","hash":"3048357f3ac245c65604c2702f1e0a50af2f7895","modified":1629304639017},{"_id":"public/tags/经济/index.html","hash":"37159a0fb5ef31361f203feca79896bd9ef425b6","modified":1629304639017},{"_id":"public/tags/哲理/index.html","hash":"e5ed6ed42e820bb04eda620aa5a91d7c52df8d53","modified":1629304639017},{"_id":"public/tags/书籍/index.html","hash":"c80688be9ad985d7cb4a9995d4b9162ebb2c7ec5","modified":1629304639017},{"_id":"public/tags/心理/index.html","hash":"41561e20f312b455afa212bdcb5cb8eeae2625db","modified":1629304639017},{"_id":"public/tags/Mac/index.html","hash":"0f3866cb3400adc95be287b5d28569f12ca87044","modified":1629304639018},{"_id":"public/tags/工具/index.html","hash":"2b539099dcf089a842243a0434bf66e549f2e72a","modified":1629304639018},{"_id":"public/tags/文学/index.html","hash":"6cdda1de67a22ed147a8c73d4cc2893e8ccf946c","modified":1629304639018},{"_id":"public/tags/娱乐/index.html","hash":"e84ba6edd5274d3f6b7c393d99768a7c5c99fc0d","modified":1629304639018},{"_id":"public/lib/blog-encrypt.js","hash":"c9c3cd609c4d93a377849a010497a8eea2a0576e","modified":1629304638994},{"_id":"public/hexo-onlineeditor.html","hash":"9d29c3ebf8acad934217f6623e1e09266ef69a73","modified":1629304638986},{"_id":"public/categories/IT/Blog/index.html","hash":"97c6d970c87dcf81bd660a66f5906a2410187387","modified":1629304638993},{"_id":"public/archives/2021/index.html","hash":"0a4534c4de6489453699d742f090e4b20baf33d8","modified":1629304638992},{"_id":"public/archives/2021/07/index.html","hash":"6882f6a91c763b564f2b7202bb4579bc036629d9","modified":1629304638992},{"_id":"public/css/blog-encrypt.css","hash":"262922c3f49cb8cca7b3ea982c49b57de2af53d6","modified":1629304639023},{"_id":"public/lib/crypto-js.js","hash":"3dd73b6f13dc818a3a9c5c7424c1c4a9649b00a2","modified":1629304639871},{"_id":"public/images/mobile2.png","hash":"ba9a7a5464369c4272f6345ef879b5d1c2449de1","modified":1629304639018},{"_id":"public/images/mobile1.png","hash":"db83e3ffbf60ff88443cd3b9d1c23666005e88f0","modified":1629304639018},{"_id":"public/css/images/favicon.ico","hash":"b37ac89616b9e4c01a35991af59fe6b63e41a48e","modified":1629304639018},{"_id":"public/css/images/logo.png","hash":"8c61e1ec0b7c7200045d7795bac097fce475ef16","modified":1629304639018},{"_id":"public/css/images/thumb-default-small.png","hash":"e8403b97ed9251f9f5207765b0ce796c5000b4ba","modified":1629304639019},{"_id":"public/libs/fonts/glyphicons-halflings-regular.woff2","hash":"ca35b697d99cae4d1b60f2d60fcd37771987eb07","modified":1629304639019},{"_id":"public/libs/fonts/glyphicons-halflings-regular.woff","hash":"278e49a86e634da6f2a02f3b47dd9d2a8f26210f","modified":1629304639019},{"_id":"public/libs/fonts/glyphicons-halflings-regular.ttf","hash":"44bc1850f570972267b169ae18f1cb06b611ffa2","modified":1629304639020},{"_id":"public/libs/fonts/glyphicons-halflings-regular.eot","hash":"86b6f62b7853e67d3e635f6512a5a5efc58ea3c3","modified":1629304639020},{"_id":"public/libs/lightgallery/css/lg-fb-comment-box.css.map","hash":"51e9df39edf0faa3f38c1bab0c1fa6c922b9edcb","modified":1629304639020},{"_id":"public/libs/lightgallery/css/lg-transitions.css.map","hash":"50c3348638b4d82fa08a449c690e8d2bb593005d","modified":1629304639020},{"_id":"public/libs/lightgallery/css/lightgallery.css.map","hash":"3175b4107078674d25798979f7666f4daf31e624","modified":1629304639021},{"_id":"public/libs/lightgallery/fonts/lg.eot","hash":"54caf05a81e33d7bf04f2e420736ce6f1de5f936","modified":1629304639021},{"_id":"public/libs/lightgallery/fonts/lg.svg","hash":"9a732790adc004b22022cc60fd5f77ec4c8e3e5a","modified":1629304639021},{"_id":"public/libs/lightgallery/fonts/lg.woff","hash":"3048de344dd5cad4624e0127e58eaae4b576f574","modified":1629304639021},{"_id":"public/libs/lightgallery/fonts/lg.ttf","hash":"f6421c0c397311ae09f9257aa58bcd5e9720f493","modified":1629304639021},{"_id":"public/libs/lightgallery/img/loading.gif","hash":"607810444094b8619fa4efa6273bc2a7e38dd4b4","modified":1629304639021},{"_id":"public/libs/lightgallery/img/video-play.png","hash":"3ea484cdc04d2e4547f80cbf80001dcf248c94ef","modified":1629304639021},{"_id":"public/libs/lightgallery/img/vimeo-play.png","hash":"6190254f2804904a4a1fa1eb390dfd334e416992","modified":1629304639021},{"_id":"public/libs/lightgallery/img/youtube-play.png","hash":"fea6df9d9d43151f9c9d15f000adb30eb3e26fc4","modified":1629304639021},{"_id":"public/libs/open-sans/fonts/59ZRklaO5bWGqF5A9baEERJtnKITppOI_IvcXXDNrsc.woff2","hash":"c4248ea800bd5608344ce163f5658b57e7ef9410","modified":1629304639021},{"_id":"public/libs/open-sans/fonts/K88pR3goAWT7BTt32Z01mxJtnKITppOI_IvcXXDNrsc.woff2","hash":"e0350190d720a8fec0557ab47b318ec4e4486448","modified":1629304639021},{"_id":"public/libs/open-sans/fonts/LWCjsQkB6EMdfHrEVqA1KRJtnKITppOI_IvcXXDNrsc.woff2","hash":"2c5b039b57f62625e88226a938679ec937431ad1","modified":1629304639021},{"_id":"public/libs/open-sans/fonts/MTP_ySUJH_bn48VBG8sNShWV49_lSm1NYrwo-zkhivY.woff2","hash":"22413bb8bfb78608c1e25aa1ed5c1f38557df79f","modified":1629304639021},{"_id":"public/libs/open-sans/fonts/MTP_ySUJH_bn48VBG8sNSj0LW-43aMEzIO6XUTLjad8.woff2","hash":"63eb74ef040aade256f2274a7f31a914edddb0ea","modified":1629304639022},{"_id":"public/libs/open-sans/fonts/MTP_ySUJH_bn48VBG8sNSpX5f-9o1vgP2EXwfjgl7AY.woff2","hash":"328a22fe3eec71ad9e5ece4d67dd62e79dab6b7f","modified":1629304639022},{"_id":"public/libs/open-sans/fonts/MTP_ySUJH_bn48VBG8sNSq-j2U0lmluP9RWlSytm3ho.woff2","hash":"4dc6d7174ea6d89f4c45e43e1bfc3e03d8ffebaf","modified":1629304639022},{"_id":"public/libs/open-sans/fonts/MTP_ySUJH_bn48VBG8sNSqaRobkAwv3vxw3jMhVENGA.woff2","hash":"415eee05976ab8b2471602a5ddb78a6c58fc21aa","modified":1629304639022},{"_id":"public/libs/open-sans/fonts/MTP_ySUJH_bn48VBG8sNSugdm0LZdjqr5-oayXSOefg.woff2","hash":"a0b0c389cf46d63c850e61fed572485ff0b68183","modified":1629304639022},{"_id":"public/libs/open-sans/fonts/MTP_ySUJH_bn48VBG8sNSv8zf_FOSsgRmwsS7Aa9k2w.woff2","hash":"c5f29fed6632efe0aa83318369f0d8c4061b775b","modified":1629304639022},{"_id":"public/libs/open-sans/fonts/RjgO7rYTmqiVp7vzi-Q5URJtnKITppOI_IvcXXDNrsc.woff2","hash":"be201d32a9aa5d186723ebb3c538be691aa8c53a","modified":1629304639022},{"_id":"public/libs/open-sans/fonts/cJZKeOuBrn4kERxqtaUH3VtXRa8TVwTICgirnJhmVJw.woff2","hash":"afc44700053c9a28f9ab26f6aec4862ac1d0795d","modified":1629304639022},{"_id":"public/libs/open-sans/fonts/u-WUoqrET9fUeobQW7jkRRJtnKITppOI_IvcXXDNrsc.woff2","hash":"113978181dcac77baecef6115a9121d8f6e4fc3a","modified":1629304639022},{"_id":"public/libs/open-sans/fonts/xjAJXh38I15wypJXxuGMBiYE0-AqJ3nfInTTiDXDjU4.woff2","hash":"5067c81462c15422853c94d21a1726865a61634f","modified":1629304639022},{"_id":"public/libs/open-sans/fonts/xjAJXh38I15wypJXxuGMBjTOQ_MqJVwkKsUn0wKzc2I.woff2","hash":"b366f2fda2e524eb5ef50058eefff249a3b96e6c","modified":1629304639022},{"_id":"public/libs/open-sans/fonts/xjAJXh38I15wypJXxuGMBjUj_cnvWIuuBMVgbX098Mw.woff2","hash":"d22904914469be735490e3c8cb093c7862896dd5","modified":1629304639022},{"_id":"public/libs/open-sans/fonts/xjAJXh38I15wypJXxuGMBkbcKLIaa1LC45dFaAfauRA.woff2","hash":"ae80fb3cd16339aa7b5da280ab53975523dcaac2","modified":1629304639022},{"_id":"public/libs/open-sans/fonts/xjAJXh38I15wypJXxuGMBmo_sUJ8uO4YLWRInS22T3Y.woff2","hash":"b85efde42fa3a03c32b1d31c6cd74c622fc7916c","modified":1629304639022},{"_id":"public/libs/open-sans/fonts/xjAJXh38I15wypJXxuGMBo4P5ICox8Kq3LLUNMylGO4.woff2","hash":"e75607ba1417181397c700775b84303d5a2957b9","modified":1629304639023},{"_id":"public/libs/open-sans/fonts/xjAJXh38I15wypJXxuGMBr6up8jxqWt8HVA3mDhkV_0.woff2","hash":"d0b40a7848703556c6631f24e961a98ca5829255","modified":1629304639023},{"_id":"public/libs/open-sans/fonts/xozscpT2726on7jbcb_pAhJtnKITppOI_IvcXXDNrsc.woff2","hash":"be365eca44760ce3fc9b377c43d4634958479c69","modified":1629304639023},{"_id":"public/libs/source-code-pro/fonts/mrl8jkM18OlOQN8JLgasD9V_2ngZ8dMf8fLgjYEouxg.woff2","hash":"942addaec4d3a60af33947a84a3d85f926015947","modified":1629304639023},{"_id":"public/libs/source-code-pro/fonts/mrl8jkM18OlOQN8JLgasDy2Q8seG17bfDXYR_jUsrzg.woff2","hash":"b0e0bb5ef78db8b15d430d0b9be9d4329289a310","modified":1629304639023},{"_id":"public/libs/fonts/glyphicons-halflings-regular.svg","hash":"de51a8494180a6db074af2dee2383f0a363c5b08","modified":1629304639782},{"_id":"public/libs/font-awesome/fonts/fontawesome-webfont.woff","hash":"6d7e6a5fc802b13694d8820fc0138037c0977d2e","modified":1629304639840},{"_id":"public/libs/font-awesome/fonts/fontawesome-webfont.woff2","hash":"97e438cc545714309882fbceadbf344fcaddcec5","modified":1629304639844},{"_id":"public/libs/font-awesome/fonts/FontAwesome.otf","hash":"1b22f17fdc38070de50e6d1ab3a32da71aa2d819","modified":1629304639844},{"_id":"public/libs/font-awesome/fonts/fontawesome-webfont.eot","hash":"965ce8f688fedbeed504efd498bc9c1622d12362","modified":1629304639844},{"_id":"public/js/insight.js","hash":"c9dfd20ae82a446facad01439b7bb75332e3705b","modified":1629304639866},{"_id":"public/js/main.js","hash":"d1ab55b8f28037dab5512c40d33553fac966dc39","modified":1629304639866},{"_id":"public/libs/justified-gallery/justifiedGallery.min.css","hash":"13fbcba5e97aa88b748d94d3efc4718475279907","modified":1629304639867},{"_id":"public/libs/source-code-pro/styles.css","hash":"93c308012738728f906cd4c5cfdb34189e0c712b","modified":1629304639867},{"_id":"public/libs/open-sans/styles.css","hash":"5ca6e111046232bde112d33201a60532aee7d3c4","modified":1629304639867},{"_id":"public/libs/lightgallery/css/lg-fb-comment-box.css","hash":"844ce27b8488968bccb3e50bb49184ba2aae0625","modified":1629304639867},{"_id":"public/libs/lightgallery/css/lg-fb-comment-box.min.css","hash":"05830fadb8454f39dcc98c8686eb4d5c24b71fc0","modified":1629304639867},{"_id":"public/libs/lightgallery/js/lg-autoplay.js","hash":"426bb78b93acfc39d533ea2bab1cec8dc289cf24","modified":1629304639867},{"_id":"public/libs/lightgallery/js/lg-autoplay.min.js","hash":"d845741bcaf961579622880eb2a445257efad1ac","modified":1629304639868},{"_id":"public/libs/lightgallery/js/lg-fullscreen.js","hash":"65c47ac65362854ba44b00a010bb01e3630209d8","modified":1629304639868},{"_id":"public/libs/lightgallery/js/lg-fullscreen.min.js","hash":"b6b9e4022700b7faf2a5a175ba44a3bd938fdd20","modified":1629304639868},{"_id":"public/libs/lightgallery/js/lg-hash.js","hash":"15d16516c5642d3de1566ff8fc9160136ccaa405","modified":1629304639868},{"_id":"public/libs/lightgallery/js/lg-hash.min.js","hash":"43f1e1e720ab0e241c19b83aa26bd6848eab8edc","modified":1629304639868},{"_id":"public/libs/lightgallery/js/lg-pager.js","hash":"8092c692b244bb26343eb03b91bd97deb9dafc9c","modified":1629304639868},{"_id":"public/libs/lightgallery/js/lg-pager.min.js","hash":"25caa6ff65b1c6dee09941e795ae2633bdbab211","modified":1629304639869},{"_id":"public/libs/lightgallery/js/lg-share.js","hash":"b7fb5f6474911060a351b0a6fe9dbb9ac3fb22aa","modified":1629304639869},{"_id":"public/libs/lightgallery/js/lg-share.min.js","hash":"39c615f07c5d3aaa65a2c3068a30fdd6dd5c372d","modified":1629304639869},{"_id":"public/libs/lightgallery/js/lg-thumbnail.min.js","hash":"18dd7d2909d1bfd6852f031d03e774b4428c512b","modified":1629304639869},{"_id":"public/libs/lightgallery/js/lg-video.js","hash":"4f99b598f6bb18de9eca8c45c5b4373a03962367","modified":1629304639869},{"_id":"public/libs/lightgallery/js/lg-video.min.js","hash":"032c001ab045a69856f9c3ed4a2a3bf12a8e310f","modified":1629304639869},{"_id":"public/libs/lightgallery/js/lg-zoom.min.js","hash":"15b49f9728439819ece15e4295cce254c87a4f45","modified":1629304639869},{"_id":"public/libs/jquery/plugins/cookie/1.4.1/jquery.cookie.js","hash":"31e1bcc4cf805a2c2fee21f48ded1e598f64a2a8","modified":1629304639869},{"_id":"public/css/style.css","hash":"567e5bfb0dbbc816348bd4d32f7b7259e8625b23","modified":1629304639869},{"_id":"public/libs/justified-gallery/jquery.justifiedGallery.min.js","hash":"b2683e7a872bc109b1756a65188a37cef7d0bd5c","modified":1629304639869},{"_id":"public/libs/font-awesome/css/font-awesome.css","hash":"b5020c3860669185ba3f316fa7332cdf5c06f393","modified":1629304639869},{"_id":"public/libs/font-awesome/css/font-awesome.min.css","hash":"7cd5a3384333f95c3d37d9488ad82cd6c4b03761","modified":1629304639869},{"_id":"public/libs/lightgallery/css/lg-transitions.css","hash":"7871c28498d74451d6aa438c8d3a1817810a1e19","modified":1629304639869},{"_id":"public/libs/lightgallery/css/lg-transitions.min.css","hash":"5c22e2073a4c96d6212c72135391b599e8d1359f","modified":1629304639870},{"_id":"public/libs/lightgallery/css/lightgallery.css","hash":"bef55316a32e512d5a8940e5d0bfe8bf7a9c5c61","modified":1629304639870},{"_id":"public/libs/lightgallery/css/lightgallery.min.css","hash":"c9a2e19c932b56f4a2ce30c98910d10b74edb38a","modified":1629304639870},{"_id":"public/libs/lightgallery/js/lg-thumbnail.js","hash":"3a6476b6df1d2bef4a21861a78776282a7a11ef1","modified":1629304639870},{"_id":"public/libs/lightgallery/js/lg-zoom.js","hash":"a758e2c8fcf710f9ff761da0eea0ab9321f3484d","modified":1629304639870},{"_id":"public/libs/lightgallery/js/lightgallery.js","hash":"3cd19b33ba99efd5ba1d167da91720566d274b2c","modified":1629304639870},{"_id":"public/libs/lightgallery/js/lightgallery.min.js","hash":"956ef9b706755318da69ad0b5d7786339d831251","modified":1629304639870},{"_id":"public/libs/jquery/2.1.3/jquery.min.js","hash":"41b4bfbaa96be6d1440db6e78004ade1c134e276","modified":1629304639870},{"_id":"public/uploads/road-to-asset-freedom-mindmap.html","hash":"8ac819fd921e3fde7d5a7896e9e099dffb30cbe5","modified":1629304639870},{"_id":"public/images/SitePreview.png","hash":"c37c32696828492d6a8a4dfb0f84af98f5fb1306","modified":1629304639870},{"_id":"public/libs/font-awesome/fonts/fontawesome-webfont.ttf","hash":"61d8d967807ef12598d81582fa95b9f600c3ee01","modified":1629304639871},{"_id":"public/libs/font-awesome/fonts/fontawesome-webfont.svg","hash":"c0522272bbaef2acb3d341912754d6ea2d0ecfc0","modified":1629304639941},{"_id":"public/uploads/tianya.png","hash":"2d392e6eb508d31f7328d0c21492f3970f0ee213","modified":1629304640068}],"Category":[{"name":"常用文件","_id":"cka1y594t00064huuvvjmyzwy"},{"name":"摘录","_id":"cka1y5953000b4huuyyfu5z4d"},{"name":"文档","_id":"cka1y5959000j4huug5k1h4j7"},{"name":"随笔","_id":"cka1y595b000o4huul85o0vh5"},{"name":"读书笔记","_id":"cka1y596g000v4huufrvfyl7e"},{"name":"IT","_id":"cka1y597u00184huu67j8phqt"},{"name":"Mac","parent":"cka1y597u00184huu67j8phqt","_id":"cka1y5987001q4huu2h0pcxc7"},{"name":"Code","parent":"cka1y597u00184huu67j8phqt","_id":"cka1y598b001w4huu0hxl1aoy"},{"name":"Tools","parent":"cka1y597u00184huu67j8phqt","_id":"cka1y598e00234huu3y8d3uke"},{"name":"Web","parent":"cka1y597u00184huu67j8phqt","_id":"cka1y598z003b4huuyf8flxmz"},{"name":"skill","parent":"cka1y597u00184huu67j8phqt","_id":"cka1y5997003q4huuzp1l2yal"},{"name":"片段","parent":"cka1y5953000b4huuyyfu5z4d","_id":"cka1y599a003w4huuplb2sm25"},{"name":"娱乐","parent":"cka1y5953000b4huuyyfu5z4d","_id":"cka1y599b00404huu2nbcrdvc"},{"name":"Blog","parent":"cka1y597u00184huu67j8phqt","_id":"ckr9qy9qo0002g9sht8n0g8qc"}],"Data":[],"Page":[{"title":"关于本站","date":"2019-07-20T20:03:56.000Z","layout":"page","_content":"自从过上了极简生活,家务变得很少。对于一个巨蟹座的中年大叔,整理笔记成了我主要的挥洒精力的地方。我是笔记App的重度用户,用了两年的印象笔记,然后又五年的为知笔记,乃至尝试了新生人类惊为天人的熊掌记、Notion、等等。仍然感觉各种不爽。自从有了Hexo,终于可以定下心来,专心做笔记了。\n\n\n\n作为不是处女座的强迫症患者,我把自己的这个笔记库部署到了两个不同的站点。内容基本一样,组织方式十分不同。\n\n[完整个人维基](https://maiernte.github.io/wiki)\n\n[心情版的博客](https://maiernte.github.io)","source":"about/index.md","raw":"---\ntitle: 关于本站\ndate: 2019-07-20 22:03:56\nlayout: \"page\"\n---\n自从过上了极简生活,家务变得很少。对于一个巨蟹座的中年大叔,整理笔记成了我主要的挥洒精力的地方。我是笔记App的重度用户,用了两年的印象笔记,然后又五年的为知笔记,乃至尝试了新生人类惊为天人的熊掌记、Notion、等等。仍然感觉各种不爽。自从有了Hexo,终于可以定下心来,专心做笔记了。\n\n\n\n作为不是处女座的强迫症患者,我把自己的这个笔记库部署到了两个不同的站点。内容基本一样,组织方式十分不同。\n\n[完整个人维基](https://maiernte.github.io/wiki)\n\n[心情版的博客](https://maiernte.github.io)","updated":"2019-07-22T17:31:07.000Z","path":"about/index.html","_id":"cka1y592h00014huu243mez1a","comments":1,"content":"

自从过上了极简生活,家务变得很少。对于一个巨蟹座的中年大叔,整理笔记成了我主要的挥洒精力的地方。我是笔记App的重度用户,用了两年的印象笔记,然后又五年的为知笔记,乃至尝试了新生人类惊为天人的熊掌记、Notion、等等。仍然感觉各种不爽。自从有了Hexo,终于可以定下心来,专心做笔记了。

\n

作为不是处女座的强迫症患者,我把自己的这个笔记库部署到了两个不同的站点。内容基本一样,组织方式十分不同。

\n

完整个人维基

\n

心情版的博客

\n","site":{"data":{}},"excerpt":"","more":"

自从过上了极简生活,家务变得很少。对于一个巨蟹座的中年大叔,整理笔记成了我主要的挥洒精力的地方。我是笔记App的重度用户,用了两年的印象笔记,然后又五年的为知笔记,乃至尝试了新生人类惊为天人的熊掌记、Notion、等等。仍然感觉各种不爽。自从有了Hexo,终于可以定下心来,专心做笔记了。

\n

作为不是处女座的强迫症患者,我把自己的这个笔记库部署到了两个不同的站点。内容基本一样,组织方式十分不同。

\n

完整个人维基

\n

心情版的博客

\n"},{"title":"分类","date":"2019-07-20T19:59:23.000Z","type":"categories","layout":"categories","comments":0,"_content":"","source":"categories/index.md","raw":"---\ntitle: 分类\ndate: 2019-07-20 21:59:23\ntype: \"categories\"\nlayout: \"categories\"\ncomments: false\n---\n","updated":"2019-07-22T03:39:06.000Z","path":"categories/index.html","_id":"cka1y592j00024huuarbix88c","content":"","site":{"data":{}},"excerpt":"","more":""},{"title":"标签","date":"2019-07-20T19:49:33.000Z","type":"tags","layout":"tags","comments":0,"_content":"","source":"tags/index.md","raw":"---\ntitle: 标签\ndate: 2019-07-20 21:49:33\ntype: \"tags\"\nlayout: \"tags\"\ncomments: false\n---\n","updated":"2019-07-22T03:37:51.000Z","path":"tags/index.html","_id":"cka1y593q00034huu0cpu2qd8","content":"","site":{"data":{}},"excerpt":"","more":""}],"Post":[{"title":"典故.md","date":"2019-07-23T04:36:46.000Z","_content":"###### 豫让刺赵简子\n\n晋毕阳之孙豫让,始事范、中行氏而不说,去而就知伯,知伯宠之。及三晋分知氏,赵襄子最恐知伯,而将其头以为饮器。豫让遁逃山中曰:“磋乎!士为知己者死,女为悦己者容。吾其报知氏之仇矣。”\n\n乃变姓名,为刑人,入宫涂厕,欲以刺襄子。 襄子如厕,心动,执问涂者,则豫让也。 刃其曰:“欲为知伯报仇!”左右欲杀之。 赵襄子曰:“彼义士也,吾谨避之耳。且知伯已死,无后,而其臣至为报仇,此天下之贤人也。”卒释之。 豫让又漆身为厉,灭须去眉,自刑以变其容,为乞人而往乞,其妻不识,曰:“状貌不似吾夫,其音何类吾夫之甚也。”又吞炭为哑,变其音。 其友谓之曰:“子之道甚难而无功,谓子有志,则然矣,谓子知,则否。以子之才,而善事襄子,襄子必近幸子;子之得近而行所欲,此甚易而功必成。”豫让乃笑而应之曰:“是为先知报后知,为故君贼新君,大乱君臣之义者无此矣。凡吾所谓为此者,以明君臣之义,非从易也。且夫委质而事人,而求弑之,是怀二心以事君也。吾所为难,亦将以愧天下后世人臣怀二心者。”\n\n居顷之,襄子当出,豫让伏所当过桥下。 襄子至桥而马惊。 襄子曰:“此必豫让也。”使人问之,果豫让。 于是赵襄子面数豫让曰:“子不尝事范中行氏乎?知伯灭范中行氏,而子不为报仇,反委质事知伯。知伯已死,子独何为报仇之深也?”豫让曰:“臣事范中行氏,范中行氏以众人遇臣,臣故众人报之;知伯以国士遇臣,臣故国士报之。”襄子乃喟然叹泣曰:“嗟乎,豫子!豫子之为知伯,名既成矣,寡人舍子,亦以足矣。子自为计,寡人不舍子。”使兵环之。 豫让曰:“臣闻明主不掩人之义,忠臣不爱死以成名。君前已宽舍臣,天下莫不称君之贤。今日之事,臣故伏诛,然愿请君之衣而击之,虽死不恨。非所望也,敢布腹心。”于是襄子义之,乃使使者持衣与豫让。 豫让拔剑三跃,呼天击之曰:“而可以报知伯矣。”遂伏剑而死。 死之日,赵国之士闻之,皆为涕泣。\n\n—— 《战国策》","source":"_drafts/典故-md.md","raw":"title: 典故.md\ndate: 2019-07-23 06:36:46\ntags:\n---\n###### 豫让刺赵简子\n\n晋毕阳之孙豫让,始事范、中行氏而不说,去而就知伯,知伯宠之。及三晋分知氏,赵襄子最恐知伯,而将其头以为饮器。豫让遁逃山中曰:“磋乎!士为知己者死,女为悦己者容。吾其报知氏之仇矣。”\n\n乃变姓名,为刑人,入宫涂厕,欲以刺襄子。 襄子如厕,心动,执问涂者,则豫让也。 刃其曰:“欲为知伯报仇!”左右欲杀之。 赵襄子曰:“彼义士也,吾谨避之耳。且知伯已死,无后,而其臣至为报仇,此天下之贤人也。”卒释之。 豫让又漆身为厉,灭须去眉,自刑以变其容,为乞人而往乞,其妻不识,曰:“状貌不似吾夫,其音何类吾夫之甚也。”又吞炭为哑,变其音。 其友谓之曰:“子之道甚难而无功,谓子有志,则然矣,谓子知,则否。以子之才,而善事襄子,襄子必近幸子;子之得近而行所欲,此甚易而功必成。”豫让乃笑而应之曰:“是为先知报后知,为故君贼新君,大乱君臣之义者无此矣。凡吾所谓为此者,以明君臣之义,非从易也。且夫委质而事人,而求弑之,是怀二心以事君也。吾所为难,亦将以愧天下后世人臣怀二心者。”\n\n居顷之,襄子当出,豫让伏所当过桥下。 襄子至桥而马惊。 襄子曰:“此必豫让也。”使人问之,果豫让。 于是赵襄子面数豫让曰:“子不尝事范中行氏乎?知伯灭范中行氏,而子不为报仇,反委质事知伯。知伯已死,子独何为报仇之深也?”豫让曰:“臣事范中行氏,范中行氏以众人遇臣,臣故众人报之;知伯以国士遇臣,臣故国士报之。”襄子乃喟然叹泣曰:“嗟乎,豫子!豫子之为知伯,名既成矣,寡人舍子,亦以足矣。子自为计,寡人不舍子。”使兵环之。 豫让曰:“臣闻明主不掩人之义,忠臣不爱死以成名。君前已宽舍臣,天下莫不称君之贤。今日之事,臣故伏诛,然愿请君之衣而击之,虽死不恨。非所望也,敢布腹心。”于是襄子义之,乃使使者持衣与豫让。 豫让拔剑三跃,呼天击之曰:“而可以报知伯矣。”遂伏剑而死。 死之日,赵国之士闻之,皆为涕泣。\n\n—— 《战国策》","slug":"典故-md","published":0,"updated":"2019-07-23T04:36:46.000Z","_id":"cka1y592b00004huurtszb8lj","comments":1,"layout":"post","photos":[],"link":"","content":"
豫让刺赵简子
\n

晋毕阳之孙豫让,始事范、中行氏而不说,去而就知伯,知伯宠之。及三晋分知氏,赵襄子最恐知伯,而将其头以为饮器。豫让遁逃山中曰:“磋乎!士为知己者死,女为悦己者容。吾其报知氏之仇矣。”

\n

乃变姓名,为刑人,入宫涂厕,欲以刺襄子。 襄子如厕,心动,执问涂者,则豫让也。 刃其曰:“欲为知伯报仇!”左右欲杀之。 赵襄子曰:“彼义士也,吾谨避之耳。且知伯已死,无后,而其臣至为报仇,此天下之贤人也。”卒释之。 豫让又漆身为厉,灭须去眉,自刑以变其容,为乞人而往乞,其妻不识,曰:“状貌不似吾夫,其音何类吾夫之甚也。”又吞炭为哑,变其音。 其友谓之曰:“子之道甚难而无功,谓子有志,则然矣,谓子知,则否。以子之才,而善事襄子,襄子必近幸子;子之得近而行所欲,此甚易而功必成。”豫让乃笑而应之曰:“是为先知报后知,为故君贼新君,大乱君臣之义者无此矣。凡吾所谓为此者,以明君臣之义,非从易也。且夫委质而事人,而求弑之,是怀二心以事君也。吾所为难,亦将以愧天下后世人臣怀二心者。”

\n

居顷之,襄子当出,豫让伏所当过桥下。 襄子至桥而马惊。 襄子曰:“此必豫让也。”使人问之,果豫让。 于是赵襄子面数豫让曰:“子不尝事范中行氏乎?知伯灭范中行氏,而子不为报仇,反委质事知伯。知伯已死,子独何为报仇之深也?”豫让曰:“臣事范中行氏,范中行氏以众人遇臣,臣故众人报之;知伯以国士遇臣,臣故国士报之。”襄子乃喟然叹泣曰:“嗟乎,豫子!豫子之为知伯,名既成矣,寡人舍子,亦以足矣。子自为计,寡人不舍子。”使兵环之。 豫让曰:“臣闻明主不掩人之义,忠臣不爱死以成名。君前已宽舍臣,天下莫不称君之贤。今日之事,臣故伏诛,然愿请君之衣而击之,虽死不恨。非所望也,敢布腹心。”于是襄子义之,乃使使者持衣与豫让。 豫让拔剑三跃,呼天击之曰:“而可以报知伯矣。”遂伏剑而死。 死之日,赵国之士闻之,皆为涕泣。

\n

—— 《战国策》

\n","site":{"data":{}},"excerpt":"","more":"
豫让刺赵简子
\n

晋毕阳之孙豫让,始事范、中行氏而不说,去而就知伯,知伯宠之。及三晋分知氏,赵襄子最恐知伯,而将其头以为饮器。豫让遁逃山中曰:“磋乎!士为知己者死,女为悦己者容。吾其报知氏之仇矣。”

\n

乃变姓名,为刑人,入宫涂厕,欲以刺襄子。 襄子如厕,心动,执问涂者,则豫让也。 刃其曰:“欲为知伯报仇!”左右欲杀之。 赵襄子曰:“彼义士也,吾谨避之耳。且知伯已死,无后,而其臣至为报仇,此天下之贤人也。”卒释之。 豫让又漆身为厉,灭须去眉,自刑以变其容,为乞人而往乞,其妻不识,曰:“状貌不似吾夫,其音何类吾夫之甚也。”又吞炭为哑,变其音。 其友谓之曰:“子之道甚难而无功,谓子有志,则然矣,谓子知,则否。以子之才,而善事襄子,襄子必近幸子;子之得近而行所欲,此甚易而功必成。”豫让乃笑而应之曰:“是为先知报后知,为故君贼新君,大乱君臣之义者无此矣。凡吾所谓为此者,以明君臣之义,非从易也。且夫委质而事人,而求弑之,是怀二心以事君也。吾所为难,亦将以愧天下后世人臣怀二心者。”

\n

居顷之,襄子当出,豫让伏所当过桥下。 襄子至桥而马惊。 襄子曰:“此必豫让也。”使人问之,果豫让。 于是赵襄子面数豫让曰:“子不尝事范中行氏乎?知伯灭范中行氏,而子不为报仇,反委质事知伯。知伯已死,子独何为报仇之深也?”豫让曰:“臣事范中行氏,范中行氏以众人遇臣,臣故众人报之;知伯以国士遇臣,臣故国士报之。”襄子乃喟然叹泣曰:“嗟乎,豫子!豫子之为知伯,名既成矣,寡人舍子,亦以足矣。子自为计,寡人不舍子。”使兵环之。 豫让曰:“臣闻明主不掩人之义,忠臣不爱死以成名。君前已宽舍臣,天下莫不称君之贤。今日之事,臣故伏诛,然愿请君之衣而击之,虽死不恨。非所望也,敢布腹心。”于是襄子义之,乃使使者持衣与豫让。 豫让拔剑三跃,呼天击之曰:“而可以报知伯矣。”遂伏剑而死。 死之日,赵国之士闻之,皆为涕泣。

\n

—— 《战国策》

\n"},{"title":"Hexo日常管理","date":"2019-07-30T15:27:28.000Z","urlname":"hexo-blog-alltag-verwalten","toc":true,"notshow":true,"_content":"\n# 复制MD文件\n\n\n#### 查找最新文件\n\n```sh\nls -t /Users/mai/Projects/hexo/source/_posts/*.md | head -1 | xargs ls -l | awk '{print $6 \"-\" $7 \"-\" $8 }'\n\n# 最旧的文件就应该是\nls -t /Users/mai/Projects/hexo/source/_posts/*.md | tail -1 | xargs ls -l | awk '{print $6 \"-\" $7 \"-\" $8 }'\n```\n\n\n\n# 其它\n\nHexo 代码折叠\n\n```\n{% fold 点击显/隐内容 %}\n需要隐藏的内容。。。\n{% endfold %}\n```\n\n\n\n# 参考文件\n\n[有用的shell命令](helpfull-shell-command.html)\n\n# 会导致编译奔溃的错误\n\n大括号和井号连在一起\n\n```sh\n{#、 #}、{#} 这三种情况都会导致系统奔溃\n{} 和 # 之间如果有别的字符就不会。如 { # }\n或者放在代码段内也不会。行内代码不能避免这种情形。\n```\n\n","source":"_posts/常用文件/Hexo日常管理.md","raw":"---\ntitle: Hexo日常管理\ndate: 2019-07-30 17:27:28\nurlname: hexo-blog-alltag-verwalten\ntoc: true\ntags: [Hexo]\ncategories: [常用文件]\nnotshow: true\n\n---\n\n# 复制MD文件\n\n\n#### 查找最新文件\n\n```sh\nls -t /Users/mai/Projects/hexo/source/_posts/*.md | head -1 | xargs ls -l | awk '{print $6 \"-\" $7 \"-\" $8 }'\n\n# 最旧的文件就应该是\nls -t /Users/mai/Projects/hexo/source/_posts/*.md | tail -1 | xargs ls -l | awk '{print $6 \"-\" $7 \"-\" $8 }'\n```\n\n\n\n# 其它\n\nHexo 代码折叠\n\n```\n{% fold 点击显/隐内容 %}\n需要隐藏的内容。。。\n{% endfold %}\n```\n\n\n\n# 参考文件\n\n[有用的shell命令](helpfull-shell-command.html)\n\n# 会导致编译奔溃的错误\n\n大括号和井号连在一起\n\n```sh\n{#、 #}、{#} 这三种情况都会导致系统奔溃\n{} 和 # 之间如果有别的字符就不会。如 { # }\n或者放在代码段内也不会。行内代码不能避免这种情形。\n```\n\n","slug":"常用文件/Hexo日常管理","published":1,"updated":"2019-08-02T03:54:52.000Z","_id":"cka1y594p00044huusb0xswfi","comments":1,"layout":"post","photos":[],"link":"","content":"

复制MD文件

\n\n

查找最新文件

\n
1
2
3
4
ls -t /Users/mai/Projects/hexo/source/_posts/*.md | head -1 | xargs ls -l | awk '{print  $6 \"-\" $7 \"-\" $8 }'

# 最旧的文件就应该是
ls -t /Users/mai/Projects/hexo/source/_posts/*.md | tail -1 | xargs ls -l | awk '{print $6 \"-\" $7 \"-\" $8 }'
\n

其它

\n

Hexo 代码折叠

\n
1
2
3
{% fold 点击显/隐内容 %}
需要隐藏的内容。。。
{% endfold %}
\n

参考文件

\n

有用的shell命令

\n

会导致编译奔溃的错误

\n

大括号和井号连在一起

\n
1
2
3
{#、 #}、{#} 这三种情况都会导致系统奔溃
{} 和 # 之间如果有别的字符就不会。如 { # }
或者放在代码段内也不会。行内代码不能避免这种情形。
\n","site":{"data":{}},"excerpt":"","more":"

复制MD文件

\n\n

查找最新文件

\n\n

其它

\n

Hexo 代码折叠

\n\n

参考文件

\n

有用的shell命令

\n

会导致编译奔溃的错误

\n

大括号和井号连在一起

\n\n"},{"title":"《驴得水》——影评","date":"2019-07-28T13:17:19.000Z","urlname":"lvdeshui-film","_content":"\n![](https://github.com/maiernte/img/raw/master/collection/%E9%A9%B4%E5%BE%97%E6%B0%B4%E5%89%A7%E7%85%A7.jpg)\n\n\n\n> 追求自由的人,疯了,死了。\n不愿低头的人,成了听话的牲口。\n宽容大度的人,成了唯利是图的小人。\n淳朴憨厚的人,成了狡诈的恶棍。\n正面积极的人,用谎言掩盖真相。\n\n你觉得这是电影吗?其实,这是现实。我们先来看一下电影故事讲的是什么:\n\n一群怀揣伟大梦想的人,却敌不过山区缺水的现实,养了一头驴拉水。上头却不给养驴费,于是就把驴谎报成老师。上头来检查,不能因为一头驴毁了梦想啊。于是为了捍卫梦想的道路,却失去了梦想的意义。《驴得水》的海报上说,“讲个笑话,你可别哭啊”。 就像另一句笑话讲的那样, “小的时候我想拯救世界,长大后却发现世界都拯救不了我”。\n\n好笑,但却想哭。\n\n谁TM还没点梦想啊。但有时梦想很脆弱,甚至敌不过一碗炸酱面。你想让自己闪闪发光,但总得先养活自己,饿着肚子的人怎么去谈梦想?这也是很多刚毕业不久的人,所要面对的最为矛盾的情况。“我有很多想法,有很多想做的事。但我现在没钱、没人脉、没背景,甚至还没长相。想要出去闯一片天地, 但还要为一日三餐和落脚地打拼。梦想是高潮,现实却是性冷淡。还能怎么办呢?先养活自己再说吧”。于是,你找了一份莫名其妙的工作,你一日三餐是不愁了,你做着日复一日重复的工作,但是你不敢停,你越来越迷茫,越来越看不清生活的方向。\n\n你害怕那种怀揣梦想,但却又碌碌无为的日子,但你却不知道从哪里开始改变。于是你只能在焦虑中慢慢对现实妥协,然后你变成了自己曾经最讨厌的那种人。冷漠、没有激情、不思进取、浑浑噩噩,就像影片中的人物一样。曾经那些他们坚信的东西在面对现实时,都变得不堪一击。铁男说,“我没有办法啊,你知道子弹从脸上呼啸而过的感觉吗”?像不像我们经常说的,“我没办法啊,现实就是这样”。\n\n是啊,现实就是这样!作为芸芸众生,普通屁民,谁TM还没被现实强奸过啊。但想要活得更好,重要的不是治愈,而是带着病痛活下去。而且我们要清醒的认识到一个事实,有时我们之所以像傻逼一样努力,不是为了改变世界,而是为了不让世界改变我们。或许,这才是我们对这个世界最大的善意。\n","source":"_posts/摘录/《驴得水》影评.md","raw":"---\ntitle: 《驴得水》——影评\ndate: 2019-07-28 15:17:19\nurlname: lvdeshui-film\ntags: [影视]\ncategories: 摘录\n\n---\n\n![](https://github.com/maiernte/img/raw/master/collection/%E9%A9%B4%E5%BE%97%E6%B0%B4%E5%89%A7%E7%85%A7.jpg)\n\n\n\n> 追求自由的人,疯了,死了。\n不愿低头的人,成了听话的牲口。\n宽容大度的人,成了唯利是图的小人。\n淳朴憨厚的人,成了狡诈的恶棍。\n正面积极的人,用谎言掩盖真相。\n\n你觉得这是电影吗?其实,这是现实。我们先来看一下电影故事讲的是什么:\n\n一群怀揣伟大梦想的人,却敌不过山区缺水的现实,养了一头驴拉水。上头却不给养驴费,于是就把驴谎报成老师。上头来检查,不能因为一头驴毁了梦想啊。于是为了捍卫梦想的道路,却失去了梦想的意义。《驴得水》的海报上说,“讲个笑话,你可别哭啊”。 就像另一句笑话讲的那样, “小的时候我想拯救世界,长大后却发现世界都拯救不了我”。\n\n好笑,但却想哭。\n\n谁TM还没点梦想啊。但有时梦想很脆弱,甚至敌不过一碗炸酱面。你想让自己闪闪发光,但总得先养活自己,饿着肚子的人怎么去谈梦想?这也是很多刚毕业不久的人,所要面对的最为矛盾的情况。“我有很多想法,有很多想做的事。但我现在没钱、没人脉、没背景,甚至还没长相。想要出去闯一片天地, 但还要为一日三餐和落脚地打拼。梦想是高潮,现实却是性冷淡。还能怎么办呢?先养活自己再说吧”。于是,你找了一份莫名其妙的工作,你一日三餐是不愁了,你做着日复一日重复的工作,但是你不敢停,你越来越迷茫,越来越看不清生活的方向。\n\n你害怕那种怀揣梦想,但却又碌碌无为的日子,但你却不知道从哪里开始改变。于是你只能在焦虑中慢慢对现实妥协,然后你变成了自己曾经最讨厌的那种人。冷漠、没有激情、不思进取、浑浑噩噩,就像影片中的人物一样。曾经那些他们坚信的东西在面对现实时,都变得不堪一击。铁男说,“我没有办法啊,你知道子弹从脸上呼啸而过的感觉吗”?像不像我们经常说的,“我没办法啊,现实就是这样”。\n\n是啊,现实就是这样!作为芸芸众生,普通屁民,谁TM还没被现实强奸过啊。但想要活得更好,重要的不是治愈,而是带着病痛活下去。而且我们要清醒的认识到一个事实,有时我们之所以像傻逼一样努力,不是为了改变世界,而是为了不让世界改变我们。或许,这才是我们对这个世界最大的善意。\n","slug":"摘录/《驴得水》影评","published":1,"updated":"2019-08-15T21:48:56.000Z","_id":"cka1y594r00054huunm0reb46","comments":1,"layout":"post","photos":[],"link":"","content":"
\n

追求自由的人,疯了,死了。
\n不愿低头的人,成了听话的牲口。
\n宽容大度的人,成了唯利是图的小人。
\n淳朴憨厚的人,成了狡诈的恶棍。
\n正面积极的人,用谎言掩盖真相。

\n
\n

你觉得这是电影吗?其实,这是现实。我们先来看一下电影故事讲的是什么:

\n

一群怀揣伟大梦想的人,却敌不过山区缺水的现实,养了一头驴拉水。上头却不给养驴费,于是就把驴谎报成老师。上头来检查,不能因为一头驴毁了梦想啊。于是为了捍卫梦想的道路,却失去了梦想的意义。《驴得水》的海报上说,“讲个笑话,你可别哭啊”。 就像另一句笑话讲的那样, “小的时候我想拯救世界,长大后却发现世界都拯救不了我”。

\n

好笑,但却想哭。

\n

谁TM还没点梦想啊。但有时梦想很脆弱,甚至敌不过一碗炸酱面。你想让自己闪闪发光,但总得先养活自己,饿着肚子的人怎么去谈梦想?这也是很多刚毕业不久的人,所要面对的最为矛盾的情况。“我有很多想法,有很多想做的事。但我现在没钱、没人脉、没背景,甚至还没长相。想要出去闯一片天地, 但还要为一日三餐和落脚地打拼。梦想是高潮,现实却是性冷淡。还能怎么办呢?先养活自己再说吧”。于是,你找了一份莫名其妙的工作,你一日三餐是不愁了,你做着日复一日重复的工作,但是你不敢停,你越来越迷茫,越来越看不清生活的方向。

\n

你害怕那种怀揣梦想,但却又碌碌无为的日子,但你却不知道从哪里开始改变。于是你只能在焦虑中慢慢对现实妥协,然后你变成了自己曾经最讨厌的那种人。冷漠、没有激情、不思进取、浑浑噩噩,就像影片中的人物一样。曾经那些他们坚信的东西在面对现实时,都变得不堪一击。铁男说,“我没有办法啊,你知道子弹从脸上呼啸而过的感觉吗”?像不像我们经常说的,“我没办法啊,现实就是这样”。

\n

是啊,现实就是这样!作为芸芸众生,普通屁民,谁TM还没被现实强奸过啊。但想要活得更好,重要的不是治愈,而是带着病痛活下去。而且我们要清醒的认识到一个事实,有时我们之所以像傻逼一样努力,不是为了改变世界,而是为了不让世界改变我们。或许,这才是我们对这个世界最大的善意。

","site":{"data":{}},"excerpt":"

","more":"
\n

追求自由的人,疯了,死了。
\n不愿低头的人,成了听话的牲口。
\n宽容大度的人,成了唯利是图的小人。
\n淳朴憨厚的人,成了狡诈的恶棍。
\n正面积极的人,用谎言掩盖真相。

\n
\n

你觉得这是电影吗?其实,这是现实。我们先来看一下电影故事讲的是什么:

\n

一群怀揣伟大梦想的人,却敌不过山区缺水的现实,养了一头驴拉水。上头却不给养驴费,于是就把驴谎报成老师。上头来检查,不能因为一头驴毁了梦想啊。于是为了捍卫梦想的道路,却失去了梦想的意义。《驴得水》的海报上说,“讲个笑话,你可别哭啊”。 就像另一句笑话讲的那样, “小的时候我想拯救世界,长大后却发现世界都拯救不了我”。

\n

好笑,但却想哭。

\n

谁TM还没点梦想啊。但有时梦想很脆弱,甚至敌不过一碗炸酱面。你想让自己闪闪发光,但总得先养活自己,饿着肚子的人怎么去谈梦想?这也是很多刚毕业不久的人,所要面对的最为矛盾的情况。“我有很多想法,有很多想做的事。但我现在没钱、没人脉、没背景,甚至还没长相。想要出去闯一片天地, 但还要为一日三餐和落脚地打拼。梦想是高潮,现实却是性冷淡。还能怎么办呢?先养活自己再说吧”。于是,你找了一份莫名其妙的工作,你一日三餐是不愁了,你做着日复一日重复的工作,但是你不敢停,你越来越迷茫,越来越看不清生活的方向。

\n

你害怕那种怀揣梦想,但却又碌碌无为的日子,但你却不知道从哪里开始改变。于是你只能在焦虑中慢慢对现实妥协,然后你变成了自己曾经最讨厌的那种人。冷漠、没有激情、不思进取、浑浑噩噩,就像影片中的人物一样。曾经那些他们坚信的东西在面对现实时,都变得不堪一击。铁男说,“我没有办法啊,你知道子弹从脸上呼啸而过的感觉吗”?像不像我们经常说的,“我没办法啊,现实就是这样”。

\n

是啊,现实就是这样!作为芸芸众生,普通屁民,谁TM还没被现实强奸过啊。但想要活得更好,重要的不是治愈,而是带着病痛活下去。而且我们要清醒的认识到一个事实,有时我们之所以像傻逼一样努力,不是为了改变世界,而是为了不让世界改变我们。或许,这才是我们对这个世界最大的善意。

"},{"title":"典故","date":"2019-07-29T06:45:50.000Z","urlname":"old-stories-collection","toc":true,"notshow":true,"_content":"\n###### 豫让刺赵简子\n\n晋毕阳之孙豫让,始事范、中行氏而不说,去而就知伯,知伯宠之。及三晋分知氏,赵襄子最恐知伯,而将其头以为饮器。豫让遁逃山中曰:“磋乎!士为知己者死,女为悦己者容。吾其报知氏之仇矣。”\n\n\n\n乃变姓名,为刑人,入宫涂厕,欲以刺襄子。 襄子如厕,心动,执问涂者,则豫让也。 刃其曰:“欲为知伯报仇!”左右欲杀之。 赵襄子曰:“彼义士也,吾谨避之耳。且知伯已死,无后,而其臣至为报仇,此天下之贤人也。”卒释之。 豫让又漆身为厉,灭须去眉,自刑以变其容,为乞人而往乞,其妻不识,曰:“状貌不似吾夫,其音何类吾夫之甚也。”又吞炭为哑,变其音。 其友谓之曰:“子之道甚难而无功,谓子有志,则然矣,谓子知,则否。以子之才,而善事襄子,襄子必近幸子;子之得近而行所欲,此甚易而功必成。”豫让乃笑而应之曰:“是为先知报后知,为故君贼新君,大乱君臣之义者无此矣。凡吾所谓为此者,以明君臣之义,非从易也。且夫委质而事人,而求弑之,是怀二心以事君也。吾所为难,亦将以愧天下后世人臣怀二心者。”\n\n居顷之,襄子当出,豫让伏所当过桥下。 襄子至桥而马惊。 襄子曰:“此必豫让也。”使人问之,果豫让。 于是赵襄子面数豫让曰:“子不尝事范中行氏乎?知伯灭范中行氏,而子不为报仇,反委质事知伯。知伯已死,子独何为报仇之深也?”豫让曰:“臣事范中行氏,范中行氏以众人遇臣,臣故众人报之;知伯以国士遇臣,臣故国士报之。”襄子乃喟然叹泣曰:“嗟乎,豫子!豫子之为知伯,名既成矣,寡人舍子,亦以足矣。子自为计,寡人不舍子。”使兵环之。 豫让曰:“臣闻明主不掩人之义,忠臣不爱死以成名。君前已宽舍臣,天下莫不称君之贤。今日之事,臣故伏诛,然愿请君之衣而击之,虽死不恨。非所望也,敢布腹心。”于是襄子义之,乃使使者持衣与豫让。 豫让拔剑三跃,呼天击之曰:“而可以报知伯矣。”遂伏剑而死。 死之日,赵国之士闻之,皆为涕泣。\n\n—— 《战国策》\n","source":"_posts/摘录/典故.md","raw":"---\ntitle: 典故\ndate: 2019-07-29 08:45:50\nurlname: old-stories-collection\ntoc: true\ntags: [历史政治]\ncategories: [摘录]\nnotshow: true\n\n---\n\n###### 豫让刺赵简子\n\n晋毕阳之孙豫让,始事范、中行氏而不说,去而就知伯,知伯宠之。及三晋分知氏,赵襄子最恐知伯,而将其头以为饮器。豫让遁逃山中曰:“磋乎!士为知己者死,女为悦己者容。吾其报知氏之仇矣。”\n\n\n\n乃变姓名,为刑人,入宫涂厕,欲以刺襄子。 襄子如厕,心动,执问涂者,则豫让也。 刃其曰:“欲为知伯报仇!”左右欲杀之。 赵襄子曰:“彼义士也,吾谨避之耳。且知伯已死,无后,而其臣至为报仇,此天下之贤人也。”卒释之。 豫让又漆身为厉,灭须去眉,自刑以变其容,为乞人而往乞,其妻不识,曰:“状貌不似吾夫,其音何类吾夫之甚也。”又吞炭为哑,变其音。 其友谓之曰:“子之道甚难而无功,谓子有志,则然矣,谓子知,则否。以子之才,而善事襄子,襄子必近幸子;子之得近而行所欲,此甚易而功必成。”豫让乃笑而应之曰:“是为先知报后知,为故君贼新君,大乱君臣之义者无此矣。凡吾所谓为此者,以明君臣之义,非从易也。且夫委质而事人,而求弑之,是怀二心以事君也。吾所为难,亦将以愧天下后世人臣怀二心者。”\n\n居顷之,襄子当出,豫让伏所当过桥下。 襄子至桥而马惊。 襄子曰:“此必豫让也。”使人问之,果豫让。 于是赵襄子面数豫让曰:“子不尝事范中行氏乎?知伯灭范中行氏,而子不为报仇,反委质事知伯。知伯已死,子独何为报仇之深也?”豫让曰:“臣事范中行氏,范中行氏以众人遇臣,臣故众人报之;知伯以国士遇臣,臣故国士报之。”襄子乃喟然叹泣曰:“嗟乎,豫子!豫子之为知伯,名既成矣,寡人舍子,亦以足矣。子自为计,寡人不舍子。”使兵环之。 豫让曰:“臣闻明主不掩人之义,忠臣不爱死以成名。君前已宽舍臣,天下莫不称君之贤。今日之事,臣故伏诛,然愿请君之衣而击之,虽死不恨。非所望也,敢布腹心。”于是襄子义之,乃使使者持衣与豫让。 豫让拔剑三跃,呼天击之曰:“而可以报知伯矣。”遂伏剑而死。 死之日,赵国之士闻之,皆为涕泣。\n\n—— 《战国策》\n","slug":"摘录/典故","published":1,"updated":"2019-07-31T03:51:35.000Z","_id":"cka1y594x00084huu6k4ch39z","comments":1,"layout":"post","photos":[],"link":"","content":"
豫让刺赵简子
\n

晋毕阳之孙豫让,始事范、中行氏而不说,去而就知伯,知伯宠之。及三晋分知氏,赵襄子最恐知伯,而将其头以为饮器。豫让遁逃山中曰:“磋乎!士为知己者死,女为悦己者容。吾其报知氏之仇矣。”

\n\n

乃变姓名,为刑人,入宫涂厕,欲以刺襄子。 襄子如厕,心动,执问涂者,则豫让也。 刃其曰:“欲为知伯报仇!”左右欲杀之。 赵襄子曰:“彼义士也,吾谨避之耳。且知伯已死,无后,而其臣至为报仇,此天下之贤人也。”卒释之。 豫让又漆身为厉,灭须去眉,自刑以变其容,为乞人而往乞,其妻不识,曰:“状貌不似吾夫,其音何类吾夫之甚也。”又吞炭为哑,变其音。 其友谓之曰:“子之道甚难而无功,谓子有志,则然矣,谓子知,则否。以子之才,而善事襄子,襄子必近幸子;子之得近而行所欲,此甚易而功必成。”豫让乃笑而应之曰:“是为先知报后知,为故君贼新君,大乱君臣之义者无此矣。凡吾所谓为此者,以明君臣之义,非从易也。且夫委质而事人,而求弑之,是怀二心以事君也。吾所为难,亦将以愧天下后世人臣怀二心者。”

\n

居顷之,襄子当出,豫让伏所当过桥下。 襄子至桥而马惊。 襄子曰:“此必豫让也。”使人问之,果豫让。 于是赵襄子面数豫让曰:“子不尝事范中行氏乎?知伯灭范中行氏,而子不为报仇,反委质事知伯。知伯已死,子独何为报仇之深也?”豫让曰:“臣事范中行氏,范中行氏以众人遇臣,臣故众人报之;知伯以国士遇臣,臣故国士报之。”襄子乃喟然叹泣曰:“嗟乎,豫子!豫子之为知伯,名既成矣,寡人舍子,亦以足矣。子自为计,寡人不舍子。”使兵环之。 豫让曰:“臣闻明主不掩人之义,忠臣不爱死以成名。君前已宽舍臣,天下莫不称君之贤。今日之事,臣故伏诛,然愿请君之衣而击之,虽死不恨。非所望也,敢布腹心。”于是襄子义之,乃使使者持衣与豫让。 豫让拔剑三跃,呼天击之曰:“而可以报知伯矣。”遂伏剑而死。 死之日,赵国之士闻之,皆为涕泣。

\n

—— 《战国策》

\n","site":{"data":{}},"excerpt":"
豫让刺赵简子
\n

晋毕阳之孙豫让,始事范、中行氏而不说,去而就知伯,知伯宠之。及三晋分知氏,赵襄子最恐知伯,而将其头以为饮器。豫让遁逃山中曰:“磋乎!士为知己者死,女为悦己者容。吾其报知氏之仇矣。”

","more":"

乃变姓名,为刑人,入宫涂厕,欲以刺襄子。 襄子如厕,心动,执问涂者,则豫让也。 刃其曰:“欲为知伯报仇!”左右欲杀之。 赵襄子曰:“彼义士也,吾谨避之耳。且知伯已死,无后,而其臣至为报仇,此天下之贤人也。”卒释之。 豫让又漆身为厉,灭须去眉,自刑以变其容,为乞人而往乞,其妻不识,曰:“状貌不似吾夫,其音何类吾夫之甚也。”又吞炭为哑,变其音。 其友谓之曰:“子之道甚难而无功,谓子有志,则然矣,谓子知,则否。以子之才,而善事襄子,襄子必近幸子;子之得近而行所欲,此甚易而功必成。”豫让乃笑而应之曰:“是为先知报后知,为故君贼新君,大乱君臣之义者无此矣。凡吾所谓为此者,以明君臣之义,非从易也。且夫委质而事人,而求弑之,是怀二心以事君也。吾所为难,亦将以愧天下后世人臣怀二心者。”

\n

居顷之,襄子当出,豫让伏所当过桥下。 襄子至桥而马惊。 襄子曰:“此必豫让也。”使人问之,果豫让。 于是赵襄子面数豫让曰:“子不尝事范中行氏乎?知伯灭范中行氏,而子不为报仇,反委质事知伯。知伯已死,子独何为报仇之深也?”豫让曰:“臣事范中行氏,范中行氏以众人遇臣,臣故众人报之;知伯以国士遇臣,臣故国士报之。”襄子乃喟然叹泣曰:“嗟乎,豫子!豫子之为知伯,名既成矣,寡人舍子,亦以足矣。子自为计,寡人不舍子。”使兵环之。 豫让曰:“臣闻明主不掩人之义,忠臣不爱死以成名。君前已宽舍臣,天下莫不称君之贤。今日之事,臣故伏诛,然愿请君之衣而击之,虽死不恨。非所望也,敢布腹心。”于是襄子义之,乃使使者持衣与豫让。 豫让拔剑三跃,呼天击之曰:“而可以报知伯矣。”遂伏剑而死。 死之日,赵国之士闻之,皆为涕泣。

\n

—— 《战国策》

"},{"title":"RZF Organisation","urlname":"rzf-organisation","toc":true,"notshow":true,"date":"2019-07-22T18:23:00.000Z","_content":"\n# Kontakt\n\n## Abteilung\n- Verteiler \"**V-Krank**\"\n Für Ihre Krank- bzw. Gesundmeldung sowie alle übrigen Mitteilungen zum Thema Krankheit nutzen Sie bitte den Verteiler V-Krank (V-Krank-5011@fv.nrw.de).\n- Verteiler \"**V-Heimarbeitszeiten**\"\n Für die Meldung der Heimarbeitszeiten nutzen Sie bitte den Verteiler V-Heimarbeitszeiten (V-Heimarbeitszeiten-5011@fv.nrw.de).\n- Verteiler \"**V-Dienstreisezeiten**\"\n Über den Verteiler V-Dienstreisezeiten (V-Dienstreisezeiten-5011@fv.nrw.de) teilen Sie bitte Ihre Dienstreisezeiten, Lehrgangzeiten sowie das Ende des Dienstgeschäftes bei Dienstgängen mit. Zur Berechnung der Reisezeiten nutzen Sie bitte das im OASE-Vordruckschrank hinterlegte Berechnungsblatt (Vordruck H76 Reisezeitenberechnung).\n- Verteiler \"**V-GST**\"\n Den Verteiler V-GST (V-GST-5011@fv.nrw.de) verwenden Sie insbesondere für die nachfolgenden Angelegenheiten:\n Fragen/Mitteilungen zum Thema Urlaub, Sonderurlaub, Dienstbefreiung\n - Mitteilung von Zeiten bei vergessenen oder fehlerhaften GLAZ-Buchungen\n - Mitteilung über die ganztägige Kernzeitinanspruchnahme (GLAZ-Tag)\n - alle Fragen/Mitteilungen zu den übrigen Personalangelegenheiten, die nicht über die vorgenannten Verteiler abgedeckt sind.\n\n## Personal\n### Rohde, Rainer\nTelefon : (0211) 4572 - 2554\nE-Mail: rainer.rohde@fv.nrw.de\n### Uphoff, Christian\nchristian.uphoff@fv.nrw.de\n\n\\Drucker \\C0114237\\DR011226","source":"_posts/文档/RZF-Organisation.md","raw":"---\ntitle: RZF Organisation\nurlname: rzf-organisation\ntoc: true\ntags: [工作]\ncategories: 文档\nnotshow: true\ndate: 2019-07-22 20:23:00\n\n---\n\n# Kontakt\n\n## Abteilung\n- Verteiler \"**V-Krank**\"\n Für Ihre Krank- bzw. Gesundmeldung sowie alle übrigen Mitteilungen zum Thema Krankheit nutzen Sie bitte den Verteiler V-Krank (V-Krank-5011@fv.nrw.de).\n- Verteiler \"**V-Heimarbeitszeiten**\"\n Für die Meldung der Heimarbeitszeiten nutzen Sie bitte den Verteiler V-Heimarbeitszeiten (V-Heimarbeitszeiten-5011@fv.nrw.de).\n- Verteiler \"**V-Dienstreisezeiten**\"\n Über den Verteiler V-Dienstreisezeiten (V-Dienstreisezeiten-5011@fv.nrw.de) teilen Sie bitte Ihre Dienstreisezeiten, Lehrgangzeiten sowie das Ende des Dienstgeschäftes bei Dienstgängen mit. Zur Berechnung der Reisezeiten nutzen Sie bitte das im OASE-Vordruckschrank hinterlegte Berechnungsblatt (Vordruck H76 Reisezeitenberechnung).\n- Verteiler \"**V-GST**\"\n Den Verteiler V-GST (V-GST-5011@fv.nrw.de) verwenden Sie insbesondere für die nachfolgenden Angelegenheiten:\n Fragen/Mitteilungen zum Thema Urlaub, Sonderurlaub, Dienstbefreiung\n - Mitteilung von Zeiten bei vergessenen oder fehlerhaften GLAZ-Buchungen\n - Mitteilung über die ganztägige Kernzeitinanspruchnahme (GLAZ-Tag)\n - alle Fragen/Mitteilungen zu den übrigen Personalangelegenheiten, die nicht über die vorgenannten Verteiler abgedeckt sind.\n\n## Personal\n### Rohde, Rainer\nTelefon : (0211) 4572 - 2554\nE-Mail: rainer.rohde@fv.nrw.de\n### Uphoff, Christian\nchristian.uphoff@fv.nrw.de\n\n\\Drucker \\C0114237\\DR011226","slug":"文档/RZF-Organisation","published":1,"updated":"2019-08-22T08:39:21.000Z","_id":"cka1y595000094huuoh5kztsj","comments":1,"layout":"post","photos":[],"link":"","content":"

Kontakt

\n

Abteilung

\n
    \n
  • Verteiler “V-Krank
    \nFür Ihre Krank- bzw. Gesundmeldung sowie alle übrigen Mitteilungen zum Thema Krankheit nutzen Sie bitte den Verteiler V-Krank (V-Krank-5011@fv.nrw.de).
  • \n
  • Verteiler “V-Heimarbeitszeiten
    \nFür die Meldung der Heimarbeitszeiten nutzen Sie bitte den Verteiler V-Heimarbeitszeiten (V-Heimarbeitszeiten-5011@fv.nrw.de).
  • \n
  • Verteiler “V-Dienstreisezeiten
    \nÜber den Verteiler V-Dienstreisezeiten (V-Dienstreisezeiten-5011@fv.nrw.de) teilen Sie bitte Ihre Dienstreisezeiten, Lehrgangzeiten sowie das Ende des Dienstgeschäftes bei Dienstgängen mit. Zur Berechnung der Reisezeiten nutzen Sie bitte das im OASE-Vordruckschrank hinterlegte Berechnungsblatt (Vordruck H76 Reisezeitenberechnung).
  • \n
  • Verteiler “V-GST
    \nDen Verteiler V-GST (V-GST-5011@fv.nrw.de) verwenden Sie insbesondere für die nachfolgenden Angelegenheiten:
    \nFragen/Mitteilungen zum Thema Urlaub, Sonderurlaub, Dienstbefreiung\n
      \n
    • Mitteilung von Zeiten bei vergessenen oder fehlerhaften GLAZ-Buchungen
    • \n
    • Mitteilung über die ganztägige Kernzeitinanspruchnahme (GLAZ-Tag)
    • \n
    • alle Fragen/Mitteilungen zu den übrigen Personalangelegenheiten, die nicht über die vorgenannten Verteiler abgedeckt sind.
    • \n
    \n
  • \n
\n

Personal

\n

Rohde, Rainer

\n

Telefon : (0211) 4572 - 2554
\nE-Mail: rainer.rohde@fv.nrw.de

\n

Uphoff, Christian

\n

christian.uphoff@fv.nrw.de

\n

\\Drucker \\C0114237\\DR011226

\n","site":{"data":{}},"excerpt":"","more":"

Kontakt

\n

Abteilung

\n
    \n
  • Verteiler “V-Krank
    \nFür Ihre Krank- bzw. Gesundmeldung sowie alle übrigen Mitteilungen zum Thema Krankheit nutzen Sie bitte den Verteiler V-Krank (V-Krank-5011@fv.nrw.de).
  • \n
  • Verteiler “V-Heimarbeitszeiten
    \nFür die Meldung der Heimarbeitszeiten nutzen Sie bitte den Verteiler V-Heimarbeitszeiten (V-Heimarbeitszeiten-5011@fv.nrw.de).
  • \n
  • Verteiler “V-Dienstreisezeiten
    \nÜber den Verteiler V-Dienstreisezeiten (V-Dienstreisezeiten-5011@fv.nrw.de) teilen Sie bitte Ihre Dienstreisezeiten, Lehrgangzeiten sowie das Ende des Dienstgeschäftes bei Dienstgängen mit. Zur Berechnung der Reisezeiten nutzen Sie bitte das im OASE-Vordruckschrank hinterlegte Berechnungsblatt (Vordruck H76 Reisezeitenberechnung).
  • \n
  • Verteiler “V-GST
    \nDen Verteiler V-GST (V-GST-5011@fv.nrw.de) verwenden Sie insbesondere für die nachfolgenden Angelegenheiten:
    \nFragen/Mitteilungen zum Thema Urlaub, Sonderurlaub, Dienstbefreiung\n
      \n
    • Mitteilung von Zeiten bei vergessenen oder fehlerhaften GLAZ-Buchungen
    • \n
    • Mitteilung über die ganztägige Kernzeitinanspruchnahme (GLAZ-Tag)
    • \n
    • alle Fragen/Mitteilungen zu den übrigen Personalangelegenheiten, die nicht über die vorgenannten Verteiler abgedeckt sind.
    • \n
    \n
  • \n
\n

Personal

\n

Rohde, Rainer

\n

Telefon : (0211) 4572 - 2554
\nE-Mail: rainer.rohde@fv.nrw.de

\n

Uphoff, Christian

\n

christian.uphoff@fv.nrw.de

\n

\\Drucker \\C0114237\\DR011226

\n"},{"title":"Hello World","urlname":"hellow-world","date":"2019-06-26T15:51:03.000Z","sage":false,"notshow":true,"password":123456,"abstract":"此文章含敏感性描述。","message":"输入通用密码,查看文章。","_content":"Welcome to [Hexo](https://hexo.io/)! This is your very first post. Check [documentation](https://hexo.io/docs/) for more info. If you get any problems when using Hexo, you can find the answer in [troubleshooting](https://hexo.io/docs/troubleshooting.html) or you can ask me on [GitHub](https://github.com/hexojs/hexo/issues).\n\n## Quick Start\n\n### Create a new post\n\n``` bash\n$ hexo new \"My New Post\"\n```\n\nMore info: [Writing](https://hexo.io/docs/writing.html)\n\n### Run server\n\n``` bash\n$ hexo server\n```\n\nMore info: [Server](https://hexo.io/docs/server.html)\n\n### Generate static files\n\n``` bash\n$ hexo generate\n```\n\nMore info: [Generating](https://hexo.io/docs/generating.html)\n\n### Deploy to remote sites\n\n``` bash\n$ hexo deploy\n```\n\nMore info: [Deployment](https://hexo.io/docs/deployment.html)\n","source":"_posts/随笔/hello-world.md","raw":"---\ntitle: Hello World\nurlname: hellow-world\ndate: 2019-06-26 17:51:03\ntags: [Hexo]\ncategories: 随笔\nsage: false\nnotshow: true\npassword: 123456\nabstract: 此文章含敏感性描述。\nmessage: 输入通用密码,查看文章。\n\n---\nWelcome to [Hexo](https://hexo.io/)! This is your very first post. Check [documentation](https://hexo.io/docs/) for more info. If you get any problems when using Hexo, you can find the answer in [troubleshooting](https://hexo.io/docs/troubleshooting.html) or you can ask me on [GitHub](https://github.com/hexojs/hexo/issues).\n\n## Quick Start\n\n### Create a new post\n\n``` bash\n$ hexo new \"My New Post\"\n```\n\nMore info: [Writing](https://hexo.io/docs/writing.html)\n\n### Run server\n\n``` bash\n$ hexo server\n```\n\nMore info: [Server](https://hexo.io/docs/server.html)\n\n### Generate static files\n\n``` bash\n$ hexo generate\n```\n\nMore info: [Generating](https://hexo.io/docs/generating.html)\n\n### Deploy to remote sites\n\n``` bash\n$ hexo deploy\n```\n\nMore info: [Deployment](https://hexo.io/docs/deployment.html)\n","slug":"随笔/hello-world","published":1,"updated":"2019-07-31T03:51:35.000Z","_id":"cka1y5952000a4huuo6qb7h3o","comments":1,"layout":"post","photos":[],"link":"","content":"\n
\n
\n \n \n
\n
\n
\n
Incorrect Password!
\n
No content to display!
\n
\nU2FsdGVkX1+7TT9oNPf8Ce6TsmnuE5YQQXxozWhmsuuF8mq1PvXU4mByRPaYweIRznY6oCgPv8PipL/etOooY2bmAe5/3BxQPyniuSdeXJ0C8awHa6up+5gRmhbjHKwIyovE/4OXJCIEADUg4aMBMa9uSdqheJEgFVNyPPHF0SaFQ52G3ucPq54SmB4P4g9x3NQUTCy3LZOw3KP4fN3hEQXaitjd6Cn6Lm9AmvAzXtLiGjHUcV6IuwFqWko+akLURrPiZQDdJ6Wses5F/+F8sPMAcYdJQsn0nRpUhtggnhCysFe8FBNX9eoICJITSymRzNMIymZvJi+1q8pVPEj89QDy91U9gQwoHEy1G7bGNr4dnS+l7KWbill6olGvfwu7rJbMgUnnEiu/7B511/VkDVUSUVlggncrZ/KEU4XT8Gx4OYLgZfS7r9uNDceAq694BMF4m1dVeagck8ls2+DCVvQRe3ciyrHhrkK1ouAwMxYcf1IR8kCyyScnx4X4XIk+5P2KhjZiP+z0pb0GWxX30qVUHsQrCveU0Amhdc2F70VRUghCOo83gRWgs8HlQXaqWmTPJmrFkOuKELGTlW08UKA6RR7Wx21bZcH9k+ZVxatWfUhob3K9hZuROPfo5t/xFby5Jp035iZggzfT3J7Zj22X0WD1+mTIepPLg98r6WFGnIVadH4o1kQOSX6zUrknvBqVVm4toRD25n2RgCw0EpxpAmyyvFe6nDVqrCIpe9W4NkfYXM+yR5oclXdvAdOB9M3FFc1iizhNZzCrWNI2c+m+DGnqeKBHb5AB/cpbv0RdolELqm9KsuoE3GHMBFZp78H1ef+4SNONQVKmaiTrI2WBiGvhGYcQd8xHtq3uCDf99oREjkBDn86xTCk0KgrAg53Ijn5k0+P/PehZStsYZc5ysJxIgaANrW+hyuSwPblwsHUBUEGm/ZB84NvzgIZPYLVWqC+6ujB10CAY0M3XOGo2u8U2VZ5IAD27XMiwZC+pLJBHQFFwsO2T99xuJw1OBWF9BhslpeMtxIRByV1z/6znnolei0ZgDIPCcbEeuqJb7zeoWp70sdEZQGHI5BNOEew2uCpLJjw5uaVGZCY0uZkLYBW5XD0WlOpXbqqPIrRT/naYC3YywZCBOenymdhbRKlCHoopCccLbfgFQJqDvlVQen3fA/eqnmw37wk8j7XKHb4nKIOl1q6P2YFQ+qVNNb1qiIC66SNXqrbyNWHyhDkqFSlzcrJAcSqTVtCsVqhw42BotrpjPiJ/8Zyq4aSfnR6G+eZsznHvoGqM237/Vy/faDFZTA6d/MrkExzhwjllt1svb00ZBFyF2CNv5H9daJ1EvG+HZXhPKOVq/ryYh59UXG3ypmIvKlMXjzzMHKwLfYHeel8s8kjel7u2iGAXML5uSbaCqCmfIxAazPuKhlapElEGH2AgjNRqwLoM3BH+Nq5rgYlVQkmympCoOSgTquAx6hxsiUId+sL5nCAkGb5flhQdChPYAvlhLVVaMUesmJuUF4OqAmY4sfd5BHR2uCmdSYTaborGQtTIEhnwcpUF6qYVrwes4K8nOYXZKGk6ELLHa1IlChe70KxP6qHeQ3Xq+X4teFvbcyZ/3z6SDNhob1WLAfYb2szPGOVtdT3DEsFw7YHGhgcI5X1njL4b4Vkd3Fd98PZQdrgfZlB8QO5/YC75EgdfDFqUgaR86+9Sa6AzFlXvZscPtgPMvG6RIveULyZDflsFgCqJy9W3UiU9H9wiEb+9tPEgRlf0SZ4F0V3lqksOdj6qEv6YM4KtFF1Y+mlSocp0tCIW2PcwUcJPMB54y5NwI7Qji6FbP/SmYkHBOS2HAAKyx3dnxuoIJneAfQOT70PoXt8YVxZyPtg17hcLlORU/KqcGXZhks9VvS/4bbsM5CLH6wJUAeom/NOZZkMQgK/KAiUL4WM6bjLaMYCFx/bt6WAPYeFYFZ3wyQrAhd+EFs68+79klIdtzNYivK+j3GuIRfAF+/rhqZ6ISgQEBqD6AmlRnRsFaW8AKier61VuISlGlJ3WebWf/DViHUI5RrxNJnZDLGT6ENuGvYmzVRWOsoks3tObuimBl4G7ZZVxYNCrm+uSJQ34dh+f0rg7ckoANFDBHnZsDsIF/4doX/umiCMPufqfZIKDaJKnVzd8SdiArq9vprdrDNLYHhz+I6vM8IW3ZILl0rQFx6enT4XvVeuG1fiY30b6wzNqH21Mp6w3nSpVu0tZ82R79xr1iQn9KT+ekQCqwJNGbp9yRurcB3Myv78DEN0329B+eNUXqtc64xivaiIMOHMxOVHu6UGPryNFvA+iKrBM1a5DXyjkJwOIGzIoqf0Y8vDlB92PScUk4pVymupZ5BTBk++ziHDir/CkkALuBsJqe+Z7Ct/tvAsVUbsbJPO+4bY8W0ZK++cUh8Y32x62D2j7M1nQ4wpcxsmIPngGVsuFT41WCSF6d4u56Brz+DVdBpsiMODiXQr74zKFWubjzkSou9f11FLr2dnjhx1DrGNn1mqsx0gRBWBKtdFc849injMomeJrCUhaPwV4f3EjkMrsMi3x0MzV0xBvf2ktwNck+eTY6AQa1UvH63Cka9J7Z8DsciBgkCNkd7exgtboc6bqI7c2Ai4/HMP+hQtdYg0uie7GBbRdOVqhuR++GZL6UBrEois54aUPJxK6Xype6v7qHIf3XSH7NR5qlLIOcPE6rp7lfdhUvB9mkJ5jQ1phkJjkbZ0HcohfzhlledQb5njrA6JndP0+3eKyvwLYuZxCup92FrS6X+u/PVFkuUD/y9PNmU/RsJrRsGWt0qPSvyRIzVKFdP6tdvwkUYHdHlbe0/Y5TXcGUyB0tuNCBNsJXLZvQq+3vZ8MI8ZQW7I7zpbwcIvK/n1HEISPZF974e7CROWpAcUSKFYzoC7QF4kDDbab5mbetaWclUh7qMOt0q5orAGCMTcejIRGivHMODoq6S8eeExpVqSEwn7OTsDk02z6k7kWjANzYSpClR6RGgHJa0aFNoAbFeo83/p21XFcLL/eVCrfku5kEOfyERL/nuycdX/g/rVmgxL8Lskvql8HJAxy4bzQARWazQn9xGqLnVQGjmuTETf7A1I/IcxIdV+7ojCQxb5rLxVcUiQLOMgqb74XJzDtMgBqXkRUVnVwHPosQg8L4eYg9wgUET1jQayMzEeR+e22wvEMDvM2qz7yffFtpI4B3xRIbTsDJA==\n
\n","site":{"data":{}},"excerpt":"此文章含敏感性描述。","more":"此文章含敏感性描述。","origin":"

Welcome to Hexo! This is your very first post. Check documentation for more info. If you get any problems when using Hexo, you can find the answer in troubleshooting or you can ask me on GitHub.

\n

Quick Start

\n

Create a new post

\n\n

More info: Writing

\n

Run server

\n\n

More info: Server

\n

Generate static files

\n\n

More info: Generating

\n

Deploy to remote sites

\n\n

More info: Deployment

\n","encrypt":true,"template":"\n
\n
\n \n \n
\n
\n
\n
Incorrect Password!
\n
No content to display!
\n
\nU2FsdGVkX1+7TT9oNPf8Ce6TsmnuE5YQQXxozWhmsuuF8mq1PvXU4mByRPaYweIRznY6oCgPv8PipL/etOooY2bmAe5/3BxQPyniuSdeXJ0C8awHa6up+5gRmhbjHKwIyovE/4OXJCIEADUg4aMBMa9uSdqheJEgFVNyPPHF0SaFQ52G3ucPq54SmB4P4g9x3NQUTCy3LZOw3KP4fN3hEQXaitjd6Cn6Lm9AmvAzXtLiGjHUcV6IuwFqWko+akLURrPiZQDdJ6Wses5F/+F8sPMAcYdJQsn0nRpUhtggnhCysFe8FBNX9eoICJITSymRzNMIymZvJi+1q8pVPEj89QDy91U9gQwoHEy1G7bGNr4dnS+l7KWbill6olGvfwu7rJbMgUnnEiu/7B511/VkDVUSUVlggncrZ/KEU4XT8Gx4OYLgZfS7r9uNDceAq694BMF4m1dVeagck8ls2+DCVvQRe3ciyrHhrkK1ouAwMxYcf1IR8kCyyScnx4X4XIk+5P2KhjZiP+z0pb0GWxX30qVUHsQrCveU0Amhdc2F70VRUghCOo83gRWgs8HlQXaqWmTPJmrFkOuKELGTlW08UKA6RR7Wx21bZcH9k+ZVxatWfUhob3K9hZuROPfo5t/xFby5Jp035iZggzfT3J7Zj22X0WD1+mTIepPLg98r6WFGnIVadH4o1kQOSX6zUrknvBqVVm4toRD25n2RgCw0EpxpAmyyvFe6nDVqrCIpe9W4NkfYXM+yR5oclXdvAdOB9M3FFc1iizhNZzCrWNI2c+m+DGnqeKBHb5AB/cpbv0RdolELqm9KsuoE3GHMBFZp78H1ef+4SNONQVKmaiTrI2WBiGvhGYcQd8xHtq3uCDf99oREjkBDn86xTCk0KgrAg53Ijn5k0+P/PehZStsYZc5ysJxIgaANrW+hyuSwPblwsHUBUEGm/ZB84NvzgIZPYLVWqC+6ujB10CAY0M3XOGo2u8U2VZ5IAD27XMiwZC+pLJBHQFFwsO2T99xuJw1OBWF9BhslpeMtxIRByV1z/6znnolei0ZgDIPCcbEeuqJb7zeoWp70sdEZQGHI5BNOEew2uCpLJjw5uaVGZCY0uZkLYBW5XD0WlOpXbqqPIrRT/naYC3YywZCBOenymdhbRKlCHoopCccLbfgFQJqDvlVQen3fA/eqnmw37wk8j7XKHb4nKIOl1q6P2YFQ+qVNNb1qiIC66SNXqrbyNWHyhDkqFSlzcrJAcSqTVtCsVqhw42BotrpjPiJ/8Zyq4aSfnR6G+eZsznHvoGqM237/Vy/faDFZTA6d/MrkExzhwjllt1svb00ZBFyF2CNv5H9daJ1EvG+HZXhPKOVq/ryYh59UXG3ypmIvKlMXjzzMHKwLfYHeel8s8kjel7u2iGAXML5uSbaCqCmfIxAazPuKhlapElEGH2AgjNRqwLoM3BH+Nq5rgYlVQkmympCoOSgTquAx6hxsiUId+sL5nCAkGb5flhQdChPYAvlhLVVaMUesmJuUF4OqAmY4sfd5BHR2uCmdSYTaborGQtTIEhnwcpUF6qYVrwes4K8nOYXZKGk6ELLHa1IlChe70KxP6qHeQ3Xq+X4teFvbcyZ/3z6SDNhob1WLAfYb2szPGOVtdT3DEsFw7YHGhgcI5X1njL4b4Vkd3Fd98PZQdrgfZlB8QO5/YC75EgdfDFqUgaR86+9Sa6AzFlXvZscPtgPMvG6RIveULyZDflsFgCqJy9W3UiU9H9wiEb+9tPEgRlf0SZ4F0V3lqksOdj6qEv6YM4KtFF1Y+mlSocp0tCIW2PcwUcJPMB54y5NwI7Qji6FbP/SmYkHBOS2HAAKyx3dnxuoIJneAfQOT70PoXt8YVxZyPtg17hcLlORU/KqcGXZhks9VvS/4bbsM5CLH6wJUAeom/NOZZkMQgK/KAiUL4WM6bjLaMYCFx/bt6WAPYeFYFZ3wyQrAhd+EFs68+79klIdtzNYivK+j3GuIRfAF+/rhqZ6ISgQEBqD6AmlRnRsFaW8AKier61VuISlGlJ3WebWf/DViHUI5RrxNJnZDLGT6ENuGvYmzVRWOsoks3tObuimBl4G7ZZVxYNCrm+uSJQ34dh+f0rg7ckoANFDBHnZsDsIF/4doX/umiCMPufqfZIKDaJKnVzd8SdiArq9vprdrDNLYHhz+I6vM8IW3ZILl0rQFx6enT4XvVeuG1fiY30b6wzNqH21Mp6w3nSpVu0tZ82R79xr1iQn9KT+ekQCqwJNGbp9yRurcB3Myv78DEN0329B+eNUXqtc64xivaiIMOHMxOVHu6UGPryNFvA+iKrBM1a5DXyjkJwOIGzIoqf0Y8vDlB92PScUk4pVymupZ5BTBk++ziHDir/CkkALuBsJqe+Z7Ct/tvAsVUbsbJPO+4bY8W0ZK++cUh8Y32x62D2j7M1nQ4wpcxsmIPngGVsuFT41WCSF6d4u56Brz+DVdBpsiMODiXQr74zKFWubjzkSou9f11FLr2dnjhx1DrGNn1mqsx0gRBWBKtdFc849injMomeJrCUhaPwV4f3EjkMrsMi3x0MzV0xBvf2ktwNck+eTY6AQa1UvH63Cka9J7Z8DsciBgkCNkd7exgtboc6bqI7c2Ai4/HMP+hQtdYg0uie7GBbRdOVqhuR++GZL6UBrEois54aUPJxK6Xype6v7qHIf3XSH7NR5qlLIOcPE6rp7lfdhUvB9mkJ5jQ1phkJjkbZ0HcohfzhlledQb5njrA6JndP0+3eKyvwLYuZxCup92FrS6X+u/PVFkuUD/y9PNmU/RsJrRsGWt0qPSvyRIzVKFdP6tdvwkUYHdHlbe0/Y5TXcGUyB0tuNCBNsJXLZvQq+3vZ8MI8ZQW7I7zpbwcIvK/n1HEISPZF974e7CROWpAcUSKFYzoC7QF4kDDbab5mbetaWclUh7qMOt0q5orAGCMTcejIRGivHMODoq6S8eeExpVqSEwn7OTsDk02z6k7kWjANzYSpClR6RGgHJa0aFNoAbFeo83/p21XFcLL/eVCrfku5kEOfyERL/nuycdX/g/rVmgxL8Lskvql8HJAxy4bzQARWazQn9xGqLnVQGjmuTETf7A1I/IcxIdV+7ojCQxb5rLxVcUiQLOMgqb74XJzDtMgBqXkRUVnVwHPosQg8L4eYg9wgUET1jQayMzEeR+e22wvEMDvM2qz7yffFtpI4B3xRIbTsDJA==\n
\n","decryptionError":"Incorrect Password!","noContentError":"No content to display!"},{"title":"爱乐之城——影评","date":"2019-07-21T19:17:19.000Z","urlname":"lalaland-film","_content":"\n![ ](https://github.com/maiernte/img/raw/master/collection/lalaland.jpg)\n\n\n\n我在凌晨三点醒来的夜里,想起已失去的你,曾经说着永远一起,现在却不再联系。如果当时的我们能少一些固执,是否会有更好的结局。\n\n洛杉矶,华纳兄弟电影厂旁边的咖啡馆,明星来往不息。一身素雅的米娅是这里的收银员。她的梦想就是成为一个知名演员及编剧。所以她经常请假去试镜,跑遍大大小小的片场。虽然每次她都充满希望,但现实却是四处碰壁。这天,又一次遭受打击的米娅垂头丧气回到家中。洗去一身疲态后,她站在镜子面前暗自神伤哼起歌来 。这时室友火急火燎的出现,邀请她一起去参加派对。本来心情极度郁闷的米娅不想去凑热闹。经不住一帮二货室友的游说,精心打扮一番后她们就出发了。\n\n洛杉矶的月色下,灯红酒绿,觥筹交错。但热闹是属于他们的,安静下来后她却感到愈加落寞。人潮中充斥着过剩的荷尔蒙,但却没有她想要的一双眼睛。世界瞬息万变,她却岿然不动。逃离狂欢派对后,违规停放的车子又被拖走。米娅只能走路回家,在安静的街头上。忽然一阵悠扬的钢琴声传来,如梦似幻,温润缠绵。米娅停下脚步,来到了一个毫不起眼的地下酒吧。一个优雅的男人坐在无人注意的角落里安静的弹奏着。此刻,全世界好像都暗了下来,只有他闪着耀眼的光芒。男人名叫塞巴斯汀,是一个爵士乐钢琴师。他对音乐有着自己独特的追求,不愿弹奏靡靡之音。可一曲弹罢,没有人为他鼓掌,他也被老板炒了鱿鱼。塞巴斯汀愤愤的离开,米娅鼓起勇气迎面走过去,想要认识这个让她着迷的男人。但一句话还没说完,男人就径直的走开了。米娅扑了个空,尴尬的站在那里不知所措。\n\n生活依然按部就班,米娅依然忙着追逐她的梦想。一次派对上,米娅又遇上了塞巴斯汀。他加入了一个爵士乐队,但他们的演奏依旧没人捧场。为了惩罚这个「严肃」的音乐人,也为了报复上次给她造成的尴尬,米娅点了一首非常不严肃的音乐,她甚至随着音乐舞动起来。而塞巴斯汀却站在那里既尴尬又无奈。米娅的行为让塞巴斯汀想起了那晚的无礼。他向米娅道了歉,两人算是相识了。聚会结束后,米娅又找不到车子,于是两人在夜色下散步。洛杉矶的夜色此刻显得如此迷人,在暧昧的氛围中,他们默契地跳着属于他们的舞蹈。\n\n第二天塞巴斯汀来到米娅工作的咖啡店,下班后他们一起在片场附近的街头闲聊,塞巴斯汀鼓励米娅给自己写剧本,而不是去演别人的剧本。自己给自己创造角色,说不定会有意想不到的效果。米娅也向塞巴斯汀坦白说,她讨厌爵士乐。于是固执的塞巴斯汀就带米娅来到一个演奏爵士乐的酒吧,他试图改变米娅对爵士乐的看法,向她解释爵士乐的起源。然而米娅还是不能理解,对音乐有执念的塞巴斯汀表示,他不想让爵士乐就此消亡,他想要创建自己的俱乐部,在那里只有纯粹的爵士乐,那是他一直以来的梦想。\n\n这天又一次试镜失败的米娅心情沮丧,经过电影院门口时,她想起和塞巴斯汀的电影院之约。顿时心情变得愉悦,这时几个月不见一次的男友却来接她一起吃饭。餐桌上米娅心不在焉,男友却把她晾在一边,自顾自的和哥哥聊天。而在电影院门口的塞巴斯汀焦急的等着米娅,此时餐厅传来了熟悉的曲子,那个夜晚塞巴斯汀弹奏的正是这首曲子。米娅随即起身跑了出去,穿过色彩缤纷的霓虹灯,她找到了失落的塞巴斯汀,此时的两个人根本无心观看电影。他们指尖轻触,随后十指紧扣,接着互相靠近……但灯光却忽然打开,两人无奈的相视一笑。之后米娅带着塞巴斯汀来到天文馆,他们在浪漫的氛围中翩翩起舞,魅惑的蓝色星空下,两人仿佛和整个宇宙融为一体。\n\n金风玉露终于相逢,热恋之吻甘之如饴。随后两人一边热恋,一边为各自的梦想努力。他们一起旅行、一起恶作剧,他们走遍大街小巷,他弹琴、她跳舞,在塞巴斯汀的影响下,米娅渐渐喜欢上了爵士乐。这天早上,塞巴斯汀无意中听到了米娅和她母亲的通话。米娅的母亲对她们的未来很担忧,因为塞巴斯汀没有稳定的工作。寥寥几句话,就将塞巴斯汀从梦中拉回现实。他接受了前乐队主唱的邀请,成为了他们的键盘手。但这就意味着塞巴斯汀必须放弃自己的坚持,跟着乐队的风格走。晚上回家的米娅,听到塞巴斯汀的琴声,感受到了他失落的情绪。无需过多的话语,米娅和着琴声唱着歌,这种默契让他们心照不宣。就这样两人互相鼓励,互相安慰,塞巴斯汀的乐队开始走红。米娅也陆陆续续接到了一些大大小小的角色。看着梦想之门慢慢打开,他们也变得越来越忙碌。乐队巡演时,米娅站在台下看着万众瞩目的塞巴斯汀,喧闹的人群,闪烁的灯光,流行的爵士乐,一切看起来都那么美好……台上的男人意气风发、星光闪耀,米娅却觉得和他有了距离。晚上回到家的米娅得到了一个大大的惊喜。忙碌的他们很久都没有见面了,塞巴斯汀明天一早又要离开,他想要让米娅跟他一起,米娅却问他喜不喜欢现在弹奏的音乐?但此时的塞巴斯汀已经尝到了名利带来的甜头,他放弃了曾经的梦想,也放弃了曾经的坚持。他以为这些是米娅想要的:稳定的生活,不菲的收入,以及聚少离多的爱情。他说以前那些梦想太虚无缥缈,现在他需要成熟起来。最后激动的塞巴斯汀对米娅说,你喜欢以前不堪的我,是因为相比而言,那会让你感觉自我良好。这句伤人的话使得他们关系僵化,接着米娅一声不响的离开。第二天在给乐队拍宣传片的时候,摄影师让塞巴斯汀随便弹,于是他弹起了熟悉的曲子,接着他似乎想起了什么……再一次试镜被嘲笑后,米娅心情降至冰点。她准备返回老家,这个城市再没什么值得她留恋,梦想也好,爱人也罢,终究只是一场梦。面对挽留的塞巴斯汀,她再也无法忍受,哭着说她受够了。米娅回到了自己的家,塞巴斯汀也回到了乐队。\n\n一段时间后,塞巴斯汀出现在了米娅家门口。一个知名导演正在选角,试镜电话打给了塞巴斯汀,在塞巴斯汀的鼓励下,米娅鼓起勇气决定再试一次。导演让米娅随便讲一个故事,于是她用歌声讲述了自己的梦想。面试过后,他们来到天文馆门口,一起谈论着对未来的打算。他说你的梦想一定会实现的。秋天的洛杉矶,纯净而理性。他们的感情在这里开始,也在这里结束……\n\n五年后米娅成了知名演员,实现了自己的梦想。她事业有成,结婚生子,生活安稳,家庭美满。晚上米娅和丈夫遭遇堵车,路边散步时发现了一个酒吧。热闹的气氛吸引了米娅的注意,这正是当年塞巴斯汀带她去的酒吧。米娅发现酒吧的名字是她多年前为塞巴斯汀取的。这里只有纯粹的爵士乐,塞巴斯汀的梦想就是拥有这样一个地方。落坐以后,塞巴斯汀看到了台下的米娅,沉默片刻后,他弹起了那首熟悉的音乐。\n***\n*就像最初他们相见时那样,他们忘记了全世界。那个夜晚,那次初见,时间仿佛从未流逝。但这次不等她说完一句话,他就热烈的吻上了她唇。他毫无顾忌,她毫无防备,他们痴迷于彼此的味道。他们翩翩起舞,一路走向梦想,走进热恋,相互陪伴,相互成全,一起成长,一起狂欢。然后携手走进那片星空。他眼神温柔,她身姿婀娜。他们打造着自己的小窝,享受着二人世界。爱的结晶来到他们身边,放佛那些美好是和他一起度过的。直到今天这个夜晚,他们始终如一,此志不渝。*\n\n___\n曲终之后,她被拉回现实,然后和丈夫一起离开。在拐角处她转身,回头,两人遥遥相望,然后互相报以微笑。时隔经年,若我遇见你,我该如何与你致意?以眼泪,以沉默!\n\n我一同学特别喜欢这部电影,我知道那是因为她在电影中看到了自己。她的挚爱,七年长跑,可终究还是没能走到一起。或许这就是所谓的「在别人的故事里,流着自己的眼泪」。你是否也在无人的深夜,想起某个人,然后哭着醒来。看着周围的一切,熟悉又陌生,那个藏在心里的人啊,此时你身在哪里?可知有人还在深爱着你。虽然思念依然刻骨铭心,但你们之间却只剩下曾经。最怕的莫过于,在寂静无声的日子里,莫名其妙的,突然听懂了一首歌,只是你听到的不再是歌曲,而是人生。\n\n**「初识不知曲中意,再听已是曲中人」**……就像是做了一场梦,醒来之时万籁俱寂,物是人非事事休,欲语泪先流……年少时我们总想给最爱的TA更多,却忽略了TA最想要的只是真实的你。后来的我们什么都有了,但却没了我们。我还是我,你还是你,我们却不再是我们。……于是你只能在某个深夜,听着歌,流着泪,然后默默的在心里对那个人说,今夜,我不关心世界,今夜,我只想你。\n\n","source":"_posts/摘录/爱乐之城——影评.md","raw":"---\ntitle: 爱乐之城——影评\ndate: 2019-07-21 21:17:19\nurlname: lalaland-film\ntags: [影视]\ncategories: 摘录\n\n---\n\n![ ](https://github.com/maiernte/img/raw/master/collection/lalaland.jpg)\n\n\n\n我在凌晨三点醒来的夜里,想起已失去的你,曾经说着永远一起,现在却不再联系。如果当时的我们能少一些固执,是否会有更好的结局。\n\n洛杉矶,华纳兄弟电影厂旁边的咖啡馆,明星来往不息。一身素雅的米娅是这里的收银员。她的梦想就是成为一个知名演员及编剧。所以她经常请假去试镜,跑遍大大小小的片场。虽然每次她都充满希望,但现实却是四处碰壁。这天,又一次遭受打击的米娅垂头丧气回到家中。洗去一身疲态后,她站在镜子面前暗自神伤哼起歌来 。这时室友火急火燎的出现,邀请她一起去参加派对。本来心情极度郁闷的米娅不想去凑热闹。经不住一帮二货室友的游说,精心打扮一番后她们就出发了。\n\n洛杉矶的月色下,灯红酒绿,觥筹交错。但热闹是属于他们的,安静下来后她却感到愈加落寞。人潮中充斥着过剩的荷尔蒙,但却没有她想要的一双眼睛。世界瞬息万变,她却岿然不动。逃离狂欢派对后,违规停放的车子又被拖走。米娅只能走路回家,在安静的街头上。忽然一阵悠扬的钢琴声传来,如梦似幻,温润缠绵。米娅停下脚步,来到了一个毫不起眼的地下酒吧。一个优雅的男人坐在无人注意的角落里安静的弹奏着。此刻,全世界好像都暗了下来,只有他闪着耀眼的光芒。男人名叫塞巴斯汀,是一个爵士乐钢琴师。他对音乐有着自己独特的追求,不愿弹奏靡靡之音。可一曲弹罢,没有人为他鼓掌,他也被老板炒了鱿鱼。塞巴斯汀愤愤的离开,米娅鼓起勇气迎面走过去,想要认识这个让她着迷的男人。但一句话还没说完,男人就径直的走开了。米娅扑了个空,尴尬的站在那里不知所措。\n\n生活依然按部就班,米娅依然忙着追逐她的梦想。一次派对上,米娅又遇上了塞巴斯汀。他加入了一个爵士乐队,但他们的演奏依旧没人捧场。为了惩罚这个「严肃」的音乐人,也为了报复上次给她造成的尴尬,米娅点了一首非常不严肃的音乐,她甚至随着音乐舞动起来。而塞巴斯汀却站在那里既尴尬又无奈。米娅的行为让塞巴斯汀想起了那晚的无礼。他向米娅道了歉,两人算是相识了。聚会结束后,米娅又找不到车子,于是两人在夜色下散步。洛杉矶的夜色此刻显得如此迷人,在暧昧的氛围中,他们默契地跳着属于他们的舞蹈。\n\n第二天塞巴斯汀来到米娅工作的咖啡店,下班后他们一起在片场附近的街头闲聊,塞巴斯汀鼓励米娅给自己写剧本,而不是去演别人的剧本。自己给自己创造角色,说不定会有意想不到的效果。米娅也向塞巴斯汀坦白说,她讨厌爵士乐。于是固执的塞巴斯汀就带米娅来到一个演奏爵士乐的酒吧,他试图改变米娅对爵士乐的看法,向她解释爵士乐的起源。然而米娅还是不能理解,对音乐有执念的塞巴斯汀表示,他不想让爵士乐就此消亡,他想要创建自己的俱乐部,在那里只有纯粹的爵士乐,那是他一直以来的梦想。\n\n这天又一次试镜失败的米娅心情沮丧,经过电影院门口时,她想起和塞巴斯汀的电影院之约。顿时心情变得愉悦,这时几个月不见一次的男友却来接她一起吃饭。餐桌上米娅心不在焉,男友却把她晾在一边,自顾自的和哥哥聊天。而在电影院门口的塞巴斯汀焦急的等着米娅,此时餐厅传来了熟悉的曲子,那个夜晚塞巴斯汀弹奏的正是这首曲子。米娅随即起身跑了出去,穿过色彩缤纷的霓虹灯,她找到了失落的塞巴斯汀,此时的两个人根本无心观看电影。他们指尖轻触,随后十指紧扣,接着互相靠近……但灯光却忽然打开,两人无奈的相视一笑。之后米娅带着塞巴斯汀来到天文馆,他们在浪漫的氛围中翩翩起舞,魅惑的蓝色星空下,两人仿佛和整个宇宙融为一体。\n\n金风玉露终于相逢,热恋之吻甘之如饴。随后两人一边热恋,一边为各自的梦想努力。他们一起旅行、一起恶作剧,他们走遍大街小巷,他弹琴、她跳舞,在塞巴斯汀的影响下,米娅渐渐喜欢上了爵士乐。这天早上,塞巴斯汀无意中听到了米娅和她母亲的通话。米娅的母亲对她们的未来很担忧,因为塞巴斯汀没有稳定的工作。寥寥几句话,就将塞巴斯汀从梦中拉回现实。他接受了前乐队主唱的邀请,成为了他们的键盘手。但这就意味着塞巴斯汀必须放弃自己的坚持,跟着乐队的风格走。晚上回家的米娅,听到塞巴斯汀的琴声,感受到了他失落的情绪。无需过多的话语,米娅和着琴声唱着歌,这种默契让他们心照不宣。就这样两人互相鼓励,互相安慰,塞巴斯汀的乐队开始走红。米娅也陆陆续续接到了一些大大小小的角色。看着梦想之门慢慢打开,他们也变得越来越忙碌。乐队巡演时,米娅站在台下看着万众瞩目的塞巴斯汀,喧闹的人群,闪烁的灯光,流行的爵士乐,一切看起来都那么美好……台上的男人意气风发、星光闪耀,米娅却觉得和他有了距离。晚上回到家的米娅得到了一个大大的惊喜。忙碌的他们很久都没有见面了,塞巴斯汀明天一早又要离开,他想要让米娅跟他一起,米娅却问他喜不喜欢现在弹奏的音乐?但此时的塞巴斯汀已经尝到了名利带来的甜头,他放弃了曾经的梦想,也放弃了曾经的坚持。他以为这些是米娅想要的:稳定的生活,不菲的收入,以及聚少离多的爱情。他说以前那些梦想太虚无缥缈,现在他需要成熟起来。最后激动的塞巴斯汀对米娅说,你喜欢以前不堪的我,是因为相比而言,那会让你感觉自我良好。这句伤人的话使得他们关系僵化,接着米娅一声不响的离开。第二天在给乐队拍宣传片的时候,摄影师让塞巴斯汀随便弹,于是他弹起了熟悉的曲子,接着他似乎想起了什么……再一次试镜被嘲笑后,米娅心情降至冰点。她准备返回老家,这个城市再没什么值得她留恋,梦想也好,爱人也罢,终究只是一场梦。面对挽留的塞巴斯汀,她再也无法忍受,哭着说她受够了。米娅回到了自己的家,塞巴斯汀也回到了乐队。\n\n一段时间后,塞巴斯汀出现在了米娅家门口。一个知名导演正在选角,试镜电话打给了塞巴斯汀,在塞巴斯汀的鼓励下,米娅鼓起勇气决定再试一次。导演让米娅随便讲一个故事,于是她用歌声讲述了自己的梦想。面试过后,他们来到天文馆门口,一起谈论着对未来的打算。他说你的梦想一定会实现的。秋天的洛杉矶,纯净而理性。他们的感情在这里开始,也在这里结束……\n\n五年后米娅成了知名演员,实现了自己的梦想。她事业有成,结婚生子,生活安稳,家庭美满。晚上米娅和丈夫遭遇堵车,路边散步时发现了一个酒吧。热闹的气氛吸引了米娅的注意,这正是当年塞巴斯汀带她去的酒吧。米娅发现酒吧的名字是她多年前为塞巴斯汀取的。这里只有纯粹的爵士乐,塞巴斯汀的梦想就是拥有这样一个地方。落坐以后,塞巴斯汀看到了台下的米娅,沉默片刻后,他弹起了那首熟悉的音乐。\n***\n*就像最初他们相见时那样,他们忘记了全世界。那个夜晚,那次初见,时间仿佛从未流逝。但这次不等她说完一句话,他就热烈的吻上了她唇。他毫无顾忌,她毫无防备,他们痴迷于彼此的味道。他们翩翩起舞,一路走向梦想,走进热恋,相互陪伴,相互成全,一起成长,一起狂欢。然后携手走进那片星空。他眼神温柔,她身姿婀娜。他们打造着自己的小窝,享受着二人世界。爱的结晶来到他们身边,放佛那些美好是和他一起度过的。直到今天这个夜晚,他们始终如一,此志不渝。*\n\n___\n曲终之后,她被拉回现实,然后和丈夫一起离开。在拐角处她转身,回头,两人遥遥相望,然后互相报以微笑。时隔经年,若我遇见你,我该如何与你致意?以眼泪,以沉默!\n\n我一同学特别喜欢这部电影,我知道那是因为她在电影中看到了自己。她的挚爱,七年长跑,可终究还是没能走到一起。或许这就是所谓的「在别人的故事里,流着自己的眼泪」。你是否也在无人的深夜,想起某个人,然后哭着醒来。看着周围的一切,熟悉又陌生,那个藏在心里的人啊,此时你身在哪里?可知有人还在深爱着你。虽然思念依然刻骨铭心,但你们之间却只剩下曾经。最怕的莫过于,在寂静无声的日子里,莫名其妙的,突然听懂了一首歌,只是你听到的不再是歌曲,而是人生。\n\n**「初识不知曲中意,再听已是曲中人」**……就像是做了一场梦,醒来之时万籁俱寂,物是人非事事休,欲语泪先流……年少时我们总想给最爱的TA更多,却忽略了TA最想要的只是真实的你。后来的我们什么都有了,但却没了我们。我还是我,你还是你,我们却不再是我们。……于是你只能在某个深夜,听着歌,流着泪,然后默默的在心里对那个人说,今夜,我不关心世界,今夜,我只想你。\n\n","slug":"摘录/爱乐之城——影评","published":1,"updated":"2019-08-14T06:31:50.000Z","_id":"cka1y596d000s4huu6s41uv14","comments":1,"layout":"post","photos":[],"link":"","content":"

\"

\n\n

我在凌晨三点醒来的夜里,想起已失去的你,曾经说着永远一起,现在却不再联系。如果当时的我们能少一些固执,是否会有更好的结局。

\n

洛杉矶,华纳兄弟电影厂旁边的咖啡馆,明星来往不息。一身素雅的米娅是这里的收银员。她的梦想就是成为一个知名演员及编剧。所以她经常请假去试镜,跑遍大大小小的片场。虽然每次她都充满希望,但现实却是四处碰壁。这天,又一次遭受打击的米娅垂头丧气回到家中。洗去一身疲态后,她站在镜子面前暗自神伤哼起歌来 。这时室友火急火燎的出现,邀请她一起去参加派对。本来心情极度郁闷的米娅不想去凑热闹。经不住一帮二货室友的游说,精心打扮一番后她们就出发了。

\n

洛杉矶的月色下,灯红酒绿,觥筹交错。但热闹是属于他们的,安静下来后她却感到愈加落寞。人潮中充斥着过剩的荷尔蒙,但却没有她想要的一双眼睛。世界瞬息万变,她却岿然不动。逃离狂欢派对后,违规停放的车子又被拖走。米娅只能走路回家,在安静的街头上。忽然一阵悠扬的钢琴声传来,如梦似幻,温润缠绵。米娅停下脚步,来到了一个毫不起眼的地下酒吧。一个优雅的男人坐在无人注意的角落里安静的弹奏着。此刻,全世界好像都暗了下来,只有他闪着耀眼的光芒。男人名叫塞巴斯汀,是一个爵士乐钢琴师。他对音乐有着自己独特的追求,不愿弹奏靡靡之音。可一曲弹罢,没有人为他鼓掌,他也被老板炒了鱿鱼。塞巴斯汀愤愤的离开,米娅鼓起勇气迎面走过去,想要认识这个让她着迷的男人。但一句话还没说完,男人就径直的走开了。米娅扑了个空,尴尬的站在那里不知所措。

\n

生活依然按部就班,米娅依然忙着追逐她的梦想。一次派对上,米娅又遇上了塞巴斯汀。他加入了一个爵士乐队,但他们的演奏依旧没人捧场。为了惩罚这个「严肃」的音乐人,也为了报复上次给她造成的尴尬,米娅点了一首非常不严肃的音乐,她甚至随着音乐舞动起来。而塞巴斯汀却站在那里既尴尬又无奈。米娅的行为让塞巴斯汀想起了那晚的无礼。他向米娅道了歉,两人算是相识了。聚会结束后,米娅又找不到车子,于是两人在夜色下散步。洛杉矶的夜色此刻显得如此迷人,在暧昧的氛围中,他们默契地跳着属于他们的舞蹈。

\n

第二天塞巴斯汀来到米娅工作的咖啡店,下班后他们一起在片场附近的街头闲聊,塞巴斯汀鼓励米娅给自己写剧本,而不是去演别人的剧本。自己给自己创造角色,说不定会有意想不到的效果。米娅也向塞巴斯汀坦白说,她讨厌爵士乐。于是固执的塞巴斯汀就带米娅来到一个演奏爵士乐的酒吧,他试图改变米娅对爵士乐的看法,向她解释爵士乐的起源。然而米娅还是不能理解,对音乐有执念的塞巴斯汀表示,他不想让爵士乐就此消亡,他想要创建自己的俱乐部,在那里只有纯粹的爵士乐,那是他一直以来的梦想。

\n

这天又一次试镜失败的米娅心情沮丧,经过电影院门口时,她想起和塞巴斯汀的电影院之约。顿时心情变得愉悦,这时几个月不见一次的男友却来接她一起吃饭。餐桌上米娅心不在焉,男友却把她晾在一边,自顾自的和哥哥聊天。而在电影院门口的塞巴斯汀焦急的等着米娅,此时餐厅传来了熟悉的曲子,那个夜晚塞巴斯汀弹奏的正是这首曲子。米娅随即起身跑了出去,穿过色彩缤纷的霓虹灯,她找到了失落的塞巴斯汀,此时的两个人根本无心观看电影。他们指尖轻触,随后十指紧扣,接着互相靠近……但灯光却忽然打开,两人无奈的相视一笑。之后米娅带着塞巴斯汀来到天文馆,他们在浪漫的氛围中翩翩起舞,魅惑的蓝色星空下,两人仿佛和整个宇宙融为一体。

\n

金风玉露终于相逢,热恋之吻甘之如饴。随后两人一边热恋,一边为各自的梦想努力。他们一起旅行、一起恶作剧,他们走遍大街小巷,他弹琴、她跳舞,在塞巴斯汀的影响下,米娅渐渐喜欢上了爵士乐。这天早上,塞巴斯汀无意中听到了米娅和她母亲的通话。米娅的母亲对她们的未来很担忧,因为塞巴斯汀没有稳定的工作。寥寥几句话,就将塞巴斯汀从梦中拉回现实。他接受了前乐队主唱的邀请,成为了他们的键盘手。但这就意味着塞巴斯汀必须放弃自己的坚持,跟着乐队的风格走。晚上回家的米娅,听到塞巴斯汀的琴声,感受到了他失落的情绪。无需过多的话语,米娅和着琴声唱着歌,这种默契让他们心照不宣。就这样两人互相鼓励,互相安慰,塞巴斯汀的乐队开始走红。米娅也陆陆续续接到了一些大大小小的角色。看着梦想之门慢慢打开,他们也变得越来越忙碌。乐队巡演时,米娅站在台下看着万众瞩目的塞巴斯汀,喧闹的人群,闪烁的灯光,流行的爵士乐,一切看起来都那么美好……台上的男人意气风发、星光闪耀,米娅却觉得和他有了距离。晚上回到家的米娅得到了一个大大的惊喜。忙碌的他们很久都没有见面了,塞巴斯汀明天一早又要离开,他想要让米娅跟他一起,米娅却问他喜不喜欢现在弹奏的音乐?但此时的塞巴斯汀已经尝到了名利带来的甜头,他放弃了曾经的梦想,也放弃了曾经的坚持。他以为这些是米娅想要的:稳定的生活,不菲的收入,以及聚少离多的爱情。他说以前那些梦想太虚无缥缈,现在他需要成熟起来。最后激动的塞巴斯汀对米娅说,你喜欢以前不堪的我,是因为相比而言,那会让你感觉自我良好。这句伤人的话使得他们关系僵化,接着米娅一声不响的离开。第二天在给乐队拍宣传片的时候,摄影师让塞巴斯汀随便弹,于是他弹起了熟悉的曲子,接着他似乎想起了什么……再一次试镜被嘲笑后,米娅心情降至冰点。她准备返回老家,这个城市再没什么值得她留恋,梦想也好,爱人也罢,终究只是一场梦。面对挽留的塞巴斯汀,她再也无法忍受,哭着说她受够了。米娅回到了自己的家,塞巴斯汀也回到了乐队。

\n

一段时间后,塞巴斯汀出现在了米娅家门口。一个知名导演正在选角,试镜电话打给了塞巴斯汀,在塞巴斯汀的鼓励下,米娅鼓起勇气决定再试一次。导演让米娅随便讲一个故事,于是她用歌声讲述了自己的梦想。面试过后,他们来到天文馆门口,一起谈论着对未来的打算。他说你的梦想一定会实现的。秋天的洛杉矶,纯净而理性。他们的感情在这里开始,也在这里结束……

\n

五年后米娅成了知名演员,实现了自己的梦想。她事业有成,结婚生子,生活安稳,家庭美满。晚上米娅和丈夫遭遇堵车,路边散步时发现了一个酒吧。热闹的气氛吸引了米娅的注意,这正是当年塞巴斯汀带她去的酒吧。米娅发现酒吧的名字是她多年前为塞巴斯汀取的。这里只有纯粹的爵士乐,塞巴斯汀的梦想就是拥有这样一个地方。落坐以后,塞巴斯汀看到了台下的米娅,沉默片刻后,他弹起了那首熟悉的音乐。

\n
\n

就像最初他们相见时那样,他们忘记了全世界。那个夜晚,那次初见,时间仿佛从未流逝。但这次不等她说完一句话,他就热烈的吻上了她唇。他毫无顾忌,她毫无防备,他们痴迷于彼此的味道。他们翩翩起舞,一路走向梦想,走进热恋,相互陪伴,相互成全,一起成长,一起狂欢。然后携手走进那片星空。他眼神温柔,她身姿婀娜。他们打造着自己的小窝,享受着二人世界。爱的结晶来到他们身边,放佛那些美好是和他一起度过的。直到今天这个夜晚,他们始终如一,此志不渝。

\n
\n

曲终之后,她被拉回现实,然后和丈夫一起离开。在拐角处她转身,回头,两人遥遥相望,然后互相报以微笑。时隔经年,若我遇见你,我该如何与你致意?以眼泪,以沉默!

\n

我一同学特别喜欢这部电影,我知道那是因为她在电影中看到了自己。她的挚爱,七年长跑,可终究还是没能走到一起。或许这就是所谓的「在别人的故事里,流着自己的眼泪」。你是否也在无人的深夜,想起某个人,然后哭着醒来。看着周围的一切,熟悉又陌生,那个藏在心里的人啊,此时你身在哪里?可知有人还在深爱着你。虽然思念依然刻骨铭心,但你们之间却只剩下曾经。最怕的莫过于,在寂静无声的日子里,莫名其妙的,突然听懂了一首歌,只是你听到的不再是歌曲,而是人生。

\n

「初识不知曲中意,再听已是曲中人」……就像是做了一场梦,醒来之时万籁俱寂,物是人非事事休,欲语泪先流……年少时我们总想给最爱的TA更多,却忽略了TA最想要的只是真实的你。后来的我们什么都有了,但却没了我们。我还是我,你还是你,我们却不再是我们。……于是你只能在某个深夜,听着歌,流着泪,然后默默的在心里对那个人说,今夜,我不关心世界,今夜,我只想你。

\n","site":{"data":{}},"excerpt":"

\"

","more":"

我在凌晨三点醒来的夜里,想起已失去的你,曾经说着永远一起,现在却不再联系。如果当时的我们能少一些固执,是否会有更好的结局。

\n

洛杉矶,华纳兄弟电影厂旁边的咖啡馆,明星来往不息。一身素雅的米娅是这里的收银员。她的梦想就是成为一个知名演员及编剧。所以她经常请假去试镜,跑遍大大小小的片场。虽然每次她都充满希望,但现实却是四处碰壁。这天,又一次遭受打击的米娅垂头丧气回到家中。洗去一身疲态后,她站在镜子面前暗自神伤哼起歌来 。这时室友火急火燎的出现,邀请她一起去参加派对。本来心情极度郁闷的米娅不想去凑热闹。经不住一帮二货室友的游说,精心打扮一番后她们就出发了。

\n

洛杉矶的月色下,灯红酒绿,觥筹交错。但热闹是属于他们的,安静下来后她却感到愈加落寞。人潮中充斥着过剩的荷尔蒙,但却没有她想要的一双眼睛。世界瞬息万变,她却岿然不动。逃离狂欢派对后,违规停放的车子又被拖走。米娅只能走路回家,在安静的街头上。忽然一阵悠扬的钢琴声传来,如梦似幻,温润缠绵。米娅停下脚步,来到了一个毫不起眼的地下酒吧。一个优雅的男人坐在无人注意的角落里安静的弹奏着。此刻,全世界好像都暗了下来,只有他闪着耀眼的光芒。男人名叫塞巴斯汀,是一个爵士乐钢琴师。他对音乐有着自己独特的追求,不愿弹奏靡靡之音。可一曲弹罢,没有人为他鼓掌,他也被老板炒了鱿鱼。塞巴斯汀愤愤的离开,米娅鼓起勇气迎面走过去,想要认识这个让她着迷的男人。但一句话还没说完,男人就径直的走开了。米娅扑了个空,尴尬的站在那里不知所措。

\n

生活依然按部就班,米娅依然忙着追逐她的梦想。一次派对上,米娅又遇上了塞巴斯汀。他加入了一个爵士乐队,但他们的演奏依旧没人捧场。为了惩罚这个「严肃」的音乐人,也为了报复上次给她造成的尴尬,米娅点了一首非常不严肃的音乐,她甚至随着音乐舞动起来。而塞巴斯汀却站在那里既尴尬又无奈。米娅的行为让塞巴斯汀想起了那晚的无礼。他向米娅道了歉,两人算是相识了。聚会结束后,米娅又找不到车子,于是两人在夜色下散步。洛杉矶的夜色此刻显得如此迷人,在暧昧的氛围中,他们默契地跳着属于他们的舞蹈。

\n

第二天塞巴斯汀来到米娅工作的咖啡店,下班后他们一起在片场附近的街头闲聊,塞巴斯汀鼓励米娅给自己写剧本,而不是去演别人的剧本。自己给自己创造角色,说不定会有意想不到的效果。米娅也向塞巴斯汀坦白说,她讨厌爵士乐。于是固执的塞巴斯汀就带米娅来到一个演奏爵士乐的酒吧,他试图改变米娅对爵士乐的看法,向她解释爵士乐的起源。然而米娅还是不能理解,对音乐有执念的塞巴斯汀表示,他不想让爵士乐就此消亡,他想要创建自己的俱乐部,在那里只有纯粹的爵士乐,那是他一直以来的梦想。

\n

这天又一次试镜失败的米娅心情沮丧,经过电影院门口时,她想起和塞巴斯汀的电影院之约。顿时心情变得愉悦,这时几个月不见一次的男友却来接她一起吃饭。餐桌上米娅心不在焉,男友却把她晾在一边,自顾自的和哥哥聊天。而在电影院门口的塞巴斯汀焦急的等着米娅,此时餐厅传来了熟悉的曲子,那个夜晚塞巴斯汀弹奏的正是这首曲子。米娅随即起身跑了出去,穿过色彩缤纷的霓虹灯,她找到了失落的塞巴斯汀,此时的两个人根本无心观看电影。他们指尖轻触,随后十指紧扣,接着互相靠近……但灯光却忽然打开,两人无奈的相视一笑。之后米娅带着塞巴斯汀来到天文馆,他们在浪漫的氛围中翩翩起舞,魅惑的蓝色星空下,两人仿佛和整个宇宙融为一体。

\n

金风玉露终于相逢,热恋之吻甘之如饴。随后两人一边热恋,一边为各自的梦想努力。他们一起旅行、一起恶作剧,他们走遍大街小巷,他弹琴、她跳舞,在塞巴斯汀的影响下,米娅渐渐喜欢上了爵士乐。这天早上,塞巴斯汀无意中听到了米娅和她母亲的通话。米娅的母亲对她们的未来很担忧,因为塞巴斯汀没有稳定的工作。寥寥几句话,就将塞巴斯汀从梦中拉回现实。他接受了前乐队主唱的邀请,成为了他们的键盘手。但这就意味着塞巴斯汀必须放弃自己的坚持,跟着乐队的风格走。晚上回家的米娅,听到塞巴斯汀的琴声,感受到了他失落的情绪。无需过多的话语,米娅和着琴声唱着歌,这种默契让他们心照不宣。就这样两人互相鼓励,互相安慰,塞巴斯汀的乐队开始走红。米娅也陆陆续续接到了一些大大小小的角色。看着梦想之门慢慢打开,他们也变得越来越忙碌。乐队巡演时,米娅站在台下看着万众瞩目的塞巴斯汀,喧闹的人群,闪烁的灯光,流行的爵士乐,一切看起来都那么美好……台上的男人意气风发、星光闪耀,米娅却觉得和他有了距离。晚上回到家的米娅得到了一个大大的惊喜。忙碌的他们很久都没有见面了,塞巴斯汀明天一早又要离开,他想要让米娅跟他一起,米娅却问他喜不喜欢现在弹奏的音乐?但此时的塞巴斯汀已经尝到了名利带来的甜头,他放弃了曾经的梦想,也放弃了曾经的坚持。他以为这些是米娅想要的:稳定的生活,不菲的收入,以及聚少离多的爱情。他说以前那些梦想太虚无缥缈,现在他需要成熟起来。最后激动的塞巴斯汀对米娅说,你喜欢以前不堪的我,是因为相比而言,那会让你感觉自我良好。这句伤人的话使得他们关系僵化,接着米娅一声不响的离开。第二天在给乐队拍宣传片的时候,摄影师让塞巴斯汀随便弹,于是他弹起了熟悉的曲子,接着他似乎想起了什么……再一次试镜被嘲笑后,米娅心情降至冰点。她准备返回老家,这个城市再没什么值得她留恋,梦想也好,爱人也罢,终究只是一场梦。面对挽留的塞巴斯汀,她再也无法忍受,哭着说她受够了。米娅回到了自己的家,塞巴斯汀也回到了乐队。

\n

一段时间后,塞巴斯汀出现在了米娅家门口。一个知名导演正在选角,试镜电话打给了塞巴斯汀,在塞巴斯汀的鼓励下,米娅鼓起勇气决定再试一次。导演让米娅随便讲一个故事,于是她用歌声讲述了自己的梦想。面试过后,他们来到天文馆门口,一起谈论着对未来的打算。他说你的梦想一定会实现的。秋天的洛杉矶,纯净而理性。他们的感情在这里开始,也在这里结束……

\n

五年后米娅成了知名演员,实现了自己的梦想。她事业有成,结婚生子,生活安稳,家庭美满。晚上米娅和丈夫遭遇堵车,路边散步时发现了一个酒吧。热闹的气氛吸引了米娅的注意,这正是当年塞巴斯汀带她去的酒吧。米娅发现酒吧的名字是她多年前为塞巴斯汀取的。这里只有纯粹的爵士乐,塞巴斯汀的梦想就是拥有这样一个地方。落坐以后,塞巴斯汀看到了台下的米娅,沉默片刻后,他弹起了那首熟悉的音乐。

\n
\n

就像最初他们相见时那样,他们忘记了全世界。那个夜晚,那次初见,时间仿佛从未流逝。但这次不等她说完一句话,他就热烈的吻上了她唇。他毫无顾忌,她毫无防备,他们痴迷于彼此的味道。他们翩翩起舞,一路走向梦想,走进热恋,相互陪伴,相互成全,一起成长,一起狂欢。然后携手走进那片星空。他眼神温柔,她身姿婀娜。他们打造着自己的小窝,享受着二人世界。爱的结晶来到他们身边,放佛那些美好是和他一起度过的。直到今天这个夜晚,他们始终如一,此志不渝。

\n
\n

曲终之后,她被拉回现实,然后和丈夫一起离开。在拐角处她转身,回头,两人遥遥相望,然后互相报以微笑。时隔经年,若我遇见你,我该如何与你致意?以眼泪,以沉默!

\n

我一同学特别喜欢这部电影,我知道那是因为她在电影中看到了自己。她的挚爱,七年长跑,可终究还是没能走到一起。或许这就是所谓的「在别人的故事里,流着自己的眼泪」。你是否也在无人的深夜,想起某个人,然后哭着醒来。看着周围的一切,熟悉又陌生,那个藏在心里的人啊,此时你身在哪里?可知有人还在深爱着你。虽然思念依然刻骨铭心,但你们之间却只剩下曾经。最怕的莫过于,在寂静无声的日子里,莫名其妙的,突然听懂了一首歌,只是你听到的不再是歌曲,而是人生。

\n

「初识不知曲中意,再听已是曲中人」……就像是做了一场梦,醒来之时万籁俱寂,物是人非事事休,欲语泪先流……年少时我们总想给最爱的TA更多,却忽略了TA最想要的只是真实的你。后来的我们什么都有了,但却没了我们。我还是我,你还是你,我们却不再是我们。……于是你只能在某个深夜,听着歌,流着泪,然后默默的在心里对那个人说,今夜,我不关心世界,今夜,我只想你。

"},{"title":"财富自由之路-李笑来","date":"2019-07-21T07:05:22.000Z","urlname":"road-to-asset-freedom","toc":true,"contentpw":123456,"_content":"\n\n![图片来自七牛](https://github.com/maiernte/img/raw/master/collection/photo.jpg)\n\n\n\n\n\n进度:10课\n\n# 哲学层面\n\n## 金钱、时间、注意力\n\n钱不是最重要,它可以再生。时间也不是,它本质上不属于你,你只能试着与它做朋友。注意力是自己可以做主的。**必须把宝贵的注意力全部放在自己身上**。放在自己的哪儿上?答:“**成长**”。不珍惜自己注意力的人最终注定是贫穷的,因为他们终生被收割,不可能有真正有价值的产出,怎么可能最终变得富有?另外,要放在自己的**真爱**上,以及对整个社会真正**有贡献**的事情上。(对于后两者,关注的焦点还是“成长”。)\n\n\n\n注意力才是你人生最宝贵的财富(不是金钱和时间),你的一切价值都是你的注意力的产出。\n\n> 俗三个大坑:1. 莫名其妙的凑热闹。2. 心急火燎的随大流。3. 操碎了别人的心 (*万众创业关你屁事,干好自己的活*)。\n\n\n\n金钱、时间和注意力的比较:$ 注意力 > 时间 > 金钱 $\n\n- 凡是可以用钱买的其实都是便宜的。\n\n- 凡是能用钱买来的时间就是便宜的。\n\n- 凡是能用时间换来的注意力持续就是有价值的。\n\n\n\n:question: 时间和金钱谁更重要。\n\n> 答案是`时间`。因为财富自由的定义就是“*不为生活需要出售时间*”。另外一个角度是,“*花钱买你的时间更划算*”。\n\n\n\n:question: 注意力和时间更重要。\n\n> 注意力是能让你有所产出的唯一资源!而时间不一定是你的,时间不会自动产出。(李笑来: 花大量时间与老婆沟通,陪伴,以便换来自己集中注意力工作的机会。)\n\n\n\n## 合作与信任\n\n追求百分百的***安全感***,肯定会把自己困在了永恒的当下。必须放弃一部分安全感,才能有深入的、长期的观察和思考。打破枷锁的方法:\n\n1. 放弃部分安全感,才能获得进步。\n2. 通过有效社交,补全主动放弃的安全感。\n\n\n\n:bookmark:【**合作**】​ 的本质是大家各自放弃一小部分安全感,并把那一部分安全感交给合作方来保障。\n\n:bookmark: 【**信任**】就是相信对方不会利用自己主动放弃的那一部分安全感。所谓缺乏安全感,就是不相信别人竟然可以不利用自己放弃的那一部分安全感,所以只能自己去搞定百分之百的安全感,让人心力交瘁。\n\n\n\n- 不要与缺乏安全感的人合作。尤其是婚姻。\n- 最大的勇敢,就是在孑然一身的时候,还勇于放弃部分安全感。“大智若愚”,大智更像是结果。若愚才是原因。\n- 将军赶路不打小鬼。\n\n\n\n## 活在真实中\n\n如果想活在真实的世界,就要勇于面对「真实」。要搞清楚以下几个概念。\n\n\n\n### 什么算落后\n\n1. 20%之后都是落后,因为世界20%的人占了有限资源的80%。在人工智能和新技术时代,可能1%之后都算落后。将来可能是千分之一,万分之一之后都算。\n\n2. 我们每个人都已经可以尽量感知到这个世界的全部。所以要对自己是否处在落后状态有清晰认知。\n\n3. 我们对知识的渴求已经变成害怕落后。这是种危机感和焦虑,但它能帮我们持续进步,摆脱落后。\n\n\n\n**乌比冈湖效应**:Lake Wobegon Effect 每个人都自认高于平均水平。\n\n**邓宁- 克鲁格效应** :Dunning-Kruger Effect 能力欠缺的人有一种虚幻的自我优越感,错误的认为自己比真实情况更加优秀。\n\n **麻烦守恒定律**:以前因为怕麻烦二省去的麻烦,在未来的某一天,或者未来的某一时刻,一定会以另一种形式呈现在你面前。麻烦不会无缘无故的消失,问题也不会无缘无故的解决。\n\n\n\n### 元认知能力\n\n:pencil:**指对自己的思考过程的认知和理解**。\n\n元认知能力起作用的三个步骤:\n\n1. 哦,原来我是这么想的。\n2. 嗯?我这么想难道是不对的吗?\n3. 啊!我应该这么想才对。。。。\n\n认知能力好比是马,而元认知能力是马车夫。所谓可以用来解放自己的“心智”,指的就是具备足够的元认知能力的大脑。人与人之间的技能差异,证据确凿来自于“刻意锻炼”。而一个人能做到“刻意锻炼”,唯一能够仰仗的就是元认知能力。\n\n- 元认知能力是一个人可拥有的最重要的能力。\n- 元认知能力不仅可以习得,还可以通过刻意训练长期持续发展。\n\n\n\n我们知道我们想要改变的,能够改变的,不是“现在的自己”,而是“将来的自己”。通过刻意练习提高元认知能力的三个方法:坐享、兴趣、反思。\n\n- **坐享**:可以增加大脑皮层的沟回。\n\n- **兴趣**:兴趣是最好的教学。\n\n- **反思**:每天花十分钟反思一下自己的思路和思考结果,琢磨一下自己想法有没有逻辑错误。不仅是元认知能力的刻意训练方式,也是调整情绪的根本。\n\n\n\n## 竞争力\n\n### 多维竞争\n\n😂 据说绝大多数人的幸福感是建立在比较之上的。有个玩笑:所谓的幸福就是自己的收入总比妹夫的收入多百分之二十。。。。。\n\n😂 一般人所谓的“成长”,就是不断的把别人比下去的过程。\n\n\n\n维度在生活上有三个体现:\n\n1. 生活是有多个维度的。\n2. 在多个维度打造竞争力。\n3. 至少在一个维度上足够突出。凡事都是有成本。处处平庸是不行的。\n\n\n\n面对维度,要有以下意识:\n\n- 单个维度,大家比的是长度,两个维度上大家比的是面积,三个维度上大家比的是体积。\n- 每次跨界,都是给自己拓展一个新的维度。\n- 对新知识保持开放态度。\n\n\n\n\n\n# 应用层面\n\n## 「活在未来」\n\n如何活在未来\n\n1. 对未来要有个预测\n2. 那个预测需要时间才能得到结果\n3. 笃信你的预测是正确的。\n4. 于是你按照那个预测的结果行动、选择、思考。\n5. 你终将走到那个结果出现的时刻\n6. 最终证明你的预测是正确的。\n7. 那么,由于你提前按未来正确的结果行动、选择、思考,于是,在相当长的时间里,你生活的一部分就是“活在未来”。\n\n## 人际关系的本质\n\n人际关系在本质上还是**交易**。明白这一点,就能更清楚的看清楚关于**贵人**的问题。 \n\n$ 求助别人 != 麻烦别人 $ \n\n求助不是低声下气的行为,而是一种交易。不仅如此,还是一种隐蔽的、`意义巨大的交易`。贵人之所以原因帮助你,是因为他已经看到你的价值。分清楚“求助”、“乞讨”、“添麻烦”、“占便宜”之间的区别。\n\n能够遇到贵人在一定程度上是偶然也是必然,它是自己生活的一面镜子。你是贵人,生活这面镜子就帮你找到更多的贵人。至于是偶然还是必然,其实你是控制不了的。自己首先得是个贵人,才能遇到贵人,甚至更多贵人。最不济,你也已经成为自己的贵人,而且不会轻易离你而去。“遇到贵人”这件事从来不是我们的目的,相反“成为贵人”倒是我们应该努力的方向。在你出手相助的那一瞬间,你已经得到了自然的回报。\n\n\n\n12条遇到贵人的原则:\n\n1. 乐观的人更容易成为他人的贵人\n2. 贵人更容易遇到贵人\n3. 能帮助他人进步,才是真正的贵人\n4. 优秀的、值得尊重的人,更容易获得帮助。\n5. 乐于分享的人容易获得帮助\n6. 不给他人制造负担的人容易获得帮助\n7. 不以求助为耻的人容易获得帮助\n8. 求助的时候不仅仅用金钱作为回报,帮助他人的时候也不应该收取金钱回报。\n9. 贵人不一定是牛人,贵人通常“以和为贵”。\n10. 很多时候,人们的成功,来源于大量的人**希望看到他成功**。反过来,如果大量的人不愿意看到某人成功,那么这个人真的很难获得所谓的“贵人相助”\n11. 正在做“正确”事情,更容易获得贵人相助。也就是所谓的“**得道多助**”。\n12. 活在未来的人更容易遇到贵人,因为别人能在他身上看到**未来**。\n\n\n\n\n\n## 资本的定义\n\n钱和资本不是一样的东西,正如砖头和房子不是一回事。钱要成为资本必须满足三个基本要素:\n\n1. 资金的金额大小\n2. 资金的使用时限\n3. 资金背后的智慧\n\n\n\n残酷的事实,大多数人其实不配站在资本之后。好消息是资本背后的实力是可以习得的。不能被自己心平气和判上无期徒刑的资金,就别假装资本出来混迹江湖。大多数人在股票市场上“投资”的不是资本,而是“装傻充愣的资金”而已。\n\n\n\n\n\n# 暂时不知道往哪里分\n\n- 好的工具应该让人离开它,而不是黏住它。\n- 你创造财富能力取决于你能给别人创造多少真正的价值。(只有你觉得有价值的话,是几乎没有什么意义的)。\n\n\n\n\n\n\n\n财富自由之路 - 思维导图 ([看全景导图请点击链接](uploads/road-to-asset-freedom-mindmap.html))\n\n
","source":"_posts/读书笔记/财富自由之路-李笑来.md","raw":"---\ntitle: 财富自由之路-李笑来\ndate: 2019-07-21 09:05:22\nurlname: road-to-asset-freedom\ntoc: true\ncontentpw: 123456\ntags: [成长, 经济]\ncategories: 读书笔记\n\n---\n\n\n![图片来自七牛](https://github.com/maiernte/img/raw/master/collection/photo.jpg)\n\n\n\n\n\n进度:10课\n\n# 哲学层面\n\n## 金钱、时间、注意力\n\n钱不是最重要,它可以再生。时间也不是,它本质上不属于你,你只能试着与它做朋友。注意力是自己可以做主的。**必须把宝贵的注意力全部放在自己身上**。放在自己的哪儿上?答:“**成长**”。不珍惜自己注意力的人最终注定是贫穷的,因为他们终生被收割,不可能有真正有价值的产出,怎么可能最终变得富有?另外,要放在自己的**真爱**上,以及对整个社会真正**有贡献**的事情上。(对于后两者,关注的焦点还是“成长”。)\n\n\n\n注意力才是你人生最宝贵的财富(不是金钱和时间),你的一切价值都是你的注意力的产出。\n\n> 俗三个大坑:1. 莫名其妙的凑热闹。2. 心急火燎的随大流。3. 操碎了别人的心 (*万众创业关你屁事,干好自己的活*)。\n\n\n\n金钱、时间和注意力的比较:$ 注意力 > 时间 > 金钱 $\n\n- 凡是可以用钱买的其实都是便宜的。\n\n- 凡是能用钱买来的时间就是便宜的。\n\n- 凡是能用时间换来的注意力持续就是有价值的。\n\n\n\n:question: 时间和金钱谁更重要。\n\n> 答案是`时间`。因为财富自由的定义就是“*不为生活需要出售时间*”。另外一个角度是,“*花钱买你的时间更划算*”。\n\n\n\n:question: 注意力和时间更重要。\n\n> 注意力是能让你有所产出的唯一资源!而时间不一定是你的,时间不会自动产出。(李笑来: 花大量时间与老婆沟通,陪伴,以便换来自己集中注意力工作的机会。)\n\n\n\n## 合作与信任\n\n追求百分百的***安全感***,肯定会把自己困在了永恒的当下。必须放弃一部分安全感,才能有深入的、长期的观察和思考。打破枷锁的方法:\n\n1. 放弃部分安全感,才能获得进步。\n2. 通过有效社交,补全主动放弃的安全感。\n\n\n\n:bookmark:【**合作**】​ 的本质是大家各自放弃一小部分安全感,并把那一部分安全感交给合作方来保障。\n\n:bookmark: 【**信任**】就是相信对方不会利用自己主动放弃的那一部分安全感。所谓缺乏安全感,就是不相信别人竟然可以不利用自己放弃的那一部分安全感,所以只能自己去搞定百分之百的安全感,让人心力交瘁。\n\n\n\n- 不要与缺乏安全感的人合作。尤其是婚姻。\n- 最大的勇敢,就是在孑然一身的时候,还勇于放弃部分安全感。“大智若愚”,大智更像是结果。若愚才是原因。\n- 将军赶路不打小鬼。\n\n\n\n## 活在真实中\n\n如果想活在真实的世界,就要勇于面对「真实」。要搞清楚以下几个概念。\n\n\n\n### 什么算落后\n\n1. 20%之后都是落后,因为世界20%的人占了有限资源的80%。在人工智能和新技术时代,可能1%之后都算落后。将来可能是千分之一,万分之一之后都算。\n\n2. 我们每个人都已经可以尽量感知到这个世界的全部。所以要对自己是否处在落后状态有清晰认知。\n\n3. 我们对知识的渴求已经变成害怕落后。这是种危机感和焦虑,但它能帮我们持续进步,摆脱落后。\n\n\n\n**乌比冈湖效应**:Lake Wobegon Effect 每个人都自认高于平均水平。\n\n**邓宁- 克鲁格效应** :Dunning-Kruger Effect 能力欠缺的人有一种虚幻的自我优越感,错误的认为自己比真实情况更加优秀。\n\n **麻烦守恒定律**:以前因为怕麻烦二省去的麻烦,在未来的某一天,或者未来的某一时刻,一定会以另一种形式呈现在你面前。麻烦不会无缘无故的消失,问题也不会无缘无故的解决。\n\n\n\n### 元认知能力\n\n:pencil:**指对自己的思考过程的认知和理解**。\n\n元认知能力起作用的三个步骤:\n\n1. 哦,原来我是这么想的。\n2. 嗯?我这么想难道是不对的吗?\n3. 啊!我应该这么想才对。。。。\n\n认知能力好比是马,而元认知能力是马车夫。所谓可以用来解放自己的“心智”,指的就是具备足够的元认知能力的大脑。人与人之间的技能差异,证据确凿来自于“刻意锻炼”。而一个人能做到“刻意锻炼”,唯一能够仰仗的就是元认知能力。\n\n- 元认知能力是一个人可拥有的最重要的能力。\n- 元认知能力不仅可以习得,还可以通过刻意训练长期持续发展。\n\n\n\n我们知道我们想要改变的,能够改变的,不是“现在的自己”,而是“将来的自己”。通过刻意练习提高元认知能力的三个方法:坐享、兴趣、反思。\n\n- **坐享**:可以增加大脑皮层的沟回。\n\n- **兴趣**:兴趣是最好的教学。\n\n- **反思**:每天花十分钟反思一下自己的思路和思考结果,琢磨一下自己想法有没有逻辑错误。不仅是元认知能力的刻意训练方式,也是调整情绪的根本。\n\n\n\n## 竞争力\n\n### 多维竞争\n\n😂 据说绝大多数人的幸福感是建立在比较之上的。有个玩笑:所谓的幸福就是自己的收入总比妹夫的收入多百分之二十。。。。。\n\n😂 一般人所谓的“成长”,就是不断的把别人比下去的过程。\n\n\n\n维度在生活上有三个体现:\n\n1. 生活是有多个维度的。\n2. 在多个维度打造竞争力。\n3. 至少在一个维度上足够突出。凡事都是有成本。处处平庸是不行的。\n\n\n\n面对维度,要有以下意识:\n\n- 单个维度,大家比的是长度,两个维度上大家比的是面积,三个维度上大家比的是体积。\n- 每次跨界,都是给自己拓展一个新的维度。\n- 对新知识保持开放态度。\n\n\n\n\n\n# 应用层面\n\n## 「活在未来」\n\n如何活在未来\n\n1. 对未来要有个预测\n2. 那个预测需要时间才能得到结果\n3. 笃信你的预测是正确的。\n4. 于是你按照那个预测的结果行动、选择、思考。\n5. 你终将走到那个结果出现的时刻\n6. 最终证明你的预测是正确的。\n7. 那么,由于你提前按未来正确的结果行动、选择、思考,于是,在相当长的时间里,你生活的一部分就是“活在未来”。\n\n## 人际关系的本质\n\n人际关系在本质上还是**交易**。明白这一点,就能更清楚的看清楚关于**贵人**的问题。 \n\n$ 求助别人 != 麻烦别人 $ \n\n求助不是低声下气的行为,而是一种交易。不仅如此,还是一种隐蔽的、`意义巨大的交易`。贵人之所以原因帮助你,是因为他已经看到你的价值。分清楚“求助”、“乞讨”、“添麻烦”、“占便宜”之间的区别。\n\n能够遇到贵人在一定程度上是偶然也是必然,它是自己生活的一面镜子。你是贵人,生活这面镜子就帮你找到更多的贵人。至于是偶然还是必然,其实你是控制不了的。自己首先得是个贵人,才能遇到贵人,甚至更多贵人。最不济,你也已经成为自己的贵人,而且不会轻易离你而去。“遇到贵人”这件事从来不是我们的目的,相反“成为贵人”倒是我们应该努力的方向。在你出手相助的那一瞬间,你已经得到了自然的回报。\n\n\n\n12条遇到贵人的原则:\n\n1. 乐观的人更容易成为他人的贵人\n2. 贵人更容易遇到贵人\n3. 能帮助他人进步,才是真正的贵人\n4. 优秀的、值得尊重的人,更容易获得帮助。\n5. 乐于分享的人容易获得帮助\n6. 不给他人制造负担的人容易获得帮助\n7. 不以求助为耻的人容易获得帮助\n8. 求助的时候不仅仅用金钱作为回报,帮助他人的时候也不应该收取金钱回报。\n9. 贵人不一定是牛人,贵人通常“以和为贵”。\n10. 很多时候,人们的成功,来源于大量的人**希望看到他成功**。反过来,如果大量的人不愿意看到某人成功,那么这个人真的很难获得所谓的“贵人相助”\n11. 正在做“正确”事情,更容易获得贵人相助。也就是所谓的“**得道多助**”。\n12. 活在未来的人更容易遇到贵人,因为别人能在他身上看到**未来**。\n\n\n\n\n\n## 资本的定义\n\n钱和资本不是一样的东西,正如砖头和房子不是一回事。钱要成为资本必须满足三个基本要素:\n\n1. 资金的金额大小\n2. 资金的使用时限\n3. 资金背后的智慧\n\n\n\n残酷的事实,大多数人其实不配站在资本之后。好消息是资本背后的实力是可以习得的。不能被自己心平气和判上无期徒刑的资金,就别假装资本出来混迹江湖。大多数人在股票市场上“投资”的不是资本,而是“装傻充愣的资金”而已。\n\n\n\n\n\n# 暂时不知道往哪里分\n\n- 好的工具应该让人离开它,而不是黏住它。\n- 你创造财富能力取决于你能给别人创造多少真正的价值。(只有你觉得有价值的话,是几乎没有什么意义的)。\n\n\n\n\n\n\n\n财富自由之路 - 思维导图 ([看全景导图请点击链接](uploads/road-to-asset-freedom-mindmap.html))\n\n
","slug":"读书笔记/财富自由之路-李笑来","published":1,"updated":"2019-08-14T06:36:09.000Z","_id":"cka1y596e000t4huuu6ed1frz","comments":1,"layout":"post","photos":[],"link":"","content":"

进度:10课

\n

哲学层面

\n

金钱、时间、注意力

\n

钱不是最重要,它可以再生。时间也不是,它本质上不属于你,你只能试着与它做朋友。注意力是自己可以做主的。必须把宝贵的注意力全部放在自己身上。放在自己的哪儿上?答:“成长”。不珍惜自己注意力的人最终注定是贫穷的,因为他们终生被收割,不可能有真正有价值的产出,怎么可能最终变得富有?另外,要放在自己的真爱上,以及对整个社会真正有贡献的事情上。(对于后两者,关注的焦点还是“成长”。)

\n

注意力才是你人生最宝贵的财富(不是金钱和时间),你的一切价值都是你的注意力的产出。

\n
\n

俗三个大坑:1. 莫名其妙的凑热闹。2. 心急火燎的随大流。3. 操碎了别人的心 (万众创业关你屁事,干好自己的活)。

\n
\n

金钱、时间和注意力的比较:$ 注意力 > 时间 > 金钱 $

\n
    \n
  • \n

    凡是可以用钱买的其实都是便宜的。

    \n
  • \n
  • \n

    凡是能用钱买来的时间就是便宜的。

    \n
  • \n
  • \n

    凡是能用时间换来的注意力持续就是有价值的。

    \n
  • \n
\n

:question: 时间和金钱谁更重要。

\n
\n

答案是时间。因为财富自由的定义就是“不为生活需要出售时间”。另外一个角度是,“花钱买你的时间更划算”。

\n
\n

:question: 注意力和时间更重要。

\n
\n

注意力是能让你有所产出的唯一资源!而时间不一定是你的,时间不会自动产出。(李笑来: 花大量时间与老婆沟通,陪伴,以便换来自己集中注意力工作的机会。)

\n
\n

合作与信任

\n

追求百分百的安全感,肯定会把自己困在了永恒的当下。必须放弃一部分安全感,才能有深入的、长期的观察和思考。打破枷锁的方法:

\n
    \n
  1. 放弃部分安全感,才能获得进步。
  2. \n
  3. 通过有效社交,补全主动放弃的安全感。
  4. \n
\n

:bookmark:【合作】​ 的本质是大家各自放弃一小部分安全感,并把那一部分安全感交给合作方来保障。

\n

:bookmark: 【信任】就是相信对方不会利用自己主动放弃的那一部分安全感。所谓缺乏安全感,就是不相信别人竟然可以不利用自己放弃的那一部分安全感,所以只能自己去搞定百分之百的安全感,让人心力交瘁。

\n
    \n
  • 不要与缺乏安全感的人合作。尤其是婚姻。
  • \n
  • 最大的勇敢,就是在孑然一身的时候,还勇于放弃部分安全感。“大智若愚”,大智更像是结果。若愚才是原因。
  • \n
  • 将军赶路不打小鬼。
  • \n
\n

活在真实中

\n

如果想活在真实的世界,就要勇于面对「真实」。要搞清楚以下几个概念。

\n

什么算落后

\n
    \n
  1. \n

    20%之后都是落后,因为世界20%的人占了有限资源的80%。在人工智能和新技术时代,可能1%之后都算落后。将来可能是千分之一,万分之一之后都算。

    \n
  2. \n
  3. \n

    我们每个人都已经可以尽量感知到这个世界的全部。所以要对自己是否处在落后状态有清晰认知。

    \n
  4. \n
  5. \n

    我们对知识的渴求已经变成害怕落后。这是种危机感和焦虑,但它能帮我们持续进步,摆脱落后。

    \n
  6. \n
\n

乌比冈湖效应:Lake Wobegon Effect 每个人都自认高于平均水平。

\n

邓宁- 克鲁格效应 :Dunning-Kruger Effect 能力欠缺的人有一种虚幻的自我优越感,错误的认为自己比真实情况更加优秀。

\n

麻烦守恒定律:以前因为怕麻烦二省去的麻烦,在未来的某一天,或者未来的某一时刻,一定会以另一种形式呈现在你面前。麻烦不会无缘无故的消失,问题也不会无缘无故的解决。

\n

元认知能力

\n

:pencil:指对自己的思考过程的认知和理解

\n

元认知能力起作用的三个步骤:

\n
    \n
  1. 哦,原来我是这么想的。
  2. \n
  3. 嗯?我这么想难道是不对的吗?
  4. \n
  5. 啊!我应该这么想才对。。。。
  6. \n
\n

认知能力好比是马,而元认知能力是马车夫。所谓可以用来解放自己的“心智”,指的就是具备足够的元认知能力的大脑。人与人之间的技能差异,证据确凿来自于“刻意锻炼”。而一个人能做到“刻意锻炼”,唯一能够仰仗的就是元认知能力。

\n
    \n
  • 元认知能力是一个人可拥有的最重要的能力。
  • \n
  • 元认知能力不仅可以习得,还可以通过刻意训练长期持续发展。
  • \n
\n

我们知道我们想要改变的,能够改变的,不是“现在的自己”,而是“将来的自己”。通过刻意练习提高元认知能力的三个方法:坐享、兴趣、反思。

\n
    \n
  • \n

    坐享:可以增加大脑皮层的沟回。

    \n
  • \n
  • \n

    兴趣:兴趣是最好的教学。

    \n
  • \n
  • \n

    反思:每天花十分钟反思一下自己的思路和思考结果,琢磨一下自己想法有没有逻辑错误。不仅是元认知能力的刻意训练方式,也是调整情绪的根本。

    \n
  • \n
\n

竞争力

\n

多维竞争

\n

😂 据说绝大多数人的幸福感是建立在比较之上的。有个玩笑:所谓的幸福就是自己的收入总比妹夫的收入多百分之二十。。。。。

\n

😂 一般人所谓的“成长”,就是不断的把别人比下去的过程。

\n

维度在生活上有三个体现:

\n
    \n
  1. 生活是有多个维度的。
  2. \n
  3. 在多个维度打造竞争力。
  4. \n
  5. 至少在一个维度上足够突出。凡事都是有成本。处处平庸是不行的。
  6. \n
\n

面对维度,要有以下意识:

\n
    \n
  • 单个维度,大家比的是长度,两个维度上大家比的是面积,三个维度上大家比的是体积。
  • \n
  • 每次跨界,都是给自己拓展一个新的维度。
  • \n
  • 对新知识保持开放态度。
  • \n
\n

应用层面

\n

「活在未来」

\n

如何活在未来

\n
    \n
  1. 对未来要有个预测
  2. \n
  3. 那个预测需要时间才能得到结果
  4. \n
  5. 笃信你的预测是正确的。
  6. \n
  7. 于是你按照那个预测的结果行动、选择、思考。
  8. \n
  9. 你终将走到那个结果出现的时刻
  10. \n
  11. 最终证明你的预测是正确的。
  12. \n
  13. 那么,由于你提前按未来正确的结果行动、选择、思考,于是,在相当长的时间里,你生活的一部分就是“活在未来”。
  14. \n
\n

人际关系的本质

\n

人际关系在本质上还是交易。明白这一点,就能更清楚的看清楚关于贵人的问题。

\n

$ 求助别人 != 麻烦别人 $

\n

求助不是低声下气的行为,而是一种交易。不仅如此,还是一种隐蔽的、意义巨大的交易。贵人之所以原因帮助你,是因为他已经看到你的价值。分清楚“求助”、“乞讨”、“添麻烦”、“占便宜”之间的区别。

\n

能够遇到贵人在一定程度上是偶然也是必然,它是自己生活的一面镜子。你是贵人,生活这面镜子就帮你找到更多的贵人。至于是偶然还是必然,其实你是控制不了的。自己首先得是个贵人,才能遇到贵人,甚至更多贵人。最不济,你也已经成为自己的贵人,而且不会轻易离你而去。“遇到贵人”这件事从来不是我们的目的,相反“成为贵人”倒是我们应该努力的方向。在你出手相助的那一瞬间,你已经得到了自然的回报。

\n

12条遇到贵人的原则:

\n
    \n
  1. 乐观的人更容易成为他人的贵人
  2. \n
  3. 贵人更容易遇到贵人
  4. \n
  5. 能帮助他人进步,才是真正的贵人
  6. \n
  7. 优秀的、值得尊重的人,更容易获得帮助。
  8. \n
  9. 乐于分享的人容易获得帮助
  10. \n
  11. 不给他人制造负担的人容易获得帮助
  12. \n
  13. 不以求助为耻的人容易获得帮助
  14. \n
  15. 求助的时候不仅仅用金钱作为回报,帮助他人的时候也不应该收取金钱回报。
  16. \n
  17. 贵人不一定是牛人,贵人通常“以和为贵”。
  18. \n
  19. 很多时候,人们的成功,来源于大量的人希望看到他成功。反过来,如果大量的人不愿意看到某人成功,那么这个人真的很难获得所谓的“贵人相助”
  20. \n
  21. 正在做“正确”事情,更容易获得贵人相助。也就是所谓的“得道多助”。
  22. \n
  23. 活在未来的人更容易遇到贵人,因为别人能在他身上看到未来
  24. \n
\n

资本的定义

\n

钱和资本不是一样的东西,正如砖头和房子不是一回事。钱要成为资本必须满足三个基本要素:

\n
    \n
  1. 资金的金额大小
  2. \n
  3. 资金的使用时限
  4. \n
  5. 资金背后的智慧
  6. \n
\n

残酷的事实,大多数人其实不配站在资本之后。好消息是资本背后的实力是可以习得的。不能被自己心平气和判上无期徒刑的资金,就别假装资本出来混迹江湖。大多数人在股票市场上“投资”的不是资本,而是“装傻充愣的资金”而已。

\n

暂时不知道往哪里分

\n
    \n
  • 好的工具应该让人离开它,而不是黏住它。
  • \n
  • 你创造财富能力取决于你能给别人创造多少真正的价值。(只有你觉得有价值的话,是几乎没有什么意义的)。
  • \n
\n

财富自由之路 - 思维导图 (看全景导图请点击链接

\n
","site":{"data":{}},"excerpt":"

\"图片来自七牛\"

","more":"

进度:10课

\n

哲学层面

\n

金钱、时间、注意力

\n

钱不是最重要,它可以再生。时间也不是,它本质上不属于你,你只能试着与它做朋友。注意力是自己可以做主的。必须把宝贵的注意力全部放在自己身上。放在自己的哪儿上?答:“成长”。不珍惜自己注意力的人最终注定是贫穷的,因为他们终生被收割,不可能有真正有价值的产出,怎么可能最终变得富有?另外,要放在自己的真爱上,以及对整个社会真正有贡献的事情上。(对于后两者,关注的焦点还是“成长”。)

\n

注意力才是你人生最宝贵的财富(不是金钱和时间),你的一切价值都是你的注意力的产出。

\n
\n

俗三个大坑:1. 莫名其妙的凑热闹。2. 心急火燎的随大流。3. 操碎了别人的心 (万众创业关你屁事,干好自己的活)。

\n
\n

金钱、时间和注意力的比较:$ 注意力 > 时间 > 金钱 $

\n
    \n
  • \n

    凡是可以用钱买的其实都是便宜的。

    \n
  • \n
  • \n

    凡是能用钱买来的时间就是便宜的。

    \n
  • \n
  • \n

    凡是能用时间换来的注意力持续就是有价值的。

    \n
  • \n
\n

:question: 时间和金钱谁更重要。

\n
\n

答案是时间。因为财富自由的定义就是“不为生活需要出售时间”。另外一个角度是,“花钱买你的时间更划算”。

\n
\n

:question: 注意力和时间更重要。

\n
\n

注意力是能让你有所产出的唯一资源!而时间不一定是你的,时间不会自动产出。(李笑来: 花大量时间与老婆沟通,陪伴,以便换来自己集中注意力工作的机会。)

\n
\n

合作与信任

\n

追求百分百的安全感,肯定会把自己困在了永恒的当下。必须放弃一部分安全感,才能有深入的、长期的观察和思考。打破枷锁的方法:

\n
    \n
  1. 放弃部分安全感,才能获得进步。
  2. \n
  3. 通过有效社交,补全主动放弃的安全感。
  4. \n
\n

:bookmark:【合作】​ 的本质是大家各自放弃一小部分安全感,并把那一部分安全感交给合作方来保障。

\n

:bookmark: 【信任】就是相信对方不会利用自己主动放弃的那一部分安全感。所谓缺乏安全感,就是不相信别人竟然可以不利用自己放弃的那一部分安全感,所以只能自己去搞定百分之百的安全感,让人心力交瘁。

\n
    \n
  • 不要与缺乏安全感的人合作。尤其是婚姻。
  • \n
  • 最大的勇敢,就是在孑然一身的时候,还勇于放弃部分安全感。“大智若愚”,大智更像是结果。若愚才是原因。
  • \n
  • 将军赶路不打小鬼。
  • \n
\n

活在真实中

\n

如果想活在真实的世界,就要勇于面对「真实」。要搞清楚以下几个概念。

\n

什么算落后

\n
    \n
  1. \n

    20%之后都是落后,因为世界20%的人占了有限资源的80%。在人工智能和新技术时代,可能1%之后都算落后。将来可能是千分之一,万分之一之后都算。

    \n
  2. \n
  3. \n

    我们每个人都已经可以尽量感知到这个世界的全部。所以要对自己是否处在落后状态有清晰认知。

    \n
  4. \n
  5. \n

    我们对知识的渴求已经变成害怕落后。这是种危机感和焦虑,但它能帮我们持续进步,摆脱落后。

    \n
  6. \n
\n

乌比冈湖效应:Lake Wobegon Effect 每个人都自认高于平均水平。

\n

邓宁- 克鲁格效应 :Dunning-Kruger Effect 能力欠缺的人有一种虚幻的自我优越感,错误的认为自己比真实情况更加优秀。

\n

麻烦守恒定律:以前因为怕麻烦二省去的麻烦,在未来的某一天,或者未来的某一时刻,一定会以另一种形式呈现在你面前。麻烦不会无缘无故的消失,问题也不会无缘无故的解决。

\n

元认知能力

\n

:pencil:指对自己的思考过程的认知和理解

\n

元认知能力起作用的三个步骤:

\n
    \n
  1. 哦,原来我是这么想的。
  2. \n
  3. 嗯?我这么想难道是不对的吗?
  4. \n
  5. 啊!我应该这么想才对。。。。
  6. \n
\n

认知能力好比是马,而元认知能力是马车夫。所谓可以用来解放自己的“心智”,指的就是具备足够的元认知能力的大脑。人与人之间的技能差异,证据确凿来自于“刻意锻炼”。而一个人能做到“刻意锻炼”,唯一能够仰仗的就是元认知能力。

\n
    \n
  • 元认知能力是一个人可拥有的最重要的能力。
  • \n
  • 元认知能力不仅可以习得,还可以通过刻意训练长期持续发展。
  • \n
\n

我们知道我们想要改变的,能够改变的,不是“现在的自己”,而是“将来的自己”。通过刻意练习提高元认知能力的三个方法:坐享、兴趣、反思。

\n
    \n
  • \n

    坐享:可以增加大脑皮层的沟回。

    \n
  • \n
  • \n

    兴趣:兴趣是最好的教学。

    \n
  • \n
  • \n

    反思:每天花十分钟反思一下自己的思路和思考结果,琢磨一下自己想法有没有逻辑错误。不仅是元认知能力的刻意训练方式,也是调整情绪的根本。

    \n
  • \n
\n

竞争力

\n

多维竞争

\n

😂 据说绝大多数人的幸福感是建立在比较之上的。有个玩笑:所谓的幸福就是自己的收入总比妹夫的收入多百分之二十。。。。。

\n

😂 一般人所谓的“成长”,就是不断的把别人比下去的过程。

\n

维度在生活上有三个体现:

\n
    \n
  1. 生活是有多个维度的。
  2. \n
  3. 在多个维度打造竞争力。
  4. \n
  5. 至少在一个维度上足够突出。凡事都是有成本。处处平庸是不行的。
  6. \n
\n

面对维度,要有以下意识:

\n
    \n
  • 单个维度,大家比的是长度,两个维度上大家比的是面积,三个维度上大家比的是体积。
  • \n
  • 每次跨界,都是给自己拓展一个新的维度。
  • \n
  • 对新知识保持开放态度。
  • \n
\n

应用层面

\n

「活在未来」

\n

如何活在未来

\n
    \n
  1. 对未来要有个预测
  2. \n
  3. 那个预测需要时间才能得到结果
  4. \n
  5. 笃信你的预测是正确的。
  6. \n
  7. 于是你按照那个预测的结果行动、选择、思考。
  8. \n
  9. 你终将走到那个结果出现的时刻
  10. \n
  11. 最终证明你的预测是正确的。
  12. \n
  13. 那么,由于你提前按未来正确的结果行动、选择、思考,于是,在相当长的时间里,你生活的一部分就是“活在未来”。
  14. \n
\n

人际关系的本质

\n

人际关系在本质上还是交易。明白这一点,就能更清楚的看清楚关于贵人的问题。

\n

$ 求助别人 != 麻烦别人 $

\n

求助不是低声下气的行为,而是一种交易。不仅如此,还是一种隐蔽的、意义巨大的交易。贵人之所以原因帮助你,是因为他已经看到你的价值。分清楚“求助”、“乞讨”、“添麻烦”、“占便宜”之间的区别。

\n

能够遇到贵人在一定程度上是偶然也是必然,它是自己生活的一面镜子。你是贵人,生活这面镜子就帮你找到更多的贵人。至于是偶然还是必然,其实你是控制不了的。自己首先得是个贵人,才能遇到贵人,甚至更多贵人。最不济,你也已经成为自己的贵人,而且不会轻易离你而去。“遇到贵人”这件事从来不是我们的目的,相反“成为贵人”倒是我们应该努力的方向。在你出手相助的那一瞬间,你已经得到了自然的回报。

\n

12条遇到贵人的原则:

\n
    \n
  1. 乐观的人更容易成为他人的贵人
  2. \n
  3. 贵人更容易遇到贵人
  4. \n
  5. 能帮助他人进步,才是真正的贵人
  6. \n
  7. 优秀的、值得尊重的人,更容易获得帮助。
  8. \n
  9. 乐于分享的人容易获得帮助
  10. \n
  11. 不给他人制造负担的人容易获得帮助
  12. \n
  13. 不以求助为耻的人容易获得帮助
  14. \n
  15. 求助的时候不仅仅用金钱作为回报,帮助他人的时候也不应该收取金钱回报。
  16. \n
  17. 贵人不一定是牛人,贵人通常“以和为贵”。
  18. \n
  19. 很多时候,人们的成功,来源于大量的人希望看到他成功。反过来,如果大量的人不愿意看到某人成功,那么这个人真的很难获得所谓的“贵人相助”
  20. \n
  21. 正在做“正确”事情,更容易获得贵人相助。也就是所谓的“得道多助”。
  22. \n
  23. 活在未来的人更容易遇到贵人,因为别人能在他身上看到未来
  24. \n
\n

资本的定义

\n

钱和资本不是一样的东西,正如砖头和房子不是一回事。钱要成为资本必须满足三个基本要素:

\n
    \n
  1. 资金的金额大小
  2. \n
  3. 资金的使用时限
  4. \n
  5. 资金背后的智慧
  6. \n
\n

残酷的事实,大多数人其实不配站在资本之后。好消息是资本背后的实力是可以习得的。不能被自己心平气和判上无期徒刑的资金,就别假装资本出来混迹江湖。大多数人在股票市场上“投资”的不是资本,而是“装傻充愣的资金”而已。

\n

暂时不知道往哪里分

\n
    \n
  • 好的工具应该让人离开它,而不是黏住它。
  • \n
  • 你创造财富能力取决于你能给别人创造多少真正的价值。(只有你觉得有价值的话,是几乎没有什么意义的)。
  • \n
\n

财富自由之路 - 思维导图 (看全景导图请点击链接

\n
"},{"title":"斯多葛主义手册","date":"2019-08-03T19:16:47.000Z","urlname":"storic-summary","toc":true,"_content":"\n\n\n![](https://github.com/maiernte/img/raw/master/collection/马可奥勒留.jpg)\n\n世间的事,有些可控,有些不可控。可控的有:观点,追求,欲望,和喜恶等。这些都是我们自己可以做出选择的。不可控的是身体,财物,名声,指令等。这些我们都无法选择。\n\n\n\n1. 世间的事,有些可控,有些不可控。可控的有:观点,追求,欲望,和喜恶等。这些都是我们自己可以做出选择的。不可控的是身体,财物,名声,指令等。这些我们都无法选择。\n\n 可控范围之内的东西在本质上是自由的,不被束缚、阻碍的。那些不可控的是虚的,是被奴役的,是我们受控于他人。记住,如果你觉得那些不可控的事物是自由的,那些受控于别人的也是你的,那么你就会被控制,被束缚。你会悲痛,你会受扰,你会指责神以及他人。但如果你只专注于你所能控制的,不被他人所拥有的干扰,那么就没有人能够影响你、束缚你。并且,你不会把过错推在他人身上。你不会去做违背你的意志的事。你不会有敌人。你也不会被伤害。\n\n 把这些当做你的目标,不让自己受那些没有意义的事诱惑,哪怕就一点点也不可以。放弃那些不可控的。如果你既想把握住可控的,又想拥有财富和权力,那么你将会什么都得不到,更不用说幸福和自由-因为幸福和自由是依赖于可控事物。\n\n 尽你最大的努力。这样你就可以对看似艰难的每一件事说:“你只不过是看起来艰难而已。” 然后比照你为自己制定的原则:这件事是否可控。如果在你控制范围之外,那么结果就无关乎于你。\n\n2. 欲望要求你去追求你想要的;厌恶则让你尽量避免你所讨厌的。但是,如果你得不到你想要的,你就会十分失望;如果你无法避免你所讨厌的,那你就会被厌恶扭曲。那么,如果你只讨厌那些在你出自本质所做选择的对立事物(即在你控制范围内你不会选择的事物),那么你就永远不需要去为之伤神。但是,如果你厌恶疾病、死亡、贫穷等你无法选择和改变的,那你就会被厌恶扭曲。不厌恶你所不能控制的,把厌恶限制在和你本性对立的事物。但是,就目前来说,压制你的欲望:因为如果你追求任何可控范围之外的事物,那你就必然会失望。不要轻易追求或者厌恶。\n\n3. 对于给你带来乐趣、有用处以及你十分喜欢的东西,从最不重要的事情开始,记得提醒你自己:他们真正的本质是什么。比如说,你很喜欢某个陶瓷杯,提醒你自己那只是因为你喜欢陶瓷杯而已,而不在于具体是哪个杯子。这样,如果杯子碎了,你也不会太伤心。当你亲吻你的家人时,提醒你自己你只是在亲吻和你亲近的人,这样当他们离世时,你就不会太难过。\n\n4. 当你做事情时,提醒你自己事情的本质是什么,你可能遇到哪些情况。比如说洗澡。在你洗澡之前,先想想洗澡时会发生哪些事情。有的人可能会把水溅得哪都是,有人可能会推娜,有人会诅咒,有人会偷东西。这样你在洗澡之前就可以跟自己说:“我现在要去洗澡了,任何这些事都有可能发生,但是这不是我能控制的,所以我会保持好的心态”。如果你以同样的心态去对待任何其他事情,你内心的平和就不会被打扰。因为你可以对自己说:”我希望的不仅仅是洗澡,还有不被任何意外困扰”。\n\n5. 人内心困扰时,通常不是被事物本身困扰,而是被他们自己的原则和概念所困扰。比如说,死亡本身并不可怕,要不然苏格拉底面临死亡时该有多么惊慌。我们对死亡的恐惧是源于我们对死亡的概念:死亡是可怕的。当我们被困扰、阻碍,伤心难过时,我们不要从事物本身或者他人身上找原因,而应该反省我们自己,还有我们的原则。一个还不通明的人,会把自己的糟糕情况怪罪于他人。一个刚刚开始学习处理这些情况的人,会从自己身上找原因。而一个已经通彻的人,既不会怪罪别人,也不会苛求自己。\n\n6. 不要为任何身外之物骄傲。一匹马可以因为自己的英爽豪气自豪,因为这是它本身拥有的。但是如果你因为拥有这样一匹马儿骄傲,事实上,你所自豪的,不过是马所拥有的好。那么,什么才是属于你的呢?你对事物的反应和态度。如果你对任何事物的形态的处之泰然,那么你就可以为你的理性自豪,因为这是属于你的。\n\n7. 想象以下情况:在一次航海旅行中,你的船抛锚靠岸了,你上岸去找水,途中你还捡了些你喜欢的贝壳,或者买个洋葱。但是,你的所有注意力必须一直集中在那艘船上,注意船长什么时候呼叫大家上船继续航行。当船长呼叫时,你必须立刻放下手中所有的东西,否则你就会被手脚捆绑得像只羊一样抛到船上。生活也是这样。生活给你老婆孩子,而不是洋葱贝壳。如果生活的船长呼叫了,你必须离开他们,立马跑到船上,而不是光顾着他们。如果你年纪大了,那你就不能离开船太远,否则你可能来不及回到船上。\n\n8. 不要苛求生活给予你所有你想要的,该发生的就会发生,随遇而安就好。\n\n9. 疾病影响的只是你的身体,而不是你选择的能力,除非那是你的选择。瘸的是腿,而不是你的脑子。不管发生什么事,只要这么跟自己说,你就会明白困难阻碍的是事物,而不是你。\n\n10. 对于每一件发生的事,检视你自己的能力,问你自己能够用哪些能力从每一件事情中获得什么适当的用处。遇到一个十分有吸引力的人时,你就会发现你的自控就是你的能力。当你痛苦时,你会发现自己的坚强。听到坏话时,你会发现自己的耐心。形成了这样的习惯之后,你就不会被事物的表象所影响。\n\n11. 不要说:“我失去了什么”。而应该说:“我归还了什么”。如果你的孩子或者妻子不幸离世了,你不是失去他们了,而是他们回归了。如果你的房子被夺走了,同样的,你是归还它们了。你可能会说:“可是那些夺走我房子的人是坏人!“。可是,给予你的人让谁来夺走你的房子真的那么重要吗?当你拥有时,照顾好它,但不要把它当做永久财物,就当自己是一个在那暂住的旅行者。\n\n12. 如果你想要提高自己,那就要拒绝以下思考方式:“如果我忽视那些琐事,那我就没有收入;如果我不更正我的仆人,那他们就会变坏”。 如果能够免于悲伤和恐惧,即使死于饥饿,那也比富得流油但备受精神困扰好得多。比起坏仆人,难道你的开心不是更重要吗?\n\n 如果你想要让自己变得更好,那就从小事做起。油洒了,酒被偷了,没关系,告诉你自己:“那只不过是平静生活的一点点代价。任何事情都是有代价的”。当你召集你的仆人时,他们可能不会来,也可能来了但是做的事情不合你意。但是他们并没有重要得以至于你必须打破自己的平静。\n\n13. 如果你想要让自己变得更好,那就不要在乎被人认为你是愚蠢的。不要希望别人认为你无所不知。即使你看上去好像对别人来说很重要,也不要被这种虚名欺骗。因为想要既保持内心平和又拥有外在事物是非常困难的。当你专注于二者之一时,你必然会忽略剩下的那个。\n\n14. 如果你希望你的家人、朋友长生不老,那是很愚蠢的想法。因为生死是在你控制范围之外的,是关乎他人的。同样地,如果你希望你的仆人不犯错,那你和傻瓜无异,因为你希望错误不是错误。但是,如果你希望你的欲望不带来失望,那是在你所能控制的范围之内的。练习控制你所能控制的。一个能够控制自己的喜恶的人,是自己生活的主人。这样的人,是真正自由的,不会成为被自己的欲望控制的奴隶,不会喜欢或者厌恶那些受别人控制的事物。\n\n15. 记住生活就像是一个晚餐聚会一样。如果别人递给你一盘食物,你应该伸出手去接,舀起适当份量给自己。如果盘子从你身边递过,不要试图去截取。如果还没轮到你这,不要起身去拿,而是等着别人递到你面前。用相同的态度对待孩子,配偶,财物,公共职位,这样你最终自然就会成为诸神宴会的搭档。如果你不仅能够做到这些,还能够做到不去拿你面前的食物,甚至是有能力拒绝你自己的欲望,这样你不仅仅能够成为诸神宴会的搭档,你还能进入他们的国度,成为为他们的一员。像Diogenes, Heraclitus这些人就是因为他们的尊贵行为而被视为神一般神圣。\n\n16. 当你看到别人因为孩子出国了,或者离世了,或者因为被琐事困扰而哭泣伤心时,不要让这些情感表象误导你。你必须作出自己的判断,明白他的伤心难过不是因为发生的事情本身,因为其他同样身处其中的人并没有受到同样的影响。他之所以受到那么大的困扰,是因为他自己本身对事情的判断。不要让自己和他一样受影响,不要让自己一样受困扰,不管是外在表现还是内心感受上。\n\n17. 记住你只是一出戏里的一个演员,而戏份角色并不是由你决定的。不管角色故事长短,不管你是一个穷人,瘸子,政府官员,或者是一个很私密的人,把你的角色演好演自然了就行。把分配给你的角色演好,那是你的本分;而到底是哪个角色,那不是由你决定的。\n\n18. 如果一只乌鸦向你预示不幸的事即将发生,不要让你内心的平静被这个表象破坏。要即刻告诉自己,“我不知道会发生什么,我不知道我的身体,财物,名声,或者家人会受什么影响,如果我愿意理性地去想,那么所有的这些恶兆就会变成幸运,因为我可以控制我要用什么态度去对待这些事情。不管发生什么,我都可以从中获得对我有利的。\n\n19. 如果你不去参与在你控制范围之外的任何战斗,那你就不会被打败。当你看到那些声名显赫,社会地位高,或者在任何方面做得很好的人,不要着急认为他们是开心的。因为如果我们清楚明白幸福只在于我们所能够控制的范围内,那我们就不会去羡慕或者攀比。不要向往头衔,而是要向往内心自由和平静。而要做到这一点,唯一的途径是要看轻我们控制范围之外的一切事物。\n\n20. 记住,那些对你出言不逊或者动手的人他本身并不是一种羞辱,而是代表那些言行的原则让你感觉到被羞辱。如果有人激怒你了,那是你对这种行为的观点激怒了你。试着不要被事情的表象牵引你的情感。给予适当的时间和稍作休息,你就能够很好地调整控制自己的情感。\n\n21. 把死亡和流放这些看似可怕的事看作是日常,那你就赢了。不用害怕贫穷,也不要刻意贪求任何东西。\n\n22. 如果你真心希望从哲学中获益,那么就要做好被众人嘲笑的准备:“她这是准备要成为一个哲学家呢”,“瞧她那傲慢的样子”……这个时候,你该做的,不是摆起傲慢的样子,而是要以神圣的态度忠诚于你所认定的,这样总有一天嘲笑你的人会开始尊敬你崇拜你。但是如果你被这些嘲笑打败,那你就成了双重的笑话。\n\n23. 如果你为了取悦他人而把你的注意力转移到那些外在的你无法控制的事物上,那么恭喜你,你已经成功地毁了你自己的生活了。\n\n24. 不要让以下这些思考方式困扰你:“我将会颜面丢尽,而且什么都不是。”耻辱是邪恶的,我们不应该被耻辱感所控制。因为获取权力或着被人嘲笑,这些都在你的控制范围之外。我们不用为任何在我们控制范围之外的事而感到耻辱。在我们可控范围之内,我们是自由的,能够左右我们自己的事情,是自我的主人-从这个角度看,我们永远不会什么都不是。“可是我帮不了我的朋友啊”,你可能会这么说。可是,怎么算是帮助朋友呢?你不能给他们钱,或者帮他们成为罗马市民。这些都是你所能控制范围之内的,是他们自己应该处理的事情。而且,如果这些都是你自己所没有的,那你怎么能够给他们呢?你可能会说:“如果我帮助他们获得这些的话,说不定我也能够得到一份呢“。如果我能够在保存我自己的尊严,忠诚和思想得到这些的话,请你帮我指明道路。可是如果你要我损害自己去得到你的利益,那这样的做法不仅不公平,而且愚蠢至极。\n\n25. 如果别人,而不是你,被邀请去宴会,或者被赞美,或者被别人咨询,不要懊恼。如果这些是好事,你应该为他人高兴。如果是坏事,不要难过。记住:这些都是在你的控制范围之外的,这样的对待一般是有对应的代价的。如果你不愿意付出这样的代价而希望得到同样的对待,那是不公平的。比如说别人用50分买了一棵生菜,但是你不想花这50分,那你就不应该认为拥有生菜的人占了便宜。那个人付出50分得到了生菜,而你口袋里还有那没有花出去的50分。同理,宴会邀请,别人的赞美,这些都是有代价的。如果你觉得这些对你是有价值的,那你就要付出同等的价值去拥有。如果你不付出就想要得到这些,那么你就是个贪得无厌的傻瓜。换个角度想,在决定不和别人交换价值的时候,你真的什么都没有得到吗?不是的:你得到了不赞美你不想赞美的人的自由,而且也不需要容忍你不想容忍的行为。\n\n26. 记住:很多事情不应该分自我或者他人。举个例子,如果邻居家的孩子打破了个杯子或者其他什么东西,我们很容易会说:“没事的,打碎东西是正常的”。可是如果打碎的是你自己的杯子呢?你应该作出相同的反应,而不是心生懊恼。同理,当别人的孩子或者妻子去世了,我们知道死亡的悲剧有时候是不可避免的,但是如果发生在我们自己身上的时候,我们却心如刀割。但是,我们应该清醒的认识到类似的悲剧不是我们能够控制的,我们所能够控制的是自己的情绪和反应,因为即使是发生在自己的身上,死亡本身并没有因为我们和死者的关系而变的更糟糕。\n\n27. 立一个靶子的目的,不是为了射失它(靶子的目的都是为了让人射中它)。那么同样的道理,大道创造出一个“恶”的事物(至少看起来如此),不是为了让人绕开它。\n\n28. 如果别人把你的身体交给一个路上遇到的陌生人,你一定会很生气。可是当别人用恶语打击你的时候,你为什么要心甘情愿地让别人控制你的思想,困惑你呢?\n\n29. 做每件事情都要考虑缘由和后果之后才能开始行动。如果你兴高采烈地开始而没有考虑可能发生的后果,当某些不好的后果开始出现时,你就会停止前进。拿参加奥林匹克赛事为例子。如果你把所有前因后果都考虑周全后认为参加比赛对你时有益的,那就全力以赴。其中,应该考虑的事情包括:你要遵守规则,节制饮食;不管风吹日晒雨淋都要雷打不动地坚持按时锻炼;你不能喝凉水活着酒。你必须全身心地、完全忘我地投入训练。而且,要做思想准备准备,比赛中你有可能会摔入沟里,胳膊脱臼,脚踝受伤,吃入尘土,被鞭打,甚至最后以失败告终。当你评估完所有的可能性之后还是一心想比赛,那就以战争的姿态出发。否则,你就会像孩子过家家一样:一会扮摔跤手,一会扮角斗士,一会吹喇叭,一会又想参加戏剧演出。这样,即使你什么都做过,但是什么都不是。就想大猩猩一样,你模仿你所看到的一切,不停地换把戏可能是一件好玩的事,但是你很快就玩腻了。你从来都没有完全投入过任何事,没有深度地从各个角度考虑和研究所有相关的细节,而只是凭一时的兴趣蜻蜓点水般地接触了各种行业。有些人当他们看到一个人说话的方式和Euphrates十分相像(不过事实上,真的有人能和Euphrates一样犀利善辩吗?),他们认为自己也能够拥有和哲学家一样的思想。但是,如果你细想一下,如果你想要成为一个摔跤手,那么你必须具备有摔跤手的宽阔肩膀,强有力的背部和大腿。但是每一个人的身体构造都是不一样的,你必须具有必备的条件才能称为一个好的摔跤手。同理,要想成为一个哲学家,你不能像你现在这样随心所欲地吃喝,不能让愤怒和不满控制你的情绪,你必须细心观察,劳作,控制自己的欲望,你必须能够忍受孤独,仆人的不敬,和外人的嘲笑,你必须能够接受别人在其他方面做得比你好。如果你已经仔细考虑过这些情况,如果你认为如果做到以上这些可以让你享受自由和宁静,那就尽情去追求哲学家的道路。如果你无法做到这些的话,那么就请不要继续,不要像孩子一样,一会试试做哲学,一会又想当政治家,演讲者,或者凯撒的军官。这些追求是互相矛盾的,你只能成为其中一个,不管做得好坏。你必须培养你自己内在的能够掌控行为的能力,或者外在的技术,二者只能取其一。\n\n30. 一个人的责任是由和别人的关系定义和衡量的。如果一个人拥有父亲的角色,那么他就有以下权利:他的孩子要照顾他,遵从他,耐心听他训话和教导。那如果他不是一个好父亲呢?他也应该受到同等的对待,因为我们无法选择我们的父亲是谁。不管他做了什么,你必须做到让自己心安理得。因为只有你能够让别人的行为伤害到你。当你觉得你被伤害了,那你就会被伤害。如果你以同样的逻辑看待邻居,市民,将军这些不同的角色,你就能够清楚地明白与这些角色相对应的社会责任。","source":"_posts/读书笔记/斯多葛主义手册.md","raw":"---\ntitle: 斯多葛主义手册\ndate: 2019-08-03 21:16:47\nurlname: storic-summary\ntoc: true\ntags: [哲理, 书籍]\ncategories: [读书笔记]\n---\n\n\n\n![](https://github.com/maiernte/img/raw/master/collection/马可奥勒留.jpg)\n\n世间的事,有些可控,有些不可控。可控的有:观点,追求,欲望,和喜恶等。这些都是我们自己可以做出选择的。不可控的是身体,财物,名声,指令等。这些我们都无法选择。\n\n\n\n1. 世间的事,有些可控,有些不可控。可控的有:观点,追求,欲望,和喜恶等。这些都是我们自己可以做出选择的。不可控的是身体,财物,名声,指令等。这些我们都无法选择。\n\n 可控范围之内的东西在本质上是自由的,不被束缚、阻碍的。那些不可控的是虚的,是被奴役的,是我们受控于他人。记住,如果你觉得那些不可控的事物是自由的,那些受控于别人的也是你的,那么你就会被控制,被束缚。你会悲痛,你会受扰,你会指责神以及他人。但如果你只专注于你所能控制的,不被他人所拥有的干扰,那么就没有人能够影响你、束缚你。并且,你不会把过错推在他人身上。你不会去做违背你的意志的事。你不会有敌人。你也不会被伤害。\n\n 把这些当做你的目标,不让自己受那些没有意义的事诱惑,哪怕就一点点也不可以。放弃那些不可控的。如果你既想把握住可控的,又想拥有财富和权力,那么你将会什么都得不到,更不用说幸福和自由-因为幸福和自由是依赖于可控事物。\n\n 尽你最大的努力。这样你就可以对看似艰难的每一件事说:“你只不过是看起来艰难而已。” 然后比照你为自己制定的原则:这件事是否可控。如果在你控制范围之外,那么结果就无关乎于你。\n\n2. 欲望要求你去追求你想要的;厌恶则让你尽量避免你所讨厌的。但是,如果你得不到你想要的,你就会十分失望;如果你无法避免你所讨厌的,那你就会被厌恶扭曲。那么,如果你只讨厌那些在你出自本质所做选择的对立事物(即在你控制范围内你不会选择的事物),那么你就永远不需要去为之伤神。但是,如果你厌恶疾病、死亡、贫穷等你无法选择和改变的,那你就会被厌恶扭曲。不厌恶你所不能控制的,把厌恶限制在和你本性对立的事物。但是,就目前来说,压制你的欲望:因为如果你追求任何可控范围之外的事物,那你就必然会失望。不要轻易追求或者厌恶。\n\n3. 对于给你带来乐趣、有用处以及你十分喜欢的东西,从最不重要的事情开始,记得提醒你自己:他们真正的本质是什么。比如说,你很喜欢某个陶瓷杯,提醒你自己那只是因为你喜欢陶瓷杯而已,而不在于具体是哪个杯子。这样,如果杯子碎了,你也不会太伤心。当你亲吻你的家人时,提醒你自己你只是在亲吻和你亲近的人,这样当他们离世时,你就不会太难过。\n\n4. 当你做事情时,提醒你自己事情的本质是什么,你可能遇到哪些情况。比如说洗澡。在你洗澡之前,先想想洗澡时会发生哪些事情。有的人可能会把水溅得哪都是,有人可能会推娜,有人会诅咒,有人会偷东西。这样你在洗澡之前就可以跟自己说:“我现在要去洗澡了,任何这些事都有可能发生,但是这不是我能控制的,所以我会保持好的心态”。如果你以同样的心态去对待任何其他事情,你内心的平和就不会被打扰。因为你可以对自己说:”我希望的不仅仅是洗澡,还有不被任何意外困扰”。\n\n5. 人内心困扰时,通常不是被事物本身困扰,而是被他们自己的原则和概念所困扰。比如说,死亡本身并不可怕,要不然苏格拉底面临死亡时该有多么惊慌。我们对死亡的恐惧是源于我们对死亡的概念:死亡是可怕的。当我们被困扰、阻碍,伤心难过时,我们不要从事物本身或者他人身上找原因,而应该反省我们自己,还有我们的原则。一个还不通明的人,会把自己的糟糕情况怪罪于他人。一个刚刚开始学习处理这些情况的人,会从自己身上找原因。而一个已经通彻的人,既不会怪罪别人,也不会苛求自己。\n\n6. 不要为任何身外之物骄傲。一匹马可以因为自己的英爽豪气自豪,因为这是它本身拥有的。但是如果你因为拥有这样一匹马儿骄傲,事实上,你所自豪的,不过是马所拥有的好。那么,什么才是属于你的呢?你对事物的反应和态度。如果你对任何事物的形态的处之泰然,那么你就可以为你的理性自豪,因为这是属于你的。\n\n7. 想象以下情况:在一次航海旅行中,你的船抛锚靠岸了,你上岸去找水,途中你还捡了些你喜欢的贝壳,或者买个洋葱。但是,你的所有注意力必须一直集中在那艘船上,注意船长什么时候呼叫大家上船继续航行。当船长呼叫时,你必须立刻放下手中所有的东西,否则你就会被手脚捆绑得像只羊一样抛到船上。生活也是这样。生活给你老婆孩子,而不是洋葱贝壳。如果生活的船长呼叫了,你必须离开他们,立马跑到船上,而不是光顾着他们。如果你年纪大了,那你就不能离开船太远,否则你可能来不及回到船上。\n\n8. 不要苛求生活给予你所有你想要的,该发生的就会发生,随遇而安就好。\n\n9. 疾病影响的只是你的身体,而不是你选择的能力,除非那是你的选择。瘸的是腿,而不是你的脑子。不管发生什么事,只要这么跟自己说,你就会明白困难阻碍的是事物,而不是你。\n\n10. 对于每一件发生的事,检视你自己的能力,问你自己能够用哪些能力从每一件事情中获得什么适当的用处。遇到一个十分有吸引力的人时,你就会发现你的自控就是你的能力。当你痛苦时,你会发现自己的坚强。听到坏话时,你会发现自己的耐心。形成了这样的习惯之后,你就不会被事物的表象所影响。\n\n11. 不要说:“我失去了什么”。而应该说:“我归还了什么”。如果你的孩子或者妻子不幸离世了,你不是失去他们了,而是他们回归了。如果你的房子被夺走了,同样的,你是归还它们了。你可能会说:“可是那些夺走我房子的人是坏人!“。可是,给予你的人让谁来夺走你的房子真的那么重要吗?当你拥有时,照顾好它,但不要把它当做永久财物,就当自己是一个在那暂住的旅行者。\n\n12. 如果你想要提高自己,那就要拒绝以下思考方式:“如果我忽视那些琐事,那我就没有收入;如果我不更正我的仆人,那他们就会变坏”。 如果能够免于悲伤和恐惧,即使死于饥饿,那也比富得流油但备受精神困扰好得多。比起坏仆人,难道你的开心不是更重要吗?\n\n 如果你想要让自己变得更好,那就从小事做起。油洒了,酒被偷了,没关系,告诉你自己:“那只不过是平静生活的一点点代价。任何事情都是有代价的”。当你召集你的仆人时,他们可能不会来,也可能来了但是做的事情不合你意。但是他们并没有重要得以至于你必须打破自己的平静。\n\n13. 如果你想要让自己变得更好,那就不要在乎被人认为你是愚蠢的。不要希望别人认为你无所不知。即使你看上去好像对别人来说很重要,也不要被这种虚名欺骗。因为想要既保持内心平和又拥有外在事物是非常困难的。当你专注于二者之一时,你必然会忽略剩下的那个。\n\n14. 如果你希望你的家人、朋友长生不老,那是很愚蠢的想法。因为生死是在你控制范围之外的,是关乎他人的。同样地,如果你希望你的仆人不犯错,那你和傻瓜无异,因为你希望错误不是错误。但是,如果你希望你的欲望不带来失望,那是在你所能控制的范围之内的。练习控制你所能控制的。一个能够控制自己的喜恶的人,是自己生活的主人。这样的人,是真正自由的,不会成为被自己的欲望控制的奴隶,不会喜欢或者厌恶那些受别人控制的事物。\n\n15. 记住生活就像是一个晚餐聚会一样。如果别人递给你一盘食物,你应该伸出手去接,舀起适当份量给自己。如果盘子从你身边递过,不要试图去截取。如果还没轮到你这,不要起身去拿,而是等着别人递到你面前。用相同的态度对待孩子,配偶,财物,公共职位,这样你最终自然就会成为诸神宴会的搭档。如果你不仅能够做到这些,还能够做到不去拿你面前的食物,甚至是有能力拒绝你自己的欲望,这样你不仅仅能够成为诸神宴会的搭档,你还能进入他们的国度,成为为他们的一员。像Diogenes, Heraclitus这些人就是因为他们的尊贵行为而被视为神一般神圣。\n\n16. 当你看到别人因为孩子出国了,或者离世了,或者因为被琐事困扰而哭泣伤心时,不要让这些情感表象误导你。你必须作出自己的判断,明白他的伤心难过不是因为发生的事情本身,因为其他同样身处其中的人并没有受到同样的影响。他之所以受到那么大的困扰,是因为他自己本身对事情的判断。不要让自己和他一样受影响,不要让自己一样受困扰,不管是外在表现还是内心感受上。\n\n17. 记住你只是一出戏里的一个演员,而戏份角色并不是由你决定的。不管角色故事长短,不管你是一个穷人,瘸子,政府官员,或者是一个很私密的人,把你的角色演好演自然了就行。把分配给你的角色演好,那是你的本分;而到底是哪个角色,那不是由你决定的。\n\n18. 如果一只乌鸦向你预示不幸的事即将发生,不要让你内心的平静被这个表象破坏。要即刻告诉自己,“我不知道会发生什么,我不知道我的身体,财物,名声,或者家人会受什么影响,如果我愿意理性地去想,那么所有的这些恶兆就会变成幸运,因为我可以控制我要用什么态度去对待这些事情。不管发生什么,我都可以从中获得对我有利的。\n\n19. 如果你不去参与在你控制范围之外的任何战斗,那你就不会被打败。当你看到那些声名显赫,社会地位高,或者在任何方面做得很好的人,不要着急认为他们是开心的。因为如果我们清楚明白幸福只在于我们所能够控制的范围内,那我们就不会去羡慕或者攀比。不要向往头衔,而是要向往内心自由和平静。而要做到这一点,唯一的途径是要看轻我们控制范围之外的一切事物。\n\n20. 记住,那些对你出言不逊或者动手的人他本身并不是一种羞辱,而是代表那些言行的原则让你感觉到被羞辱。如果有人激怒你了,那是你对这种行为的观点激怒了你。试着不要被事情的表象牵引你的情感。给予适当的时间和稍作休息,你就能够很好地调整控制自己的情感。\n\n21. 把死亡和流放这些看似可怕的事看作是日常,那你就赢了。不用害怕贫穷,也不要刻意贪求任何东西。\n\n22. 如果你真心希望从哲学中获益,那么就要做好被众人嘲笑的准备:“她这是准备要成为一个哲学家呢”,“瞧她那傲慢的样子”……这个时候,你该做的,不是摆起傲慢的样子,而是要以神圣的态度忠诚于你所认定的,这样总有一天嘲笑你的人会开始尊敬你崇拜你。但是如果你被这些嘲笑打败,那你就成了双重的笑话。\n\n23. 如果你为了取悦他人而把你的注意力转移到那些外在的你无法控制的事物上,那么恭喜你,你已经成功地毁了你自己的生活了。\n\n24. 不要让以下这些思考方式困扰你:“我将会颜面丢尽,而且什么都不是。”耻辱是邪恶的,我们不应该被耻辱感所控制。因为获取权力或着被人嘲笑,这些都在你的控制范围之外。我们不用为任何在我们控制范围之外的事而感到耻辱。在我们可控范围之内,我们是自由的,能够左右我们自己的事情,是自我的主人-从这个角度看,我们永远不会什么都不是。“可是我帮不了我的朋友啊”,你可能会这么说。可是,怎么算是帮助朋友呢?你不能给他们钱,或者帮他们成为罗马市民。这些都是你所能控制范围之内的,是他们自己应该处理的事情。而且,如果这些都是你自己所没有的,那你怎么能够给他们呢?你可能会说:“如果我帮助他们获得这些的话,说不定我也能够得到一份呢“。如果我能够在保存我自己的尊严,忠诚和思想得到这些的话,请你帮我指明道路。可是如果你要我损害自己去得到你的利益,那这样的做法不仅不公平,而且愚蠢至极。\n\n25. 如果别人,而不是你,被邀请去宴会,或者被赞美,或者被别人咨询,不要懊恼。如果这些是好事,你应该为他人高兴。如果是坏事,不要难过。记住:这些都是在你的控制范围之外的,这样的对待一般是有对应的代价的。如果你不愿意付出这样的代价而希望得到同样的对待,那是不公平的。比如说别人用50分买了一棵生菜,但是你不想花这50分,那你就不应该认为拥有生菜的人占了便宜。那个人付出50分得到了生菜,而你口袋里还有那没有花出去的50分。同理,宴会邀请,别人的赞美,这些都是有代价的。如果你觉得这些对你是有价值的,那你就要付出同等的价值去拥有。如果你不付出就想要得到这些,那么你就是个贪得无厌的傻瓜。换个角度想,在决定不和别人交换价值的时候,你真的什么都没有得到吗?不是的:你得到了不赞美你不想赞美的人的自由,而且也不需要容忍你不想容忍的行为。\n\n26. 记住:很多事情不应该分自我或者他人。举个例子,如果邻居家的孩子打破了个杯子或者其他什么东西,我们很容易会说:“没事的,打碎东西是正常的”。可是如果打碎的是你自己的杯子呢?你应该作出相同的反应,而不是心生懊恼。同理,当别人的孩子或者妻子去世了,我们知道死亡的悲剧有时候是不可避免的,但是如果发生在我们自己身上的时候,我们却心如刀割。但是,我们应该清醒的认识到类似的悲剧不是我们能够控制的,我们所能够控制的是自己的情绪和反应,因为即使是发生在自己的身上,死亡本身并没有因为我们和死者的关系而变的更糟糕。\n\n27. 立一个靶子的目的,不是为了射失它(靶子的目的都是为了让人射中它)。那么同样的道理,大道创造出一个“恶”的事物(至少看起来如此),不是为了让人绕开它。\n\n28. 如果别人把你的身体交给一个路上遇到的陌生人,你一定会很生气。可是当别人用恶语打击你的时候,你为什么要心甘情愿地让别人控制你的思想,困惑你呢?\n\n29. 做每件事情都要考虑缘由和后果之后才能开始行动。如果你兴高采烈地开始而没有考虑可能发生的后果,当某些不好的后果开始出现时,你就会停止前进。拿参加奥林匹克赛事为例子。如果你把所有前因后果都考虑周全后认为参加比赛对你时有益的,那就全力以赴。其中,应该考虑的事情包括:你要遵守规则,节制饮食;不管风吹日晒雨淋都要雷打不动地坚持按时锻炼;你不能喝凉水活着酒。你必须全身心地、完全忘我地投入训练。而且,要做思想准备准备,比赛中你有可能会摔入沟里,胳膊脱臼,脚踝受伤,吃入尘土,被鞭打,甚至最后以失败告终。当你评估完所有的可能性之后还是一心想比赛,那就以战争的姿态出发。否则,你就会像孩子过家家一样:一会扮摔跤手,一会扮角斗士,一会吹喇叭,一会又想参加戏剧演出。这样,即使你什么都做过,但是什么都不是。就想大猩猩一样,你模仿你所看到的一切,不停地换把戏可能是一件好玩的事,但是你很快就玩腻了。你从来都没有完全投入过任何事,没有深度地从各个角度考虑和研究所有相关的细节,而只是凭一时的兴趣蜻蜓点水般地接触了各种行业。有些人当他们看到一个人说话的方式和Euphrates十分相像(不过事实上,真的有人能和Euphrates一样犀利善辩吗?),他们认为自己也能够拥有和哲学家一样的思想。但是,如果你细想一下,如果你想要成为一个摔跤手,那么你必须具备有摔跤手的宽阔肩膀,强有力的背部和大腿。但是每一个人的身体构造都是不一样的,你必须具有必备的条件才能称为一个好的摔跤手。同理,要想成为一个哲学家,你不能像你现在这样随心所欲地吃喝,不能让愤怒和不满控制你的情绪,你必须细心观察,劳作,控制自己的欲望,你必须能够忍受孤独,仆人的不敬,和外人的嘲笑,你必须能够接受别人在其他方面做得比你好。如果你已经仔细考虑过这些情况,如果你认为如果做到以上这些可以让你享受自由和宁静,那就尽情去追求哲学家的道路。如果你无法做到这些的话,那么就请不要继续,不要像孩子一样,一会试试做哲学,一会又想当政治家,演讲者,或者凯撒的军官。这些追求是互相矛盾的,你只能成为其中一个,不管做得好坏。你必须培养你自己内在的能够掌控行为的能力,或者外在的技术,二者只能取其一。\n\n30. 一个人的责任是由和别人的关系定义和衡量的。如果一个人拥有父亲的角色,那么他就有以下权利:他的孩子要照顾他,遵从他,耐心听他训话和教导。那如果他不是一个好父亲呢?他也应该受到同等的对待,因为我们无法选择我们的父亲是谁。不管他做了什么,你必须做到让自己心安理得。因为只有你能够让别人的行为伤害到你。当你觉得你被伤害了,那你就会被伤害。如果你以同样的逻辑看待邻居,市民,将军这些不同的角色,你就能够清楚地明白与这些角色相对应的社会责任。","slug":"读书笔记/斯多葛主义手册","published":1,"updated":"2019-08-14T06:31:28.000Z","_id":"cka1y597o00124huu1wtf5iy9","comments":1,"layout":"post","photos":[],"link":"","content":"
    \n
  1. \n

    世间的事,有些可控,有些不可控。可控的有:观点,追求,欲望,和喜恶等。这些都是我们自己可以做出选择的。不可控的是身体,财物,名声,指令等。这些我们都无法选择。

    \n

    可控范围之内的东西在本质上是自由的,不被束缚、阻碍的。那些不可控的是虚的,是被奴役的,是我们受控于他人。记住,如果你觉得那些不可控的事物是自由的,那些受控于别人的也是你的,那么你就会被控制,被束缚。你会悲痛,你会受扰,你会指责神以及他人。但如果你只专注于你所能控制的,不被他人所拥有的干扰,那么就没有人能够影响你、束缚你。并且,你不会把过错推在他人身上。你不会去做违背你的意志的事。你不会有敌人。你也不会被伤害。

    \n

    把这些当做你的目标,不让自己受那些没有意义的事诱惑,哪怕就一点点也不可以。放弃那些不可控的。如果你既想把握住可控的,又想拥有财富和权力,那么你将会什么都得不到,更不用说幸福和自由-因为幸福和自由是依赖于可控事物。

    \n

    尽你最大的努力。这样你就可以对看似艰难的每一件事说:“你只不过是看起来艰难而已。” 然后比照你为自己制定的原则:这件事是否可控。如果在你控制范围之外,那么结果就无关乎于你。

    \n
  2. \n
  3. \n

    欲望要求你去追求你想要的;厌恶则让你尽量避免你所讨厌的。但是,如果你得不到你想要的,你就会十分失望;如果你无法避免你所讨厌的,那你就会被厌恶扭曲。那么,如果你只讨厌那些在你出自本质所做选择的对立事物(即在你控制范围内你不会选择的事物),那么你就永远不需要去为之伤神。但是,如果你厌恶疾病、死亡、贫穷等你无法选择和改变的,那你就会被厌恶扭曲。不厌恶你所不能控制的,把厌恶限制在和你本性对立的事物。但是,就目前来说,压制你的欲望:因为如果你追求任何可控范围之外的事物,那你就必然会失望。不要轻易追求或者厌恶。

    \n
  4. \n
  5. \n

    对于给你带来乐趣、有用处以及你十分喜欢的东西,从最不重要的事情开始,记得提醒你自己:他们真正的本质是什么。比如说,你很喜欢某个陶瓷杯,提醒你自己那只是因为你喜欢陶瓷杯而已,而不在于具体是哪个杯子。这样,如果杯子碎了,你也不会太伤心。当你亲吻你的家人时,提醒你自己你只是在亲吻和你亲近的人,这样当他们离世时,你就不会太难过。

    \n
  6. \n
  7. \n

    当你做事情时,提醒你自己事情的本质是什么,你可能遇到哪些情况。比如说洗澡。在你洗澡之前,先想想洗澡时会发生哪些事情。有的人可能会把水溅得哪都是,有人可能会推娜,有人会诅咒,有人会偷东西。这样你在洗澡之前就可以跟自己说:“我现在要去洗澡了,任何这些事都有可能发生,但是这不是我能控制的,所以我会保持好的心态”。如果你以同样的心态去对待任何其他事情,你内心的平和就不会被打扰。因为你可以对自己说:”我希望的不仅仅是洗澡,还有不被任何意外困扰”。

    \n
  8. \n
  9. \n

    人内心困扰时,通常不是被事物本身困扰,而是被他们自己的原则和概念所困扰。比如说,死亡本身并不可怕,要不然苏格拉底面临死亡时该有多么惊慌。我们对死亡的恐惧是源于我们对死亡的概念:死亡是可怕的。当我们被困扰、阻碍,伤心难过时,我们不要从事物本身或者他人身上找原因,而应该反省我们自己,还有我们的原则。一个还不通明的人,会把自己的糟糕情况怪罪于他人。一个刚刚开始学习处理这些情况的人,会从自己身上找原因。而一个已经通彻的人,既不会怪罪别人,也不会苛求自己。

    \n
  10. \n
  11. \n

    不要为任何身外之物骄傲。一匹马可以因为自己的英爽豪气自豪,因为这是它本身拥有的。但是如果你因为拥有这样一匹马儿骄傲,事实上,你所自豪的,不过是马所拥有的好。那么,什么才是属于你的呢?你对事物的反应和态度。如果你对任何事物的形态的处之泰然,那么你就可以为你的理性自豪,因为这是属于你的。

    \n
  12. \n
  13. \n

    想象以下情况:在一次航海旅行中,你的船抛锚靠岸了,你上岸去找水,途中你还捡了些你喜欢的贝壳,或者买个洋葱。但是,你的所有注意力必须一直集中在那艘船上,注意船长什么时候呼叫大家上船继续航行。当船长呼叫时,你必须立刻放下手中所有的东西,否则你就会被手脚捆绑得像只羊一样抛到船上。生活也是这样。生活给你老婆孩子,而不是洋葱贝壳。如果生活的船长呼叫了,你必须离开他们,立马跑到船上,而不是光顾着他们。如果你年纪大了,那你就不能离开船太远,否则你可能来不及回到船上。

    \n
  14. \n
  15. \n

    不要苛求生活给予你所有你想要的,该发生的就会发生,随遇而安就好。

    \n
  16. \n
  17. \n

    疾病影响的只是你的身体,而不是你选择的能力,除非那是你的选择。瘸的是腿,而不是你的脑子。不管发生什么事,只要这么跟自己说,你就会明白困难阻碍的是事物,而不是你。

    \n
  18. \n
  19. \n

    对于每一件发生的事,检视你自己的能力,问你自己能够用哪些能力从每一件事情中获得什么适当的用处。遇到一个十分有吸引力的人时,你就会发现你的自控就是你的能力。当你痛苦时,你会发现自己的坚强。听到坏话时,你会发现自己的耐心。形成了这样的习惯之后,你就不会被事物的表象所影响。

    \n
  20. \n
  21. \n

    不要说:“我失去了什么”。而应该说:“我归还了什么”。如果你的孩子或者妻子不幸离世了,你不是失去他们了,而是他们回归了。如果你的房子被夺走了,同样的,你是归还它们了。你可能会说:“可是那些夺走我房子的人是坏人!“。可是,给予你的人让谁来夺走你的房子真的那么重要吗?当你拥有时,照顾好它,但不要把它当做永久财物,就当自己是一个在那暂住的旅行者。

    \n
  22. \n
  23. \n

    如果你想要提高自己,那就要拒绝以下思考方式:“如果我忽视那些琐事,那我就没有收入;如果我不更正我的仆人,那他们就会变坏”。 如果能够免于悲伤和恐惧,即使死于饥饿,那也比富得流油但备受精神困扰好得多。比起坏仆人,难道你的开心不是更重要吗?

    \n

    如果你想要让自己变得更好,那就从小事做起。油洒了,酒被偷了,没关系,告诉你自己:“那只不过是平静生活的一点点代价。任何事情都是有代价的”。当你召集你的仆人时,他们可能不会来,也可能来了但是做的事情不合你意。但是他们并没有重要得以至于你必须打破自己的平静。

    \n
  24. \n
  25. \n

    如果你想要让自己变得更好,那就不要在乎被人认为你是愚蠢的。不要希望别人认为你无所不知。即使你看上去好像对别人来说很重要,也不要被这种虚名欺骗。因为想要既保持内心平和又拥有外在事物是非常困难的。当你专注于二者之一时,你必然会忽略剩下的那个。

    \n
  26. \n
  27. \n

    如果你希望你的家人、朋友长生不老,那是很愚蠢的想法。因为生死是在你控制范围之外的,是关乎他人的。同样地,如果你希望你的仆人不犯错,那你和傻瓜无异,因为你希望错误不是错误。但是,如果你希望你的欲望不带来失望,那是在你所能控制的范围之内的。练习控制你所能控制的。一个能够控制自己的喜恶的人,是自己生活的主人。这样的人,是真正自由的,不会成为被自己的欲望控制的奴隶,不会喜欢或者厌恶那些受别人控制的事物。

    \n
  28. \n
  29. \n

    记住生活就像是一个晚餐聚会一样。如果别人递给你一盘食物,你应该伸出手去接,舀起适当份量给自己。如果盘子从你身边递过,不要试图去截取。如果还没轮到你这,不要起身去拿,而是等着别人递到你面前。用相同的态度对待孩子,配偶,财物,公共职位,这样你最终自然就会成为诸神宴会的搭档。如果你不仅能够做到这些,还能够做到不去拿你面前的食物,甚至是有能力拒绝你自己的欲望,这样你不仅仅能够成为诸神宴会的搭档,你还能进入他们的国度,成为为他们的一员。像Diogenes, Heraclitus这些人就是因为他们的尊贵行为而被视为神一般神圣。

    \n
  30. \n
  31. \n

    当你看到别人因为孩子出国了,或者离世了,或者因为被琐事困扰而哭泣伤心时,不要让这些情感表象误导你。你必须作出自己的判断,明白他的伤心难过不是因为发生的事情本身,因为其他同样身处其中的人并没有受到同样的影响。他之所以受到那么大的困扰,是因为他自己本身对事情的判断。不要让自己和他一样受影响,不要让自己一样受困扰,不管是外在表现还是内心感受上。

    \n
  32. \n
  33. \n

    记住你只是一出戏里的一个演员,而戏份角色并不是由你决定的。不管角色故事长短,不管你是一个穷人,瘸子,政府官员,或者是一个很私密的人,把你的角色演好演自然了就行。把分配给你的角色演好,那是你的本分;而到底是哪个角色,那不是由你决定的。

    \n
  34. \n
  35. \n

    如果一只乌鸦向你预示不幸的事即将发生,不要让你内心的平静被这个表象破坏。要即刻告诉自己,“我不知道会发生什么,我不知道我的身体,财物,名声,或者家人会受什么影响,如果我愿意理性地去想,那么所有的这些恶兆就会变成幸运,因为我可以控制我要用什么态度去对待这些事情。不管发生什么,我都可以从中获得对我有利的。

    \n
  36. \n
  37. \n

    如果你不去参与在你控制范围之外的任何战斗,那你就不会被打败。当你看到那些声名显赫,社会地位高,或者在任何方面做得很好的人,不要着急认为他们是开心的。因为如果我们清楚明白幸福只在于我们所能够控制的范围内,那我们就不会去羡慕或者攀比。不要向往头衔,而是要向往内心自由和平静。而要做到这一点,唯一的途径是要看轻我们控制范围之外的一切事物。

    \n
  38. \n
  39. \n

    记住,那些对你出言不逊或者动手的人他本身并不是一种羞辱,而是代表那些言行的原则让你感觉到被羞辱。如果有人激怒你了,那是你对这种行为的观点激怒了你。试着不要被事情的表象牵引你的情感。给予适当的时间和稍作休息,你就能够很好地调整控制自己的情感。

    \n
  40. \n
  41. \n

    把死亡和流放这些看似可怕的事看作是日常,那你就赢了。不用害怕贫穷,也不要刻意贪求任何东西。

    \n
  42. \n
  43. \n

    如果你真心希望从哲学中获益,那么就要做好被众人嘲笑的准备:“她这是准备要成为一个哲学家呢”,“瞧她那傲慢的样子”……这个时候,你该做的,不是摆起傲慢的样子,而是要以神圣的态度忠诚于你所认定的,这样总有一天嘲笑你的人会开始尊敬你崇拜你。但是如果你被这些嘲笑打败,那你就成了双重的笑话。

    \n
  44. \n
  45. \n

    如果你为了取悦他人而把你的注意力转移到那些外在的你无法控制的事物上,那么恭喜你,你已经成功地毁了你自己的生活了。

    \n
  46. \n
  47. \n

    不要让以下这些思考方式困扰你:“我将会颜面丢尽,而且什么都不是。”耻辱是邪恶的,我们不应该被耻辱感所控制。因为获取权力或着被人嘲笑,这些都在你的控制范围之外。我们不用为任何在我们控制范围之外的事而感到耻辱。在我们可控范围之内,我们是自由的,能够左右我们自己的事情,是自我的主人-从这个角度看,我们永远不会什么都不是。“可是我帮不了我的朋友啊”,你可能会这么说。可是,怎么算是帮助朋友呢?你不能给他们钱,或者帮他们成为罗马市民。这些都是你所能控制范围之内的,是他们自己应该处理的事情。而且,如果这些都是你自己所没有的,那你怎么能够给他们呢?你可能会说:“如果我帮助他们获得这些的话,说不定我也能够得到一份呢“。如果我能够在保存我自己的尊严,忠诚和思想得到这些的话,请你帮我指明道路。可是如果你要我损害自己去得到你的利益,那这样的做法不仅不公平,而且愚蠢至极。

    \n
  48. \n
  49. \n

    如果别人,而不是你,被邀请去宴会,或者被赞美,或者被别人咨询,不要懊恼。如果这些是好事,你应该为他人高兴。如果是坏事,不要难过。记住:这些都是在你的控制范围之外的,这样的对待一般是有对应的代价的。如果你不愿意付出这样的代价而希望得到同样的对待,那是不公平的。比如说别人用50分买了一棵生菜,但是你不想花这50分,那你就不应该认为拥有生菜的人占了便宜。那个人付出50分得到了生菜,而你口袋里还有那没有花出去的50分。同理,宴会邀请,别人的赞美,这些都是有代价的。如果你觉得这些对你是有价值的,那你就要付出同等的价值去拥有。如果你不付出就想要得到这些,那么你就是个贪得无厌的傻瓜。换个角度想,在决定不和别人交换价值的时候,你真的什么都没有得到吗?不是的:你得到了不赞美你不想赞美的人的自由,而且也不需要容忍你不想容忍的行为。

    \n
  50. \n
  51. \n

    记住:很多事情不应该分自我或者他人。举个例子,如果邻居家的孩子打破了个杯子或者其他什么东西,我们很容易会说:“没事的,打碎东西是正常的”。可是如果打碎的是你自己的杯子呢?你应该作出相同的反应,而不是心生懊恼。同理,当别人的孩子或者妻子去世了,我们知道死亡的悲剧有时候是不可避免的,但是如果发生在我们自己身上的时候,我们却心如刀割。但是,我们应该清醒的认识到类似的悲剧不是我们能够控制的,我们所能够控制的是自己的情绪和反应,因为即使是发生在自己的身上,死亡本身并没有因为我们和死者的关系而变的更糟糕。

    \n
  52. \n
  53. \n

    立一个靶子的目的,不是为了射失它(靶子的目的都是为了让人射中它)。那么同样的道理,大道创造出一个“恶”的事物(至少看起来如此),不是为了让人绕开它。

    \n
  54. \n
  55. \n

    如果别人把你的身体交给一个路上遇到的陌生人,你一定会很生气。可是当别人用恶语打击你的时候,你为什么要心甘情愿地让别人控制你的思想,困惑你呢?

    \n
  56. \n
  57. \n

    做每件事情都要考虑缘由和后果之后才能开始行动。如果你兴高采烈地开始而没有考虑可能发生的后果,当某些不好的后果开始出现时,你就会停止前进。拿参加奥林匹克赛事为例子。如果你把所有前因后果都考虑周全后认为参加比赛对你时有益的,那就全力以赴。其中,应该考虑的事情包括:你要遵守规则,节制饮食;不管风吹日晒雨淋都要雷打不动地坚持按时锻炼;你不能喝凉水活着酒。你必须全身心地、完全忘我地投入训练。而且,要做思想准备准备,比赛中你有可能会摔入沟里,胳膊脱臼,脚踝受伤,吃入尘土,被鞭打,甚至最后以失败告终。当你评估完所有的可能性之后还是一心想比赛,那就以战争的姿态出发。否则,你就会像孩子过家家一样:一会扮摔跤手,一会扮角斗士,一会吹喇叭,一会又想参加戏剧演出。这样,即使你什么都做过,但是什么都不是。就想大猩猩一样,你模仿你所看到的一切,不停地换把戏可能是一件好玩的事,但是你很快就玩腻了。你从来都没有完全投入过任何事,没有深度地从各个角度考虑和研究所有相关的细节,而只是凭一时的兴趣蜻蜓点水般地接触了各种行业。有些人当他们看到一个人说话的方式和Euphrates十分相像(不过事实上,真的有人能和Euphrates一样犀利善辩吗?),他们认为自己也能够拥有和哲学家一样的思想。但是,如果你细想一下,如果你想要成为一个摔跤手,那么你必须具备有摔跤手的宽阔肩膀,强有力的背部和大腿。但是每一个人的身体构造都是不一样的,你必须具有必备的条件才能称为一个好的摔跤手。同理,要想成为一个哲学家,你不能像你现在这样随心所欲地吃喝,不能让愤怒和不满控制你的情绪,你必须细心观察,劳作,控制自己的欲望,你必须能够忍受孤独,仆人的不敬,和外人的嘲笑,你必须能够接受别人在其他方面做得比你好。如果你已经仔细考虑过这些情况,如果你认为如果做到以上这些可以让你享受自由和宁静,那就尽情去追求哲学家的道路。如果你无法做到这些的话,那么就请不要继续,不要像孩子一样,一会试试做哲学,一会又想当政治家,演讲者,或者凯撒的军官。这些追求是互相矛盾的,你只能成为其中一个,不管做得好坏。你必须培养你自己内在的能够掌控行为的能力,或者外在的技术,二者只能取其一。

    \n
  58. \n
  59. \n

    一个人的责任是由和别人的关系定义和衡量的。如果一个人拥有父亲的角色,那么他就有以下权利:他的孩子要照顾他,遵从他,耐心听他训话和教导。那如果他不是一个好父亲呢?他也应该受到同等的对待,因为我们无法选择我们的父亲是谁。不管他做了什么,你必须做到让自己心安理得。因为只有你能够让别人的行为伤害到你。当你觉得你被伤害了,那你就会被伤害。如果你以同样的逻辑看待邻居,市民,将军这些不同的角色,你就能够清楚地明白与这些角色相对应的社会责任。

    \n
  60. \n
","site":{"data":{}},"excerpt":"

\n

世间的事,有些可控,有些不可控。可控的有:观点,追求,欲望,和喜恶等。这些都是我们自己可以做出选择的。不可控的是身体,财物,名声,指令等。这些我们都无法选择。

","more":"
    \n
  1. \n

    世间的事,有些可控,有些不可控。可控的有:观点,追求,欲望,和喜恶等。这些都是我们自己可以做出选择的。不可控的是身体,财物,名声,指令等。这些我们都无法选择。

    \n

    可控范围之内的东西在本质上是自由的,不被束缚、阻碍的。那些不可控的是虚的,是被奴役的,是我们受控于他人。记住,如果你觉得那些不可控的事物是自由的,那些受控于别人的也是你的,那么你就会被控制,被束缚。你会悲痛,你会受扰,你会指责神以及他人。但如果你只专注于你所能控制的,不被他人所拥有的干扰,那么就没有人能够影响你、束缚你。并且,你不会把过错推在他人身上。你不会去做违背你的意志的事。你不会有敌人。你也不会被伤害。

    \n

    把这些当做你的目标,不让自己受那些没有意义的事诱惑,哪怕就一点点也不可以。放弃那些不可控的。如果你既想把握住可控的,又想拥有财富和权力,那么你将会什么都得不到,更不用说幸福和自由-因为幸福和自由是依赖于可控事物。

    \n

    尽你最大的努力。这样你就可以对看似艰难的每一件事说:“你只不过是看起来艰难而已。” 然后比照你为自己制定的原则:这件事是否可控。如果在你控制范围之外,那么结果就无关乎于你。

    \n
  2. \n
  3. \n

    欲望要求你去追求你想要的;厌恶则让你尽量避免你所讨厌的。但是,如果你得不到你想要的,你就会十分失望;如果你无法避免你所讨厌的,那你就会被厌恶扭曲。那么,如果你只讨厌那些在你出自本质所做选择的对立事物(即在你控制范围内你不会选择的事物),那么你就永远不需要去为之伤神。但是,如果你厌恶疾病、死亡、贫穷等你无法选择和改变的,那你就会被厌恶扭曲。不厌恶你所不能控制的,把厌恶限制在和你本性对立的事物。但是,就目前来说,压制你的欲望:因为如果你追求任何可控范围之外的事物,那你就必然会失望。不要轻易追求或者厌恶。

    \n
  4. \n
  5. \n

    对于给你带来乐趣、有用处以及你十分喜欢的东西,从最不重要的事情开始,记得提醒你自己:他们真正的本质是什么。比如说,你很喜欢某个陶瓷杯,提醒你自己那只是因为你喜欢陶瓷杯而已,而不在于具体是哪个杯子。这样,如果杯子碎了,你也不会太伤心。当你亲吻你的家人时,提醒你自己你只是在亲吻和你亲近的人,这样当他们离世时,你就不会太难过。

    \n
  6. \n
  7. \n

    当你做事情时,提醒你自己事情的本质是什么,你可能遇到哪些情况。比如说洗澡。在你洗澡之前,先想想洗澡时会发生哪些事情。有的人可能会把水溅得哪都是,有人可能会推娜,有人会诅咒,有人会偷东西。这样你在洗澡之前就可以跟自己说:“我现在要去洗澡了,任何这些事都有可能发生,但是这不是我能控制的,所以我会保持好的心态”。如果你以同样的心态去对待任何其他事情,你内心的平和就不会被打扰。因为你可以对自己说:”我希望的不仅仅是洗澡,还有不被任何意外困扰”。

    \n
  8. \n
  9. \n

    人内心困扰时,通常不是被事物本身困扰,而是被他们自己的原则和概念所困扰。比如说,死亡本身并不可怕,要不然苏格拉底面临死亡时该有多么惊慌。我们对死亡的恐惧是源于我们对死亡的概念:死亡是可怕的。当我们被困扰、阻碍,伤心难过时,我们不要从事物本身或者他人身上找原因,而应该反省我们自己,还有我们的原则。一个还不通明的人,会把自己的糟糕情况怪罪于他人。一个刚刚开始学习处理这些情况的人,会从自己身上找原因。而一个已经通彻的人,既不会怪罪别人,也不会苛求自己。

    \n
  10. \n
  11. \n

    不要为任何身外之物骄傲。一匹马可以因为自己的英爽豪气自豪,因为这是它本身拥有的。但是如果你因为拥有这样一匹马儿骄傲,事实上,你所自豪的,不过是马所拥有的好。那么,什么才是属于你的呢?你对事物的反应和态度。如果你对任何事物的形态的处之泰然,那么你就可以为你的理性自豪,因为这是属于你的。

    \n
  12. \n
  13. \n

    想象以下情况:在一次航海旅行中,你的船抛锚靠岸了,你上岸去找水,途中你还捡了些你喜欢的贝壳,或者买个洋葱。但是,你的所有注意力必须一直集中在那艘船上,注意船长什么时候呼叫大家上船继续航行。当船长呼叫时,你必须立刻放下手中所有的东西,否则你就会被手脚捆绑得像只羊一样抛到船上。生活也是这样。生活给你老婆孩子,而不是洋葱贝壳。如果生活的船长呼叫了,你必须离开他们,立马跑到船上,而不是光顾着他们。如果你年纪大了,那你就不能离开船太远,否则你可能来不及回到船上。

    \n
  14. \n
  15. \n

    不要苛求生活给予你所有你想要的,该发生的就会发生,随遇而安就好。

    \n
  16. \n
  17. \n

    疾病影响的只是你的身体,而不是你选择的能力,除非那是你的选择。瘸的是腿,而不是你的脑子。不管发生什么事,只要这么跟自己说,你就会明白困难阻碍的是事物,而不是你。

    \n
  18. \n
  19. \n

    对于每一件发生的事,检视你自己的能力,问你自己能够用哪些能力从每一件事情中获得什么适当的用处。遇到一个十分有吸引力的人时,你就会发现你的自控就是你的能力。当你痛苦时,你会发现自己的坚强。听到坏话时,你会发现自己的耐心。形成了这样的习惯之后,你就不会被事物的表象所影响。

    \n
  20. \n
  21. \n

    不要说:“我失去了什么”。而应该说:“我归还了什么”。如果你的孩子或者妻子不幸离世了,你不是失去他们了,而是他们回归了。如果你的房子被夺走了,同样的,你是归还它们了。你可能会说:“可是那些夺走我房子的人是坏人!“。可是,给予你的人让谁来夺走你的房子真的那么重要吗?当你拥有时,照顾好它,但不要把它当做永久财物,就当自己是一个在那暂住的旅行者。

    \n
  22. \n
  23. \n

    如果你想要提高自己,那就要拒绝以下思考方式:“如果我忽视那些琐事,那我就没有收入;如果我不更正我的仆人,那他们就会变坏”。 如果能够免于悲伤和恐惧,即使死于饥饿,那也比富得流油但备受精神困扰好得多。比起坏仆人,难道你的开心不是更重要吗?

    \n

    如果你想要让自己变得更好,那就从小事做起。油洒了,酒被偷了,没关系,告诉你自己:“那只不过是平静生活的一点点代价。任何事情都是有代价的”。当你召集你的仆人时,他们可能不会来,也可能来了但是做的事情不合你意。但是他们并没有重要得以至于你必须打破自己的平静。

    \n
  24. \n
  25. \n

    如果你想要让自己变得更好,那就不要在乎被人认为你是愚蠢的。不要希望别人认为你无所不知。即使你看上去好像对别人来说很重要,也不要被这种虚名欺骗。因为想要既保持内心平和又拥有外在事物是非常困难的。当你专注于二者之一时,你必然会忽略剩下的那个。

    \n
  26. \n
  27. \n

    如果你希望你的家人、朋友长生不老,那是很愚蠢的想法。因为生死是在你控制范围之外的,是关乎他人的。同样地,如果你希望你的仆人不犯错,那你和傻瓜无异,因为你希望错误不是错误。但是,如果你希望你的欲望不带来失望,那是在你所能控制的范围之内的。练习控制你所能控制的。一个能够控制自己的喜恶的人,是自己生活的主人。这样的人,是真正自由的,不会成为被自己的欲望控制的奴隶,不会喜欢或者厌恶那些受别人控制的事物。

    \n
  28. \n
  29. \n

    记住生活就像是一个晚餐聚会一样。如果别人递给你一盘食物,你应该伸出手去接,舀起适当份量给自己。如果盘子从你身边递过,不要试图去截取。如果还没轮到你这,不要起身去拿,而是等着别人递到你面前。用相同的态度对待孩子,配偶,财物,公共职位,这样你最终自然就会成为诸神宴会的搭档。如果你不仅能够做到这些,还能够做到不去拿你面前的食物,甚至是有能力拒绝你自己的欲望,这样你不仅仅能够成为诸神宴会的搭档,你还能进入他们的国度,成为为他们的一员。像Diogenes, Heraclitus这些人就是因为他们的尊贵行为而被视为神一般神圣。

    \n
  30. \n
  31. \n

    当你看到别人因为孩子出国了,或者离世了,或者因为被琐事困扰而哭泣伤心时,不要让这些情感表象误导你。你必须作出自己的判断,明白他的伤心难过不是因为发生的事情本身,因为其他同样身处其中的人并没有受到同样的影响。他之所以受到那么大的困扰,是因为他自己本身对事情的判断。不要让自己和他一样受影响,不要让自己一样受困扰,不管是外在表现还是内心感受上。

    \n
  32. \n
  33. \n

    记住你只是一出戏里的一个演员,而戏份角色并不是由你决定的。不管角色故事长短,不管你是一个穷人,瘸子,政府官员,或者是一个很私密的人,把你的角色演好演自然了就行。把分配给你的角色演好,那是你的本分;而到底是哪个角色,那不是由你决定的。

    \n
  34. \n
  35. \n

    如果一只乌鸦向你预示不幸的事即将发生,不要让你内心的平静被这个表象破坏。要即刻告诉自己,“我不知道会发生什么,我不知道我的身体,财物,名声,或者家人会受什么影响,如果我愿意理性地去想,那么所有的这些恶兆就会变成幸运,因为我可以控制我要用什么态度去对待这些事情。不管发生什么,我都可以从中获得对我有利的。

    \n
  36. \n
  37. \n

    如果你不去参与在你控制范围之外的任何战斗,那你就不会被打败。当你看到那些声名显赫,社会地位高,或者在任何方面做得很好的人,不要着急认为他们是开心的。因为如果我们清楚明白幸福只在于我们所能够控制的范围内,那我们就不会去羡慕或者攀比。不要向往头衔,而是要向往内心自由和平静。而要做到这一点,唯一的途径是要看轻我们控制范围之外的一切事物。

    \n
  38. \n
  39. \n

    记住,那些对你出言不逊或者动手的人他本身并不是一种羞辱,而是代表那些言行的原则让你感觉到被羞辱。如果有人激怒你了,那是你对这种行为的观点激怒了你。试着不要被事情的表象牵引你的情感。给予适当的时间和稍作休息,你就能够很好地调整控制自己的情感。

    \n
  40. \n
  41. \n

    把死亡和流放这些看似可怕的事看作是日常,那你就赢了。不用害怕贫穷,也不要刻意贪求任何东西。

    \n
  42. \n
  43. \n

    如果你真心希望从哲学中获益,那么就要做好被众人嘲笑的准备:“她这是准备要成为一个哲学家呢”,“瞧她那傲慢的样子”……这个时候,你该做的,不是摆起傲慢的样子,而是要以神圣的态度忠诚于你所认定的,这样总有一天嘲笑你的人会开始尊敬你崇拜你。但是如果你被这些嘲笑打败,那你就成了双重的笑话。

    \n
  44. \n
  45. \n

    如果你为了取悦他人而把你的注意力转移到那些外在的你无法控制的事物上,那么恭喜你,你已经成功地毁了你自己的生活了。

    \n
  46. \n
  47. \n

    不要让以下这些思考方式困扰你:“我将会颜面丢尽,而且什么都不是。”耻辱是邪恶的,我们不应该被耻辱感所控制。因为获取权力或着被人嘲笑,这些都在你的控制范围之外。我们不用为任何在我们控制范围之外的事而感到耻辱。在我们可控范围之内,我们是自由的,能够左右我们自己的事情,是自我的主人-从这个角度看,我们永远不会什么都不是。“可是我帮不了我的朋友啊”,你可能会这么说。可是,怎么算是帮助朋友呢?你不能给他们钱,或者帮他们成为罗马市民。这些都是你所能控制范围之内的,是他们自己应该处理的事情。而且,如果这些都是你自己所没有的,那你怎么能够给他们呢?你可能会说:“如果我帮助他们获得这些的话,说不定我也能够得到一份呢“。如果我能够在保存我自己的尊严,忠诚和思想得到这些的话,请你帮我指明道路。可是如果你要我损害自己去得到你的利益,那这样的做法不仅不公平,而且愚蠢至极。

    \n
  48. \n
  49. \n

    如果别人,而不是你,被邀请去宴会,或者被赞美,或者被别人咨询,不要懊恼。如果这些是好事,你应该为他人高兴。如果是坏事,不要难过。记住:这些都是在你的控制范围之外的,这样的对待一般是有对应的代价的。如果你不愿意付出这样的代价而希望得到同样的对待,那是不公平的。比如说别人用50分买了一棵生菜,但是你不想花这50分,那你就不应该认为拥有生菜的人占了便宜。那个人付出50分得到了生菜,而你口袋里还有那没有花出去的50分。同理,宴会邀请,别人的赞美,这些都是有代价的。如果你觉得这些对你是有价值的,那你就要付出同等的价值去拥有。如果你不付出就想要得到这些,那么你就是个贪得无厌的傻瓜。换个角度想,在决定不和别人交换价值的时候,你真的什么都没有得到吗?不是的:你得到了不赞美你不想赞美的人的自由,而且也不需要容忍你不想容忍的行为。

    \n
  50. \n
  51. \n

    记住:很多事情不应该分自我或者他人。举个例子,如果邻居家的孩子打破了个杯子或者其他什么东西,我们很容易会说:“没事的,打碎东西是正常的”。可是如果打碎的是你自己的杯子呢?你应该作出相同的反应,而不是心生懊恼。同理,当别人的孩子或者妻子去世了,我们知道死亡的悲剧有时候是不可避免的,但是如果发生在我们自己身上的时候,我们却心如刀割。但是,我们应该清醒的认识到类似的悲剧不是我们能够控制的,我们所能够控制的是自己的情绪和反应,因为即使是发生在自己的身上,死亡本身并没有因为我们和死者的关系而变的更糟糕。

    \n
  52. \n
  53. \n

    立一个靶子的目的,不是为了射失它(靶子的目的都是为了让人射中它)。那么同样的道理,大道创造出一个“恶”的事物(至少看起来如此),不是为了让人绕开它。

    \n
  54. \n
  55. \n

    如果别人把你的身体交给一个路上遇到的陌生人,你一定会很生气。可是当别人用恶语打击你的时候,你为什么要心甘情愿地让别人控制你的思想,困惑你呢?

    \n
  56. \n
  57. \n

    做每件事情都要考虑缘由和后果之后才能开始行动。如果你兴高采烈地开始而没有考虑可能发生的后果,当某些不好的后果开始出现时,你就会停止前进。拿参加奥林匹克赛事为例子。如果你把所有前因后果都考虑周全后认为参加比赛对你时有益的,那就全力以赴。其中,应该考虑的事情包括:你要遵守规则,节制饮食;不管风吹日晒雨淋都要雷打不动地坚持按时锻炼;你不能喝凉水活着酒。你必须全身心地、完全忘我地投入训练。而且,要做思想准备准备,比赛中你有可能会摔入沟里,胳膊脱臼,脚踝受伤,吃入尘土,被鞭打,甚至最后以失败告终。当你评估完所有的可能性之后还是一心想比赛,那就以战争的姿态出发。否则,你就会像孩子过家家一样:一会扮摔跤手,一会扮角斗士,一会吹喇叭,一会又想参加戏剧演出。这样,即使你什么都做过,但是什么都不是。就想大猩猩一样,你模仿你所看到的一切,不停地换把戏可能是一件好玩的事,但是你很快就玩腻了。你从来都没有完全投入过任何事,没有深度地从各个角度考虑和研究所有相关的细节,而只是凭一时的兴趣蜻蜓点水般地接触了各种行业。有些人当他们看到一个人说话的方式和Euphrates十分相像(不过事实上,真的有人能和Euphrates一样犀利善辩吗?),他们认为自己也能够拥有和哲学家一样的思想。但是,如果你细想一下,如果你想要成为一个摔跤手,那么你必须具备有摔跤手的宽阔肩膀,强有力的背部和大腿。但是每一个人的身体构造都是不一样的,你必须具有必备的条件才能称为一个好的摔跤手。同理,要想成为一个哲学家,你不能像你现在这样随心所欲地吃喝,不能让愤怒和不满控制你的情绪,你必须细心观察,劳作,控制自己的欲望,你必须能够忍受孤独,仆人的不敬,和外人的嘲笑,你必须能够接受别人在其他方面做得比你好。如果你已经仔细考虑过这些情况,如果你认为如果做到以上这些可以让你享受自由和宁静,那就尽情去追求哲学家的道路。如果你无法做到这些的话,那么就请不要继续,不要像孩子一样,一会试试做哲学,一会又想当政治家,演讲者,或者凯撒的军官。这些追求是互相矛盾的,你只能成为其中一个,不管做得好坏。你必须培养你自己内在的能够掌控行为的能力,或者外在的技术,二者只能取其一。

    \n
  58. \n
  59. \n

    一个人的责任是由和别人的关系定义和衡量的。如果一个人拥有父亲的角色,那么他就有以下权利:他的孩子要照顾他,遵从他,耐心听他训话和教导。那如果他不是一个好父亲呢?他也应该受到同等的对待,因为我们无法选择我们的父亲是谁。不管他做了什么,你必须做到让自己心安理得。因为只有你能够让别人的行为伤害到你。当你觉得你被伤害了,那你就会被伤害。如果你以同样的逻辑看待邻居,市民,将军这些不同的角色,你就能够清楚地明白与这些角色相对应的社会责任。

    \n
  60. \n
"},{"title":"《少有人走的路》笔记","date":"2019-07-20T22:14:37.000Z","urlname":"road-less-traveled-summary","toc":true,"_content":"\n**成熟 = [自律](#id_zilv) + [爱](#id_ai)**[](def_成熟)\n\n\n\n### 自律\n\n**【自律】**[](def_自律) : 主动要求自己以积极的态度去承受痛苦,解决问题。\n\n自律的四个`原则`:延迟满足感、承担责任、忠于事实、保持平衡。:smile:\n\n#### 1 延迟满足感\n\n
\n\n人生当中总是绕着困难走。一个揍孩子和对孩子大喊大叫的父母就是不懂得延迟满足感的父母。 应该陪着孩子一起经历困难和痛苦。而父母试图通过家庭暴力的方式,试图将父母本身的责任区隔开。父母没有学会延迟满足感,这个孩子将来长大了也不会。很多人延迟满足感的能力非常糟糕,来自于父母的不自律。当父母不自律的时候,孩子就没法获得足够的爱和照顾。—— 所以这个孩子会忽略自我的价值。有的人喜欢浪费时间,而浪费时间的意思就是,_「我这个人的时间没什么价值」_。\n不会延迟满足感的人,在长大后看到问题会假装没看到,以为等着问题慢慢就会过去,期待问题自行消失。\n
\n\n> - 训斥孩子 ~\\> 是为了迅速达成目的,而不是耐心陪孩子面对问题。\n> - 父母不自律 => 孩子不自律\n> - 不会延迟满足感 => 有意忽略问题\n\n#### 2 承担责任\n\n1. **神经官能症**[](def_神经官能症): 把一切东西都认为是自己的问题。\n> _我如果怎么样就好了。我要是不怎么样就好了。总是充满后悔和内疚。祥林嫂_\n2. **人格失调症**[](def_人格失调症):他认为这一切都不是我的问题。他能找到任何一个理由,是因为外在的东西,他就不会责怪自己,他认为都是你们的问题。[](flag_心理学_病症)\n> 「神经官能症」自己活得很痛苦,「人格失调症」让别人活得很痛苦。\n\n
\n\n作者提供在冲绳岛上的一个案例,一个军官的妻子,宁愿自杀也不愿意去学自动挡开车的事。\n从某种意义上说,所有的孩子都患有人格失调症,都会本能的逃避责罚。 同时又患有某种神经官能症,把自己承受的痛苦看成是罪有应得。缺少关心的孩子会自惭形秽,认为自己不够可爱,缺点大于优点等等。\n
\n\n如果你不能解决问题,那么你自己就会成为问题。`我们需要合理的承担责任,既不把责任全部推卸到外部,也不把责任全部揽到自己身上。保持一个合理的平衡。`\n> 如果你不能让自己成为人格更加健全,更加成熟的人。你就会把问题带给你的孩子,带给你的家庭。\n\n#### 3 忠于事实\n\n大量的人是生活在自己的幻想当中的。这叫**人生地图**。他给自己绘制一张人生地图,他认为人生就这样,他已经认定了。这就叫做“不忠于事实”,他只 _忠于自己的幻想_。\n
\n\n案例:有个人小时候被父母欺骗过,就是父母说话经常不算数。导致他潜意识积累了一个信念:“父母是不可信”的。当他的人生地图绘制出来这么一个坐标,认为父母不可信了自后,他几乎就推论到“人人都不可信”。所以在他一生的成长过程当中,他跟警察发生矛盾,跟领导发生矛盾,跟顾客发生矛盾,跟妻子发生矛盾。案例中最后他唯一信任的是他的两个孩子。妻子把两个孩子带走,所以他人生也崩溃了。他跟作者约定时间不来,然后他说能不能星期六,作者说我的时间是跟别人约过的,不能随便调整。他说:“你不是心理医生吗?为什么不能多关心我一点呢”?他认为作者(心理医生)也是不可信任的人,直接拉黑。\n
\n这种人你很难跟他解释,很难让他面对真正的世界。因为在他心目当中完全是用自己的一套逻辑在解决问题。\n\n所以所谓的「心理治疗」,就是鼓励「说真话」的游戏。鼓励大家能够面对事实,能够把自己看到的真相,感受到的真实的感觉,说出来的一个过程。所以没有经过这样的调试,有大量的人是天天活在「幻觉」当中的,就是沉浸在自己的人生地图当中。根本不去看一看,别人的地图是什么样。也根本不去看一看实际的生活当中,事实是什么样的。\n\n **移情**:人们会把对一个人的感情和经验移植在别人身上。会认为别人也这样。\n\n> 应该说移情、或者忽略史实,也是一种懒惰的表现。因为去更新地图是件很费力的事情。\n\n#### 4 保持平衡\n 既要承担责任,也要拒绝承担不该承担的责任。差不多又回到了「中庸」之道。「延迟满足」也不能延迟到无限, 从来不过好日子。既要延迟满足,也要过好当下的生活。要有一个富于弹性的约束机制。好像骑自行车下坡一样,既要享受速度,也要注意刹车。为了待会安全的拐弯,也要捏一捏车闸。\n ```生活就是一个不断放弃的过程。必须能够学会放弃一件又一件的事情。包括接受心理治疗就是「放弃」—— 放弃了一个「自己是正常人」 的想法。```\n\n
\n埃里克 埃里克森列举的人一生当中不断放弃的事情\n\n1. 首先要放弃「无需对外界要求作出回应」的婴儿状态。\n2. 三四岁的时候有「无所不能的幻觉」,这个要放弃掉。(为何小孩子特别喜欢绿巨人、钢铁侠、金刚狼这样的超级英雄?因为每个人在三四岁的时候都曾经幻想过自己是无所不能的超人。所以这种童话永远有市场。)\n3. 放弃完全占有父亲或者母亲的欲望。放弃童年的依赖感。\n4. 放弃心中被扭曲了的父母形象。(我们曾经以为父母是完美的)放弃。\n5. 青春期的自以为拥有「无穷潜力」的感觉。放弃! I am the King of the World!\n6. 无拘无束的自由\n7. 青年时期的灵巧与活力\n8. 青春时期的性吸引力;长生不老的空想。\n9. 对子女的权威(在子女面前总是说了算的)\n10. 各种各样「暂时性」的权力——退休了,社会给你的权力也没有了。\n11. 身体永远健康——放弃\n12. 最后,自我以及生命本身也要放弃。\n
\n\n### 爱\n\n**【爱】**[](def_爱) :为了促进自己和他人心智成熟,而不断拓展自我界限,实现自我完善的一种意愿。\n> 核心观点就是「要看重心智成熟这件事」。心智成熟是发生在你和被爱的那个人之间的,两个人都需要达成心智成熟。\n> _不要以为一昧的付出就是爱。爱的要求很高。要达成两个的`共同成熟`_\n\n一个人懂得什么是真正的爱,才能够是一个真正成熟的人。否则你会看到很多人以「爱」的名义在伤害、控制、占有对方。「爱」有以下四个误区:过度关注、坠入情网、精神灌注、自我牺牲。\n\n#### 过度关注\n* 实际上是一种「依赖」\n例子,一个妈妈,孩子都上高中了,还每天开车接送孩子上学。说孩子一个上学走太让人担心了。「过度关注」实际上是一种「依赖」。(`妈妈在“依赖”这个孩子`)这种类型的人经常说的话是“没有你我活不下去”。这个小孩之所以出现在书中,是因为孩子长大后来做了心理咨询。他在人生当中做任何事情都不成功。他的能力非常的欠缺。为什么?因为他从小到大完全被母爱这样束缚着。他妈妈根本不去管孩子能否「成熟」。他妈妈根本不去管这样做对孩子的心智健康、发展有没有好处。唯一的就是「你别出事,我必须盯着你」!`她不是为对方在做这样的事,她是在为自己做这样的事情。如果发展到极致,变得很严重的话,会变成一种疾病,叫「**消极性依赖人格失调症**」。—— 他必须依赖某一个外在的东西,他才能够觉得自己是存在的。如果有这么一个人,就是死死的缠住他,就是不离开他。有一个人作为对象,他才能找到自己的位置。如果找不到这样的人,就很可能会沉迷于毒品和酒精。\n\n* 对「爱」无度的索求\n对别人的爱根本与对方无关,他只是希望找到一个人,能够投射自己在上面,能够找到自己——「因为有人爱我,我就存在」。(例子,有个人离婚了,生活很痛苦,用酒精麻醉自己。咨询的第二天来跟医生说,我好了,我现在很幸福。因为昨晚在酒吧认识一个女人,她说她爱我。我现在很好。)总是苦思如何获得别人的爱,却没有精力去爱别人。就像饥肠辘辘的人,总想着向别人讨要食物,却拿不出食物来帮助别人。`他们永远孤独寂寞,永远无法体会到满足感。`尤其可怕的是,他们不知道自己患上了「消极性依赖人格失调症」。其造成原因多是童年缺乏爱,然后总觉的自己「没资格被爱」。人要感觉自己是被爱的,才有资格跟别人平起平坐,独立地生活和对话。患有这种心理疾病的人,他根本没有感觉到自己的资格,永远都在怀疑别人不爱他。所以只要别人拒绝他,就会感到无比的痛苦和伤心。而他永远需要找到一个紧紧拉住的,依赖的对象。这不是爱,这是占有。\n\n#### 坠入情网\n**坠入情网是欲望**。是你体内的激素分泌。因为我们的基因要求我们要生殖,见到异性感觉自己爱上他了。实际上是自己的一种欲望。一段时间后当你的欲望被释放掉了,体内的激素的大潮开始退去的时候,会发现这个人看起啦那么讨厌。坠入情网实际上是``「自我界限的短暂崩溃」``。除了自我界限的理论,还有以下几个点:\n* 不是出于主管意愿,它不是一个有计划有意识的选择。(很多人只把它看成一个感觉,而不是一个「动作」,爱是一个动词,不是感觉)\n* 不是自我界限的扩展,而是自我界限的部分的暂时性的崩溃。扩展自我界限需要付出足够的努力,坠入情网却无需努力。\n* 坠入情网唯一的作用是消除寂寞。而不是有目的的促进心灵的成长。\n* 简单来说贪恋爱可能是「爱」的发端,可能能培养出来爱,但它不是「爱」本身。\n\n#### 精神贯注\n`爱宠物、爱好这些也不是爱`,而是「精神贯注」。就是当你把自己的精神贯注在一个事物上的时候,你以为这只狗“懂你”,其实上是“你投射在了它身上”,你在猜想它的想法。跟真正的爱不一样。为什么呢:\n* 首先,我们跟宠物的沟通非常有限。我们不知道他们每天在想什么,却一厢情愿的把自己的想法和感受投射在它们身上。实际上这只是我们的主观愿望罢了。\n* 其次,我们喜欢宠物的原因是因为它们表现乖巧,任凭摆弄。如果宠物不听话,破坏家具,随意大小便,甚至咬上我们几口。我们就可能把它赶出家门。如果要改变宠物的心智,我们只能把它送到宠物学校。如果与某个人相处,局面就完全不同了。\n\n有一种精神贯注叫「婴儿之爱」。 很多妈妈只喜欢婴儿期的孩子。等孩子三四岁以后妈妈开始烦了。赶紧推给爷爷奶奶带。反过来呢,母爱很充沛,喜欢别人家的孩子,刚生的小婴儿。 这种不是爱,而是``「唯命是从的追求」``。 比如二战后美国的「战争新娘」。一开始新娘对丈夫唯命是从,当她们懂得英语,开始融入美国社会以后,矛盾就渐渐开始产生,离婚率开始上升。\n\n以上几种感情我们误以为是爱,其实不是。它们都有共同的特征,就是以「爱」作为幌子,``只想满足自己的需要``。却从来不把对方的心智成熟当一回事。\n\n\n#### 自我牺牲\n甚至还有人人会发展出来「**自我牺牲式的爱**」。有个妻子,她老公总是欺骗她,总是有外遇。每次闹完,老公回来道歉,她又开始接受他。五六次以后,妻子去找心理医生谈。心理医生告诉她要想清楚,不能老是这样接受他。有一次这个妻子说,我又原谅他了,这次他是真的改好了。他特别怎么怎么样。结果医生发现这个妻子有“受虐倾向”。有受虐倾向的人,会把「自我牺牲」当作是「爱」。他们觉得只要我能够牺牲、奉献就好。\n\n这些东西也是来自童年的经历,就是他童年当中如果有一个这样的“楷模”,总是以自我牺牲为标榜,总是以为我为别人牺牲了那么多,所以 “你看我多好,多高尚”,他在潜意识当中就会慢慢接受“自我牺牲就是爱”这种想法。\n\n
\n **自我界限**:\n小孩子刚出生的时候是没有自我界限的。他在挥动胳膊的时候,觉得整个房间都在动,他与这个世界没有是分割的。到了两三岁发现自己挥动胳膊的时候,房间没有动,甚至他发现自己哭的时候,别人并不饿。 才能慢慢感受到原来自己跟他人是不一样的。到青春期这个人的自我界限已经开始完全封闭起来了。原来这个世界只有我自己,连我的父母都不了解我,我的喜怒哀乐他们根本不知道。所以人们开始陷入深深的孤独。青春期的孩子觉得自己最“孤独”,他觉得没人理解他,我是一个完全独一无二的个体,谁跟我都不一样,他的自我界限完全封闭起来。\n到了谈恋爱。谈恋爱是需要冒风险的,你是需要有勇气打开自我的界限,和另外一个人融为一体的。所以初恋的时候,很多人会有「**圣洁**」的感觉。就是“我打开了”,有一个人竟然“完全懂我”。有一个人可以跟我融为一体,那种水乳交融的感觉,他以为自己找到了「真爱」。因为他的边界在短期的崩溃。当他的自我边界崩溃以后,他感受到了生命的狂喜,那个就是短暂的获得了「爱」的感觉。但是那是假象。`因为那个并不建立在令我和对方人格不断成熟的一个过程当中。他并不是希望达成心智的成熟,他只是自我边界的短暂崩溃`。所以过了一两个月以后,这个自我界限慢慢弥合起来,他发现说“这个人怎么跟我也不一样”?“这个人的想法跟我也不同”。 现在的孩子谈恋爱特别快,有感觉就谈,没感觉了就分。把「感觉」当成了「爱」,事实上感觉只是欲望,是性欲。\n 但不要觉得欲望不是一件好事,无论是欲望,还是依赖,或者过度关注这样的东西,都是`培养爱的基础`。\n正是因为两个人打破了边界,走到一起,双方有可能为对方作出了承诺。接下来为了完成自己的承诺,需要不断的努力,需要有自律性。当你的自律性跟承诺相结合在起来的时候,你的这个短暂的恋爱的感觉爱,会慢慢滋生出真正的爱。 能够带来对方和自己心智共同的成熟。\n
\n
\n\n``真正的「爱」`` :爱是实际行动,是真正的付出。\n\n爱的感觉与精神贯注密不可分。后者是把情感与兴趣贯注在对外的对象上,将其当作属于自己的一部分。精神贯注虽然跟真正的爱容易混淆,但是依然有显著的区别。首先,精神贯注的对象不一定是有生命的事物。因此就不见得会有心灵的感受。其次,对某种事物产生精神贯注的人,未必会重视其心智的成熟。(比如无原则溺爱孩子的父母)第三,精神贯注可能与智慧和责任无关。(酒吧认识一个人,立刻就情有所钟。但没有任何计划性,没有后续责任)。最后,精神贯注随时都有可能消失。今晚还很开心,明天不开心就分手啰。\n\n真正的爱需要投入和奉献,需要付出全部的智慧与力量。要使爱的对象得到成长,就必须付出足够多的努力,不然爱的愿望就会落空。 唯有真正的投入与奉献,才是实现爱的有效方式。真正的爱是自主的选择,无论「爱」的「感觉」是否存在, 都要奉献出情感和智慧。\n\n
\n\n**「爱」的表现**\n\n1. 倾听。我们真的能够拿出时间来,认真倾听对方的说话。最起码的尊重是通过倾听来展开的,我们要做一个良好的「倾听者」。\n2. 要有心里准备,接受爱的时候,就要准备承担风险。(有人经历过丧失亲人,之后就特别怕建立亲密关系。因为怕失去,「失去」的痛苦吓坏了他。)(爱还要面临冲突的风险。)\n3. 需要尊重对方的独立性。否则就是占有,就是依赖。\n\n### 信仰\n\n#### 科学也是信仰\n科学也是一种信仰。这个世界上上信科学的人比信宗教的人多。人不是生活在一个真实的世界当中的,人是生活在思想家为我们所设定的思想通道当中的。科学家在不断的拓宽我们人类的视线,建立了科学的信仰。 作者认为宗教的信仰在某种程度上可能会导致人的某些情况下的精神分裂。但是在某些情况下也会带来信念,帮助人们解决心理的问题。比喻:倒洗澡水的时候,千万不要把婴儿也倒出去。对待信仰的时候,不能过于简单化。\n\n#### 原罪\n作者认为人类的`「原罪」`就是`「懒惰」`。\n\n自律需要用力,爱需要用力,这个世界天然的方向是「熵增」,屋子一定会变乱。我花力气把屋子整理干净十个「逆熵」的过程,逆熵是需要话费气力的。 人天生喜欢熵增,喜欢懒惰。在伊甸园,其实上帝经常在园子里散步。这两孩子如果能去问一下,这玩意儿能吃吗?人类的命运就改变了。这两个人为什么不去问 一下上帝呢?因为这两孩子「懒惰」,而「懒惰」的背后是「恐惧」。他们担心问了上帝以后受到上帝的责罚。\n>(天涯:我认为这个解释不对。那个时候的亚当和夏娃没有罪恶感,也从来没有受过责罚,怎么会有这个恐惧呢?而恐惧则是被赶出伊甸园以后人类才有的心智。)\n\n有人不好好学习,是因为就算好好学习了也未必学得好啊。如果好好学了而没有学好,就会面对失去「我不是没能力,只是不愿学而已」这块遮羞布的恐惧。\n\n尽量要做到潜意识和意识「合一」。因为潜意识里面有很多的能量,而我们由于“懒惰”以及“恐惧”不愿意去开发的,不愿意去面对的。\n\n这本书为什么叫【少有人走的路】呢?因为人人都喜欢熵增的方向,都喜欢轻松的方向,人人都喜欢懒惰的方向。喜欢部分什么劲,就得到一切的这种感觉。如果你想要变得成熟,就要费力去做一些逆熵的行为,自律的事,延迟满足的事,用行动表达「爱」的 过程。\n\n#### 两种力量\n这个世界始终是由两种力量来统治的,分别是「政治的力量」和「心灵的力量」。\n\n【政治的力量】[](def_政治的力量):以公开或者隐秘的方式,去强迫别人遵循自己的意愿。这种力量既存在于权力之中,也存在于金钱之中。然而他并不属于拥有权力或者金钱的人。归根到底,政治的力量和德行以及智慧无关,最愚蠢最邪恶的人也可能成为地球的统治者。\n【心灵的力量】[](def_心灵的力量):则完全存在于人类的心中,它和强迫、控制别人的力量没有关系。它是在意识基础上作出决定的力量。也就是「意识的力量」。\n\n如果我们的心理能够得到力量,我们就会感到舒适和愉快,在人生的旅途上稳扎稳打,循序渐进。 进步带给我们的愉悦感难以言喻。没有什么比成为人生的专家,熟知自己所做的事情,更让人感觉到幸福。我们的心灵越是成熟,就越有可能成为人生的专家。当我们的心智成熟到一定的阶段,我们就会更加谦逊而快乐。\n\n---\n\n","source":"_posts/读书笔记/《少有人走的路》笔记.md","raw":"---\ntitle: 《少有人走的路》笔记\ndate: 2019-07-21 00:14:37\nurlname: road-less-traveled-summary\ntoc: true\ntags: [心理, 成长]\ncategories: [读书笔记]\n\n---\n\n**成熟 = [自律](#id_zilv) + [爱](#id_ai)**[](def_成熟)\n\n\n\n### 自律\n\n**【自律】**[](def_自律) : 主动要求自己以积极的态度去承受痛苦,解决问题。\n\n自律的四个`原则`:延迟满足感、承担责任、忠于事实、保持平衡。:smile:\n\n#### 1 延迟满足感\n\n
\n\n人生当中总是绕着困难走。一个揍孩子和对孩子大喊大叫的父母就是不懂得延迟满足感的父母。 应该陪着孩子一起经历困难和痛苦。而父母试图通过家庭暴力的方式,试图将父母本身的责任区隔开。父母没有学会延迟满足感,这个孩子将来长大了也不会。很多人延迟满足感的能力非常糟糕,来自于父母的不自律。当父母不自律的时候,孩子就没法获得足够的爱和照顾。—— 所以这个孩子会忽略自我的价值。有的人喜欢浪费时间,而浪费时间的意思就是,_「我这个人的时间没什么价值」_。\n不会延迟满足感的人,在长大后看到问题会假装没看到,以为等着问题慢慢就会过去,期待问题自行消失。\n
\n\n> - 训斥孩子 ~\\> 是为了迅速达成目的,而不是耐心陪孩子面对问题。\n> - 父母不自律 => 孩子不自律\n> - 不会延迟满足感 => 有意忽略问题\n\n#### 2 承担责任\n\n1. **神经官能症**[](def_神经官能症): 把一切东西都认为是自己的问题。\n> _我如果怎么样就好了。我要是不怎么样就好了。总是充满后悔和内疚。祥林嫂_\n2. **人格失调症**[](def_人格失调症):他认为这一切都不是我的问题。他能找到任何一个理由,是因为外在的东西,他就不会责怪自己,他认为都是你们的问题。[](flag_心理学_病症)\n> 「神经官能症」自己活得很痛苦,「人格失调症」让别人活得很痛苦。\n\n
\n\n作者提供在冲绳岛上的一个案例,一个军官的妻子,宁愿自杀也不愿意去学自动挡开车的事。\n从某种意义上说,所有的孩子都患有人格失调症,都会本能的逃避责罚。 同时又患有某种神经官能症,把自己承受的痛苦看成是罪有应得。缺少关心的孩子会自惭形秽,认为自己不够可爱,缺点大于优点等等。\n
\n\n如果你不能解决问题,那么你自己就会成为问题。`我们需要合理的承担责任,既不把责任全部推卸到外部,也不把责任全部揽到自己身上。保持一个合理的平衡。`\n> 如果你不能让自己成为人格更加健全,更加成熟的人。你就会把问题带给你的孩子,带给你的家庭。\n\n#### 3 忠于事实\n\n大量的人是生活在自己的幻想当中的。这叫**人生地图**。他给自己绘制一张人生地图,他认为人生就这样,他已经认定了。这就叫做“不忠于事实”,他只 _忠于自己的幻想_。\n
\n\n案例:有个人小时候被父母欺骗过,就是父母说话经常不算数。导致他潜意识积累了一个信念:“父母是不可信”的。当他的人生地图绘制出来这么一个坐标,认为父母不可信了自后,他几乎就推论到“人人都不可信”。所以在他一生的成长过程当中,他跟警察发生矛盾,跟领导发生矛盾,跟顾客发生矛盾,跟妻子发生矛盾。案例中最后他唯一信任的是他的两个孩子。妻子把两个孩子带走,所以他人生也崩溃了。他跟作者约定时间不来,然后他说能不能星期六,作者说我的时间是跟别人约过的,不能随便调整。他说:“你不是心理医生吗?为什么不能多关心我一点呢”?他认为作者(心理医生)也是不可信任的人,直接拉黑。\n
\n这种人你很难跟他解释,很难让他面对真正的世界。因为在他心目当中完全是用自己的一套逻辑在解决问题。\n\n所以所谓的「心理治疗」,就是鼓励「说真话」的游戏。鼓励大家能够面对事实,能够把自己看到的真相,感受到的真实的感觉,说出来的一个过程。所以没有经过这样的调试,有大量的人是天天活在「幻觉」当中的,就是沉浸在自己的人生地图当中。根本不去看一看,别人的地图是什么样。也根本不去看一看实际的生活当中,事实是什么样的。\n\n **移情**:人们会把对一个人的感情和经验移植在别人身上。会认为别人也这样。\n\n> 应该说移情、或者忽略史实,也是一种懒惰的表现。因为去更新地图是件很费力的事情。\n\n#### 4 保持平衡\n 既要承担责任,也要拒绝承担不该承担的责任。差不多又回到了「中庸」之道。「延迟满足」也不能延迟到无限, 从来不过好日子。既要延迟满足,也要过好当下的生活。要有一个富于弹性的约束机制。好像骑自行车下坡一样,既要享受速度,也要注意刹车。为了待会安全的拐弯,也要捏一捏车闸。\n ```生活就是一个不断放弃的过程。必须能够学会放弃一件又一件的事情。包括接受心理治疗就是「放弃」—— 放弃了一个「自己是正常人」 的想法。```\n\n
\n埃里克 埃里克森列举的人一生当中不断放弃的事情\n\n1. 首先要放弃「无需对外界要求作出回应」的婴儿状态。\n2. 三四岁的时候有「无所不能的幻觉」,这个要放弃掉。(为何小孩子特别喜欢绿巨人、钢铁侠、金刚狼这样的超级英雄?因为每个人在三四岁的时候都曾经幻想过自己是无所不能的超人。所以这种童话永远有市场。)\n3. 放弃完全占有父亲或者母亲的欲望。放弃童年的依赖感。\n4. 放弃心中被扭曲了的父母形象。(我们曾经以为父母是完美的)放弃。\n5. 青春期的自以为拥有「无穷潜力」的感觉。放弃! I am the King of the World!\n6. 无拘无束的自由\n7. 青年时期的灵巧与活力\n8. 青春时期的性吸引力;长生不老的空想。\n9. 对子女的权威(在子女面前总是说了算的)\n10. 各种各样「暂时性」的权力——退休了,社会给你的权力也没有了。\n11. 身体永远健康——放弃\n12. 最后,自我以及生命本身也要放弃。\n
\n\n### 爱\n\n**【爱】**[](def_爱) :为了促进自己和他人心智成熟,而不断拓展自我界限,实现自我完善的一种意愿。\n> 核心观点就是「要看重心智成熟这件事」。心智成熟是发生在你和被爱的那个人之间的,两个人都需要达成心智成熟。\n> _不要以为一昧的付出就是爱。爱的要求很高。要达成两个的`共同成熟`_\n\n一个人懂得什么是真正的爱,才能够是一个真正成熟的人。否则你会看到很多人以「爱」的名义在伤害、控制、占有对方。「爱」有以下四个误区:过度关注、坠入情网、精神灌注、自我牺牲。\n\n#### 过度关注\n* 实际上是一种「依赖」\n例子,一个妈妈,孩子都上高中了,还每天开车接送孩子上学。说孩子一个上学走太让人担心了。「过度关注」实际上是一种「依赖」。(`妈妈在“依赖”这个孩子`)这种类型的人经常说的话是“没有你我活不下去”。这个小孩之所以出现在书中,是因为孩子长大后来做了心理咨询。他在人生当中做任何事情都不成功。他的能力非常的欠缺。为什么?因为他从小到大完全被母爱这样束缚着。他妈妈根本不去管孩子能否「成熟」。他妈妈根本不去管这样做对孩子的心智健康、发展有没有好处。唯一的就是「你别出事,我必须盯着你」!`她不是为对方在做这样的事,她是在为自己做这样的事情。如果发展到极致,变得很严重的话,会变成一种疾病,叫「**消极性依赖人格失调症**」。—— 他必须依赖某一个外在的东西,他才能够觉得自己是存在的。如果有这么一个人,就是死死的缠住他,就是不离开他。有一个人作为对象,他才能找到自己的位置。如果找不到这样的人,就很可能会沉迷于毒品和酒精。\n\n* 对「爱」无度的索求\n对别人的爱根本与对方无关,他只是希望找到一个人,能够投射自己在上面,能够找到自己——「因为有人爱我,我就存在」。(例子,有个人离婚了,生活很痛苦,用酒精麻醉自己。咨询的第二天来跟医生说,我好了,我现在很幸福。因为昨晚在酒吧认识一个女人,她说她爱我。我现在很好。)总是苦思如何获得别人的爱,却没有精力去爱别人。就像饥肠辘辘的人,总想着向别人讨要食物,却拿不出食物来帮助别人。`他们永远孤独寂寞,永远无法体会到满足感。`尤其可怕的是,他们不知道自己患上了「消极性依赖人格失调症」。其造成原因多是童年缺乏爱,然后总觉的自己「没资格被爱」。人要感觉自己是被爱的,才有资格跟别人平起平坐,独立地生活和对话。患有这种心理疾病的人,他根本没有感觉到自己的资格,永远都在怀疑别人不爱他。所以只要别人拒绝他,就会感到无比的痛苦和伤心。而他永远需要找到一个紧紧拉住的,依赖的对象。这不是爱,这是占有。\n\n#### 坠入情网\n**坠入情网是欲望**。是你体内的激素分泌。因为我们的基因要求我们要生殖,见到异性感觉自己爱上他了。实际上是自己的一种欲望。一段时间后当你的欲望被释放掉了,体内的激素的大潮开始退去的时候,会发现这个人看起啦那么讨厌。坠入情网实际上是``「自我界限的短暂崩溃」``。除了自我界限的理论,还有以下几个点:\n* 不是出于主管意愿,它不是一个有计划有意识的选择。(很多人只把它看成一个感觉,而不是一个「动作」,爱是一个动词,不是感觉)\n* 不是自我界限的扩展,而是自我界限的部分的暂时性的崩溃。扩展自我界限需要付出足够的努力,坠入情网却无需努力。\n* 坠入情网唯一的作用是消除寂寞。而不是有目的的促进心灵的成长。\n* 简单来说贪恋爱可能是「爱」的发端,可能能培养出来爱,但它不是「爱」本身。\n\n#### 精神贯注\n`爱宠物、爱好这些也不是爱`,而是「精神贯注」。就是当你把自己的精神贯注在一个事物上的时候,你以为这只狗“懂你”,其实上是“你投射在了它身上”,你在猜想它的想法。跟真正的爱不一样。为什么呢:\n* 首先,我们跟宠物的沟通非常有限。我们不知道他们每天在想什么,却一厢情愿的把自己的想法和感受投射在它们身上。实际上这只是我们的主观愿望罢了。\n* 其次,我们喜欢宠物的原因是因为它们表现乖巧,任凭摆弄。如果宠物不听话,破坏家具,随意大小便,甚至咬上我们几口。我们就可能把它赶出家门。如果要改变宠物的心智,我们只能把它送到宠物学校。如果与某个人相处,局面就完全不同了。\n\n有一种精神贯注叫「婴儿之爱」。 很多妈妈只喜欢婴儿期的孩子。等孩子三四岁以后妈妈开始烦了。赶紧推给爷爷奶奶带。反过来呢,母爱很充沛,喜欢别人家的孩子,刚生的小婴儿。 这种不是爱,而是``「唯命是从的追求」``。 比如二战后美国的「战争新娘」。一开始新娘对丈夫唯命是从,当她们懂得英语,开始融入美国社会以后,矛盾就渐渐开始产生,离婚率开始上升。\n\n以上几种感情我们误以为是爱,其实不是。它们都有共同的特征,就是以「爱」作为幌子,``只想满足自己的需要``。却从来不把对方的心智成熟当一回事。\n\n\n#### 自我牺牲\n甚至还有人人会发展出来「**自我牺牲式的爱**」。有个妻子,她老公总是欺骗她,总是有外遇。每次闹完,老公回来道歉,她又开始接受他。五六次以后,妻子去找心理医生谈。心理医生告诉她要想清楚,不能老是这样接受他。有一次这个妻子说,我又原谅他了,这次他是真的改好了。他特别怎么怎么样。结果医生发现这个妻子有“受虐倾向”。有受虐倾向的人,会把「自我牺牲」当作是「爱」。他们觉得只要我能够牺牲、奉献就好。\n\n这些东西也是来自童年的经历,就是他童年当中如果有一个这样的“楷模”,总是以自我牺牲为标榜,总是以为我为别人牺牲了那么多,所以 “你看我多好,多高尚”,他在潜意识当中就会慢慢接受“自我牺牲就是爱”这种想法。\n\n
\n **自我界限**:\n小孩子刚出生的时候是没有自我界限的。他在挥动胳膊的时候,觉得整个房间都在动,他与这个世界没有是分割的。到了两三岁发现自己挥动胳膊的时候,房间没有动,甚至他发现自己哭的时候,别人并不饿。 才能慢慢感受到原来自己跟他人是不一样的。到青春期这个人的自我界限已经开始完全封闭起来了。原来这个世界只有我自己,连我的父母都不了解我,我的喜怒哀乐他们根本不知道。所以人们开始陷入深深的孤独。青春期的孩子觉得自己最“孤独”,他觉得没人理解他,我是一个完全独一无二的个体,谁跟我都不一样,他的自我界限完全封闭起来。\n到了谈恋爱。谈恋爱是需要冒风险的,你是需要有勇气打开自我的界限,和另外一个人融为一体的。所以初恋的时候,很多人会有「**圣洁**」的感觉。就是“我打开了”,有一个人竟然“完全懂我”。有一个人可以跟我融为一体,那种水乳交融的感觉,他以为自己找到了「真爱」。因为他的边界在短期的崩溃。当他的自我边界崩溃以后,他感受到了生命的狂喜,那个就是短暂的获得了「爱」的感觉。但是那是假象。`因为那个并不建立在令我和对方人格不断成熟的一个过程当中。他并不是希望达成心智的成熟,他只是自我边界的短暂崩溃`。所以过了一两个月以后,这个自我界限慢慢弥合起来,他发现说“这个人怎么跟我也不一样”?“这个人的想法跟我也不同”。 现在的孩子谈恋爱特别快,有感觉就谈,没感觉了就分。把「感觉」当成了「爱」,事实上感觉只是欲望,是性欲。\n 但不要觉得欲望不是一件好事,无论是欲望,还是依赖,或者过度关注这样的东西,都是`培养爱的基础`。\n正是因为两个人打破了边界,走到一起,双方有可能为对方作出了承诺。接下来为了完成自己的承诺,需要不断的努力,需要有自律性。当你的自律性跟承诺相结合在起来的时候,你的这个短暂的恋爱的感觉爱,会慢慢滋生出真正的爱。 能够带来对方和自己心智共同的成熟。\n
\n
\n\n``真正的「爱」`` :爱是实际行动,是真正的付出。\n\n爱的感觉与精神贯注密不可分。后者是把情感与兴趣贯注在对外的对象上,将其当作属于自己的一部分。精神贯注虽然跟真正的爱容易混淆,但是依然有显著的区别。首先,精神贯注的对象不一定是有生命的事物。因此就不见得会有心灵的感受。其次,对某种事物产生精神贯注的人,未必会重视其心智的成熟。(比如无原则溺爱孩子的父母)第三,精神贯注可能与智慧和责任无关。(酒吧认识一个人,立刻就情有所钟。但没有任何计划性,没有后续责任)。最后,精神贯注随时都有可能消失。今晚还很开心,明天不开心就分手啰。\n\n真正的爱需要投入和奉献,需要付出全部的智慧与力量。要使爱的对象得到成长,就必须付出足够多的努力,不然爱的愿望就会落空。 唯有真正的投入与奉献,才是实现爱的有效方式。真正的爱是自主的选择,无论「爱」的「感觉」是否存在, 都要奉献出情感和智慧。\n\n
\n\n**「爱」的表现**\n\n1. 倾听。我们真的能够拿出时间来,认真倾听对方的说话。最起码的尊重是通过倾听来展开的,我们要做一个良好的「倾听者」。\n2. 要有心里准备,接受爱的时候,就要准备承担风险。(有人经历过丧失亲人,之后就特别怕建立亲密关系。因为怕失去,「失去」的痛苦吓坏了他。)(爱还要面临冲突的风险。)\n3. 需要尊重对方的独立性。否则就是占有,就是依赖。\n\n### 信仰\n\n#### 科学也是信仰\n科学也是一种信仰。这个世界上上信科学的人比信宗教的人多。人不是生活在一个真实的世界当中的,人是生活在思想家为我们所设定的思想通道当中的。科学家在不断的拓宽我们人类的视线,建立了科学的信仰。 作者认为宗教的信仰在某种程度上可能会导致人的某些情况下的精神分裂。但是在某些情况下也会带来信念,帮助人们解决心理的问题。比喻:倒洗澡水的时候,千万不要把婴儿也倒出去。对待信仰的时候,不能过于简单化。\n\n#### 原罪\n作者认为人类的`「原罪」`就是`「懒惰」`。\n\n自律需要用力,爱需要用力,这个世界天然的方向是「熵增」,屋子一定会变乱。我花力气把屋子整理干净十个「逆熵」的过程,逆熵是需要话费气力的。 人天生喜欢熵增,喜欢懒惰。在伊甸园,其实上帝经常在园子里散步。这两孩子如果能去问一下,这玩意儿能吃吗?人类的命运就改变了。这两个人为什么不去问 一下上帝呢?因为这两孩子「懒惰」,而「懒惰」的背后是「恐惧」。他们担心问了上帝以后受到上帝的责罚。\n>(天涯:我认为这个解释不对。那个时候的亚当和夏娃没有罪恶感,也从来没有受过责罚,怎么会有这个恐惧呢?而恐惧则是被赶出伊甸园以后人类才有的心智。)\n\n有人不好好学习,是因为就算好好学习了也未必学得好啊。如果好好学了而没有学好,就会面对失去「我不是没能力,只是不愿学而已」这块遮羞布的恐惧。\n\n尽量要做到潜意识和意识「合一」。因为潜意识里面有很多的能量,而我们由于“懒惰”以及“恐惧”不愿意去开发的,不愿意去面对的。\n\n这本书为什么叫【少有人走的路】呢?因为人人都喜欢熵增的方向,都喜欢轻松的方向,人人都喜欢懒惰的方向。喜欢部分什么劲,就得到一切的这种感觉。如果你想要变得成熟,就要费力去做一些逆熵的行为,自律的事,延迟满足的事,用行动表达「爱」的 过程。\n\n#### 两种力量\n这个世界始终是由两种力量来统治的,分别是「政治的力量」和「心灵的力量」。\n\n【政治的力量】[](def_政治的力量):以公开或者隐秘的方式,去强迫别人遵循自己的意愿。这种力量既存在于权力之中,也存在于金钱之中。然而他并不属于拥有权力或者金钱的人。归根到底,政治的力量和德行以及智慧无关,最愚蠢最邪恶的人也可能成为地球的统治者。\n【心灵的力量】[](def_心灵的力量):则完全存在于人类的心中,它和强迫、控制别人的力量没有关系。它是在意识基础上作出决定的力量。也就是「意识的力量」。\n\n如果我们的心理能够得到力量,我们就会感到舒适和愉快,在人生的旅途上稳扎稳打,循序渐进。 进步带给我们的愉悦感难以言喻。没有什么比成为人生的专家,熟知自己所做的事情,更让人感觉到幸福。我们的心灵越是成熟,就越有可能成为人生的专家。当我们的心智成熟到一定的阶段,我们就会更加谦逊而快乐。\n\n---\n\n","slug":"读书笔记/《少有人走的路》笔记","published":1,"updated":"2019-08-01T04:04:18.000Z","_id":"cka1y597q00134huu98tdadd8","comments":1,"layout":"post","photos":[],"link":"","content":"

成熟 = 自律 +

\n\n

自律

\n

【自律】 : 主动要求自己以积极的态度去承受痛苦,解决问题。

\n

自律的四个原则:延迟满足感、承担责任、忠于事实、保持平衡。:smile:

\n

1 延迟满足感

\n
\n\n人生当中总是绕着困难走。一个揍孩子和对孩子大喊大叫的父母就是不懂得延迟满足感的父母。 应该陪着孩子一起经历困难和痛苦。而父母试图通过家庭暴力的方式,试图将父母本身的责任区隔开。父母没有学会延迟满足感,这个孩子将来长大了也不会。很多人延迟满足感的能力非常糟糕,来自于父母的不自律。当父母不自律的时候,孩子就没法获得足够的爱和照顾。—— 所以这个孩子会忽略自我的价值。有的人喜欢浪费时间,而浪费时间的意思就是,_「我这个人的时间没什么价值」_。\n不会延迟满足感的人,在长大后看到问题会假装没看到,以为等着问题慢慢就会过去,期待问题自行消失。\n
\n
\n
    \n
  • 训斥孩子 ~> 是为了迅速达成目的,而不是耐心陪孩子面对问题。
  • \n
  • 父母不自律 => 孩子不自律
  • \n
  • 不会延迟满足感 => 有意忽略问题
  • \n
\n
\n

2 承担责任

\n
    \n
  1. 神经官能症: 把一切东西都认为是自己的问题。
  2. \n
\n
\n

我如果怎么样就好了。我要是不怎么样就好了。总是充满后悔和内疚。祥林嫂

\n
\n
    \n
  1. 人格失调症:他认为这一切都不是我的问题。他能找到任何一个理由,是因为外在的东西,他就不会责怪自己,他认为都是你们的问题。
  2. \n
\n
\n

「神经官能症」自己活得很痛苦,「人格失调症」让别人活得很痛苦。

\n
\n
\n\n作者提供在冲绳岛上的一个案例,一个军官的妻子,宁愿自杀也不愿意去学自动挡开车的事。\n从某种意义上说,所有的孩子都患有人格失调症,都会本能的逃避责罚。 同时又患有某种神经官能症,把自己承受的痛苦看成是罪有应得。缺少关心的孩子会自惭形秽,认为自己不够可爱,缺点大于优点等等。\n
\n

如果你不能解决问题,那么你自己就会成为问题。我们需要合理的承担责任,既不把责任全部推卸到外部,也不把责任全部揽到自己身上。保持一个合理的平衡。

\n
\n

如果你不能让自己成为人格更加健全,更加成熟的人。你就会把问题带给你的孩子,带给你的家庭。

\n
\n

3 忠于事实

\n

大量的人是生活在自己的幻想当中的。这叫人生地图。他给自己绘制一张人生地图,他认为人生就这样,他已经认定了。这就叫做“不忠于事实”,他只 忠于自己的幻想

\n
\n\n案例:有个人小时候被父母欺骗过,就是父母说话经常不算数。导致他潜意识积累了一个信念:“父母是不可信”的。当他的人生地图绘制出来这么一个坐标,认为父母不可信了自后,他几乎就推论到“人人都不可信”。所以在他一生的成长过程当中,他跟警察发生矛盾,跟领导发生矛盾,跟顾客发生矛盾,跟妻子发生矛盾。案例中最后他唯一信任的是他的两个孩子。妻子把两个孩子带走,所以他人生也崩溃了。他跟作者约定时间不来,然后他说能不能星期六,作者说我的时间是跟别人约过的,不能随便调整。他说:“你不是心理医生吗?为什么不能多关心我一点呢”?他认为作者(心理医生)也是不可信任的人,直接拉黑。\n
\n这种人你很难跟他解释,很难让他面对真正的世界。因为在他心目当中完全是用自己的一套逻辑在解决问题。\n

所以所谓的「心理治疗」,就是鼓励「说真话」的游戏。鼓励大家能够面对事实,能够把自己看到的真相,感受到的真实的感觉,说出来的一个过程。所以没有经过这样的调试,有大量的人是天天活在「幻觉」当中的,就是沉浸在自己的人生地图当中。根本不去看一看,别人的地图是什么样。也根本不去看一看实际的生活当中,事实是什么样的。

\n

移情:人们会把对一个人的感情和经验移植在别人身上。会认为别人也这样。

\n
\n

应该说移情、或者忽略史实,也是一种懒惰的表现。因为去更新地图是件很费力的事情。

\n
\n

4 保持平衡

\n

既要承担责任,也要拒绝承担不该承担的责任。差不多又回到了「中庸」之道。「延迟满足」也不能延迟到无限, 从来不过好日子。既要延迟满足,也要过好当下的生活。要有一个富于弹性的约束机制。好像骑自行车下坡一样,既要享受速度,也要注意刹车。为了待会安全的拐弯,也要捏一捏车闸。
\n生活就是一个不断放弃的过程。必须能够学会放弃一件又一件的事情。包括接受心理治疗就是「放弃」—— 放弃了一个「自己是正常人」 的想法。

\n
\n埃里克 埃里克森列举的人一生当中不断放弃的事情\n
    \n
  1. 首先要放弃「无需对外界要求作出回应」的婴儿状态。
  2. \n
  3. 三四岁的时候有「无所不能的幻觉」,这个要放弃掉。(为何小孩子特别喜欢绿巨人、钢铁侠、金刚狼这样的超级英雄?因为每个人在三四岁的时候都曾经幻想过自己是无所不能的超人。所以这种童话永远有市场。)
  4. \n
  5. 放弃完全占有父亲或者母亲的欲望。放弃童年的依赖感。
  6. \n
  7. 放弃心中被扭曲了的父母形象。(我们曾经以为父母是完美的)放弃。
  8. \n
  9. 青春期的自以为拥有「无穷潜力」的感觉。放弃! I am the King of the World!
  10. \n
  11. 无拘无束的自由
  12. \n
  13. 青年时期的灵巧与活力
  14. \n
  15. 青春时期的性吸引力;长生不老的空想。
  16. \n
  17. 对子女的权威(在子女面前总是说了算的)
  18. \n
  19. 各种各样「暂时性」的权力——退休了,社会给你的权力也没有了。
  20. \n
  21. 身体永远健康——放弃
  22. \n
  23. 最后,自我以及生命本身也要放弃。
  24. \n
\n
\n

\n

【爱】 :为了促进自己和他人心智成熟,而不断拓展自我界限,实现自我完善的一种意愿。

\n
\n

核心观点就是「要看重心智成熟这件事」。心智成熟是发生在你和被爱的那个人之间的,两个人都需要达成心智成熟。
\n不要以为一昧的付出就是爱。爱的要求很高。要达成两个的共同成熟

\n
\n

一个人懂得什么是真正的爱,才能够是一个真正成熟的人。否则你会看到很多人以「爱」的名义在伤害、控制、占有对方。「爱」有以下四个误区:过度关注、坠入情网、精神灌注、自我牺牲。

\n

过度关注

\n
    \n
  • \n

    实际上是一种「依赖」
    \n例子,一个妈妈,孩子都上高中了,还每天开车接送孩子上学。说孩子一个上学走太让人担心了。「过度关注」实际上是一种「依赖」。(妈妈在“依赖”这个孩子)这种类型的人经常说的话是“没有你我活不下去”。这个小孩之所以出现在书中,是因为孩子长大后来做了心理咨询。他在人生当中做任何事情都不成功。他的能力非常的欠缺。为什么?因为他从小到大完全被母爱这样束缚着。他妈妈根本不去管孩子能否「成熟」。他妈妈根本不去管这样做对孩子的心智健康、发展有没有好处。唯一的就是「你别出事,我必须盯着你」!`她不是为对方在做这样的事,她是在为自己做这样的事情。如果发展到极致,变得很严重的话,会变成一种疾病,叫「消极性依赖人格失调症」。—— 他必须依赖某一个外在的东西,他才能够觉得自己是存在的。如果有这么一个人,就是死死的缠住他,就是不离开他。有一个人作为对象,他才能找到自己的位置。如果找不到这样的人,就很可能会沉迷于毒品和酒精。

    \n
  • \n
  • \n

    对「爱」无度的索求
    \n对别人的爱根本与对方无关,他只是希望找到一个人,能够投射自己在上面,能够找到自己——「因为有人爱我,我就存在」。(例子,有个人离婚了,生活很痛苦,用酒精麻醉自己。咨询的第二天来跟医生说,我好了,我现在很幸福。因为昨晚在酒吧认识一个女人,她说她爱我。我现在很好。)总是苦思如何获得别人的爱,却没有精力去爱别人。就像饥肠辘辘的人,总想着向别人讨要食物,却拿不出食物来帮助别人。他们永远孤独寂寞,永远无法体会到满足感。尤其可怕的是,他们不知道自己患上了「消极性依赖人格失调症」。其造成原因多是童年缺乏爱,然后总觉的自己「没资格被爱」。人要感觉自己是被爱的,才有资格跟别人平起平坐,独立地生活和对话。患有这种心理疾病的人,他根本没有感觉到自己的资格,永远都在怀疑别人不爱他。所以只要别人拒绝他,就会感到无比的痛苦和伤心。而他永远需要找到一个紧紧拉住的,依赖的对象。这不是爱,这是占有。

    \n
  • \n
\n

坠入情网

\n

坠入情网是欲望。是你体内的激素分泌。因为我们的基因要求我们要生殖,见到异性感觉自己爱上他了。实际上是自己的一种欲望。一段时间后当你的欲望被释放掉了,体内的激素的大潮开始退去的时候,会发现这个人看起啦那么讨厌。坠入情网实际上是「自我界限的短暂崩溃」。除了自我界限的理论,还有以下几个点:

\n
    \n
  • 不是出于主管意愿,它不是一个有计划有意识的选择。(很多人只把它看成一个感觉,而不是一个「动作」,爱是一个动词,不是感觉)
  • \n
  • 不是自我界限的扩展,而是自我界限的部分的暂时性的崩溃。扩展自我界限需要付出足够的努力,坠入情网却无需努力。
  • \n
  • 坠入情网唯一的作用是消除寂寞。而不是有目的的促进心灵的成长。
  • \n
  • 简单来说贪恋爱可能是「爱」的发端,可能能培养出来爱,但它不是「爱」本身。
  • \n
\n

精神贯注

\n

爱宠物、爱好这些也不是爱,而是「精神贯注」。就是当你把自己的精神贯注在一个事物上的时候,你以为这只狗“懂你”,其实上是“你投射在了它身上”,你在猜想它的想法。跟真正的爱不一样。为什么呢:

\n
    \n
  • 首先,我们跟宠物的沟通非常有限。我们不知道他们每天在想什么,却一厢情愿的把自己的想法和感受投射在它们身上。实际上这只是我们的主观愿望罢了。
  • \n
  • 其次,我们喜欢宠物的原因是因为它们表现乖巧,任凭摆弄。如果宠物不听话,破坏家具,随意大小便,甚至咬上我们几口。我们就可能把它赶出家门。如果要改变宠物的心智,我们只能把它送到宠物学校。如果与某个人相处,局面就完全不同了。
  • \n
\n

有一种精神贯注叫「婴儿之爱」。 很多妈妈只喜欢婴儿期的孩子。等孩子三四岁以后妈妈开始烦了。赶紧推给爷爷奶奶带。反过来呢,母爱很充沛,喜欢别人家的孩子,刚生的小婴儿。 这种不是爱,而是「唯命是从的追求」。 比如二战后美国的「战争新娘」。一开始新娘对丈夫唯命是从,当她们懂得英语,开始融入美国社会以后,矛盾就渐渐开始产生,离婚率开始上升。

\n

以上几种感情我们误以为是爱,其实不是。它们都有共同的特征,就是以「爱」作为幌子,只想满足自己的需要。却从来不把对方的心智成熟当一回事。

\n

自我牺牲

\n

甚至还有人人会发展出来「自我牺牲式的爱」。有个妻子,她老公总是欺骗她,总是有外遇。每次闹完,老公回来道歉,她又开始接受他。五六次以后,妻子去找心理医生谈。心理医生告诉她要想清楚,不能老是这样接受他。有一次这个妻子说,我又原谅他了,这次他是真的改好了。他特别怎么怎么样。结果医生发现这个妻子有“受虐倾向”。有受虐倾向的人,会把「自我牺牲」当作是「爱」。他们觉得只要我能够牺牲、奉献就好。

\n

这些东西也是来自童年的经历,就是他童年当中如果有一个这样的“楷模”,总是以自我牺牲为标榜,总是以为我为别人牺牲了那么多,所以 “你看我多好,多高尚”,他在潜意识当中就会慢慢接受“自我牺牲就是爱”这种想法。

\n
\n **自我界限**:\n小孩子刚出生的时候是没有自我界限的。他在挥动胳膊的时候,觉得整个房间都在动,他与这个世界没有是分割的。到了两三岁发现自己挥动胳膊的时候,房间没有动,甚至他发现自己哭的时候,别人并不饿。 才能慢慢感受到原来自己跟他人是不一样的。到青春期这个人的自我界限已经开始完全封闭起来了。原来这个世界只有我自己,连我的父母都不了解我,我的喜怒哀乐他们根本不知道。所以人们开始陷入深深的孤独。青春期的孩子觉得自己最“孤独”,他觉得没人理解他,我是一个完全独一无二的个体,谁跟我都不一样,他的自我界限完全封闭起来。\n到了谈恋爱。谈恋爱是需要冒风险的,你是需要有勇气打开自我的界限,和另外一个人融为一体的。所以初恋的时候,很多人会有「**圣洁**」的感觉。就是“我打开了”,有一个人竟然“完全懂我”。有一个人可以跟我融为一体,那种水乳交融的感觉,他以为自己找到了「真爱」。因为他的边界在短期的崩溃。当他的自我边界崩溃以后,他感受到了生命的狂喜,那个就是短暂的获得了「爱」的感觉。但是那是假象。`因为那个并不建立在令我和对方人格不断成熟的一个过程当中。他并不是希望达成心智的成熟,他只是自我边界的短暂崩溃`。所以过了一两个月以后,这个自我界限慢慢弥合起来,他发现说“这个人怎么跟我也不一样”?“这个人的想法跟我也不同”。 现在的孩子谈恋爱特别快,有感觉就谈,没感觉了就分。把「感觉」当成了「爱」,事实上感觉只是欲望,是性欲。\n 但不要觉得欲望不是一件好事,无论是欲望,还是依赖,或者过度关注这样的东西,都是`培养爱的基础`。\n正是因为两个人打破了边界,走到一起,双方有可能为对方作出了承诺。接下来为了完成自己的承诺,需要不断的努力,需要有自律性。当你的自律性跟承诺相结合在起来的时候,你的这个短暂的恋爱的感觉爱,会慢慢滋生出真正的爱。 能够带来对方和自己心智共同的成熟。\n
\n
\n

真正的「爱」 :爱是实际行动,是真正的付出。

\n

爱的感觉与精神贯注密不可分。后者是把情感与兴趣贯注在对外的对象上,将其当作属于自己的一部分。精神贯注虽然跟真正的爱容易混淆,但是依然有显著的区别。首先,精神贯注的对象不一定是有生命的事物。因此就不见得会有心灵的感受。其次,对某种事物产生精神贯注的人,未必会重视其心智的成熟。(比如无原则溺爱孩子的父母)第三,精神贯注可能与智慧和责任无关。(酒吧认识一个人,立刻就情有所钟。但没有任何计划性,没有后续责任)。最后,精神贯注随时都有可能消失。今晚还很开心,明天不开心就分手啰。

\n

真正的爱需要投入和奉献,需要付出全部的智慧与力量。要使爱的对象得到成长,就必须付出足够多的努力,不然爱的愿望就会落空。 唯有真正的投入与奉献,才是实现爱的有效方式。真正的爱是自主的选择,无论「爱」的「感觉」是否存在, 都要奉献出情感和智慧。

\n
\n

「爱」的表现

\n
    \n
  1. 倾听。我们真的能够拿出时间来,认真倾听对方的说话。最起码的尊重是通过倾听来展开的,我们要做一个良好的「倾听者」。
  2. \n
  3. 要有心里准备,接受爱的时候,就要准备承担风险。(有人经历过丧失亲人,之后就特别怕建立亲密关系。因为怕失去,「失去」的痛苦吓坏了他。)(爱还要面临冲突的风险。)
  4. \n
  5. 需要尊重对方的独立性。否则就是占有,就是依赖。
  6. \n
\n

信仰

\n

科学也是信仰

\n

科学也是一种信仰。这个世界上上信科学的人比信宗教的人多。人不是生活在一个真实的世界当中的,人是生活在思想家为我们所设定的思想通道当中的。科学家在不断的拓宽我们人类的视线,建立了科学的信仰。 作者认为宗教的信仰在某种程度上可能会导致人的某些情况下的精神分裂。但是在某些情况下也会带来信念,帮助人们解决心理的问题。比喻:倒洗澡水的时候,千万不要把婴儿也倒出去。对待信仰的时候,不能过于简单化。

\n

原罪

\n

作者认为人类的「原罪」就是「懒惰」

\n

自律需要用力,爱需要用力,这个世界天然的方向是「熵增」,屋子一定会变乱。我花力气把屋子整理干净十个「逆熵」的过程,逆熵是需要话费气力的。 人天生喜欢熵增,喜欢懒惰。在伊甸园,其实上帝经常在园子里散步。这两孩子如果能去问一下,这玩意儿能吃吗?人类的命运就改变了。这两个人为什么不去问 一下上帝呢?因为这两孩子「懒惰」,而「懒惰」的背后是「恐惧」。他们担心问了上帝以后受到上帝的责罚。

\n
\n

(天涯:我认为这个解释不对。那个时候的亚当和夏娃没有罪恶感,也从来没有受过责罚,怎么会有这个恐惧呢?而恐惧则是被赶出伊甸园以后人类才有的心智。)

\n
\n

有人不好好学习,是因为就算好好学习了也未必学得好啊。如果好好学了而没有学好,就会面对失去「我不是没能力,只是不愿学而已」这块遮羞布的恐惧。

\n

尽量要做到潜意识和意识「合一」。因为潜意识里面有很多的能量,而我们由于“懒惰”以及“恐惧”不愿意去开发的,不愿意去面对的。

\n

这本书为什么叫【少有人走的路】呢?因为人人都喜欢熵增的方向,都喜欢轻松的方向,人人都喜欢懒惰的方向。喜欢部分什么劲,就得到一切的这种感觉。如果你想要变得成熟,就要费力去做一些逆熵的行为,自律的事,延迟满足的事,用行动表达「爱」的 过程。

\n

两种力量

\n

这个世界始终是由两种力量来统治的,分别是「政治的力量」和「心灵的力量」。

\n

【政治的力量】:以公开或者隐秘的方式,去强迫别人遵循自己的意愿。这种力量既存在于权力之中,也存在于金钱之中。然而他并不属于拥有权力或者金钱的人。归根到底,政治的力量和德行以及智慧无关,最愚蠢最邪恶的人也可能成为地球的统治者。
\n【心灵的力量】:则完全存在于人类的心中,它和强迫、控制别人的力量没有关系。它是在意识基础上作出决定的力量。也就是「意识的力量」。

\n

如果我们的心理能够得到力量,我们就会感到舒适和愉快,在人生的旅途上稳扎稳打,循序渐进。 进步带给我们的愉悦感难以言喻。没有什么比成为人生的专家,熟知自己所做的事情,更让人感觉到幸福。我们的心灵越是成熟,就越有可能成为人生的专家。当我们的心智成熟到一定的阶段,我们就会更加谦逊而快乐。

\n
\n","site":{"data":{}},"excerpt":"

成熟 = 自律 +

","more":"

自律

\n

【自律】 : 主动要求自己以积极的态度去承受痛苦,解决问题。

\n

自律的四个原则:延迟满足感、承担责任、忠于事实、保持平衡。:smile:

\n

1 延迟满足感

\n
\n\n人生当中总是绕着困难走。一个揍孩子和对孩子大喊大叫的父母就是不懂得延迟满足感的父母。 应该陪着孩子一起经历困难和痛苦。而父母试图通过家庭暴力的方式,试图将父母本身的责任区隔开。父母没有学会延迟满足感,这个孩子将来长大了也不会。很多人延迟满足感的能力非常糟糕,来自于父母的不自律。当父母不自律的时候,孩子就没法获得足够的爱和照顾。—— 所以这个孩子会忽略自我的价值。有的人喜欢浪费时间,而浪费时间的意思就是,_「我这个人的时间没什么价值」_。\n不会延迟满足感的人,在长大后看到问题会假装没看到,以为等着问题慢慢就会过去,期待问题自行消失。\n
\n
\n
    \n
  • 训斥孩子 ~> 是为了迅速达成目的,而不是耐心陪孩子面对问题。
  • \n
  • 父母不自律 => 孩子不自律
  • \n
  • 不会延迟满足感 => 有意忽略问题
  • \n
\n
\n

2 承担责任

\n
    \n
  1. 神经官能症: 把一切东西都认为是自己的问题。
  2. \n
\n
\n

我如果怎么样就好了。我要是不怎么样就好了。总是充满后悔和内疚。祥林嫂

\n
\n
    \n
  1. 人格失调症:他认为这一切都不是我的问题。他能找到任何一个理由,是因为外在的东西,他就不会责怪自己,他认为都是你们的问题。
  2. \n
\n
\n

「神经官能症」自己活得很痛苦,「人格失调症」让别人活得很痛苦。

\n
\n
\n\n作者提供在冲绳岛上的一个案例,一个军官的妻子,宁愿自杀也不愿意去学自动挡开车的事。\n从某种意义上说,所有的孩子都患有人格失调症,都会本能的逃避责罚。 同时又患有某种神经官能症,把自己承受的痛苦看成是罪有应得。缺少关心的孩子会自惭形秽,认为自己不够可爱,缺点大于优点等等。\n
\n

如果你不能解决问题,那么你自己就会成为问题。我们需要合理的承担责任,既不把责任全部推卸到外部,也不把责任全部揽到自己身上。保持一个合理的平衡。

\n
\n

如果你不能让自己成为人格更加健全,更加成熟的人。你就会把问题带给你的孩子,带给你的家庭。

\n
\n

3 忠于事实

\n

大量的人是生活在自己的幻想当中的。这叫人生地图。他给自己绘制一张人生地图,他认为人生就这样,他已经认定了。这就叫做“不忠于事实”,他只 忠于自己的幻想

\n
\n\n案例:有个人小时候被父母欺骗过,就是父母说话经常不算数。导致他潜意识积累了一个信念:“父母是不可信”的。当他的人生地图绘制出来这么一个坐标,认为父母不可信了自后,他几乎就推论到“人人都不可信”。所以在他一生的成长过程当中,他跟警察发生矛盾,跟领导发生矛盾,跟顾客发生矛盾,跟妻子发生矛盾。案例中最后他唯一信任的是他的两个孩子。妻子把两个孩子带走,所以他人生也崩溃了。他跟作者约定时间不来,然后他说能不能星期六,作者说我的时间是跟别人约过的,不能随便调整。他说:“你不是心理医生吗?为什么不能多关心我一点呢”?他认为作者(心理医生)也是不可信任的人,直接拉黑。\n
\n这种人你很难跟他解释,很难让他面对真正的世界。因为在他心目当中完全是用自己的一套逻辑在解决问题。\n

所以所谓的「心理治疗」,就是鼓励「说真话」的游戏。鼓励大家能够面对事实,能够把自己看到的真相,感受到的真实的感觉,说出来的一个过程。所以没有经过这样的调试,有大量的人是天天活在「幻觉」当中的,就是沉浸在自己的人生地图当中。根本不去看一看,别人的地图是什么样。也根本不去看一看实际的生活当中,事实是什么样的。

\n

移情:人们会把对一个人的感情和经验移植在别人身上。会认为别人也这样。

\n
\n

应该说移情、或者忽略史实,也是一种懒惰的表现。因为去更新地图是件很费力的事情。

\n
\n

4 保持平衡

\n

既要承担责任,也要拒绝承担不该承担的责任。差不多又回到了「中庸」之道。「延迟满足」也不能延迟到无限, 从来不过好日子。既要延迟满足,也要过好当下的生活。要有一个富于弹性的约束机制。好像骑自行车下坡一样,既要享受速度,也要注意刹车。为了待会安全的拐弯,也要捏一捏车闸。
\n生活就是一个不断放弃的过程。必须能够学会放弃一件又一件的事情。包括接受心理治疗就是「放弃」—— 放弃了一个「自己是正常人」 的想法。

\n
\n埃里克 埃里克森列举的人一生当中不断放弃的事情\n
    \n
  1. 首先要放弃「无需对外界要求作出回应」的婴儿状态。
  2. \n
  3. 三四岁的时候有「无所不能的幻觉」,这个要放弃掉。(为何小孩子特别喜欢绿巨人、钢铁侠、金刚狼这样的超级英雄?因为每个人在三四岁的时候都曾经幻想过自己是无所不能的超人。所以这种童话永远有市场。)
  4. \n
  5. 放弃完全占有父亲或者母亲的欲望。放弃童年的依赖感。
  6. \n
  7. 放弃心中被扭曲了的父母形象。(我们曾经以为父母是完美的)放弃。
  8. \n
  9. 青春期的自以为拥有「无穷潜力」的感觉。放弃! I am the King of the World!
  10. \n
  11. 无拘无束的自由
  12. \n
  13. 青年时期的灵巧与活力
  14. \n
  15. 青春时期的性吸引力;长生不老的空想。
  16. \n
  17. 对子女的权威(在子女面前总是说了算的)
  18. \n
  19. 各种各样「暂时性」的权力——退休了,社会给你的权力也没有了。
  20. \n
  21. 身体永远健康——放弃
  22. \n
  23. 最后,自我以及生命本身也要放弃。
  24. \n
\n
\n

\n

【爱】 :为了促进自己和他人心智成熟,而不断拓展自我界限,实现自我完善的一种意愿。

\n
\n

核心观点就是「要看重心智成熟这件事」。心智成熟是发生在你和被爱的那个人之间的,两个人都需要达成心智成熟。
\n不要以为一昧的付出就是爱。爱的要求很高。要达成两个的共同成熟

\n
\n

一个人懂得什么是真正的爱,才能够是一个真正成熟的人。否则你会看到很多人以「爱」的名义在伤害、控制、占有对方。「爱」有以下四个误区:过度关注、坠入情网、精神灌注、自我牺牲。

\n

过度关注

\n
    \n
  • \n

    实际上是一种「依赖」
    \n例子,一个妈妈,孩子都上高中了,还每天开车接送孩子上学。说孩子一个上学走太让人担心了。「过度关注」实际上是一种「依赖」。(妈妈在“依赖”这个孩子)这种类型的人经常说的话是“没有你我活不下去”。这个小孩之所以出现在书中,是因为孩子长大后来做了心理咨询。他在人生当中做任何事情都不成功。他的能力非常的欠缺。为什么?因为他从小到大完全被母爱这样束缚着。他妈妈根本不去管孩子能否「成熟」。他妈妈根本不去管这样做对孩子的心智健康、发展有没有好处。唯一的就是「你别出事,我必须盯着你」!`她不是为对方在做这样的事,她是在为自己做这样的事情。如果发展到极致,变得很严重的话,会变成一种疾病,叫「消极性依赖人格失调症」。—— 他必须依赖某一个外在的东西,他才能够觉得自己是存在的。如果有这么一个人,就是死死的缠住他,就是不离开他。有一个人作为对象,他才能找到自己的位置。如果找不到这样的人,就很可能会沉迷于毒品和酒精。

    \n
  • \n
  • \n

    对「爱」无度的索求
    \n对别人的爱根本与对方无关,他只是希望找到一个人,能够投射自己在上面,能够找到自己——「因为有人爱我,我就存在」。(例子,有个人离婚了,生活很痛苦,用酒精麻醉自己。咨询的第二天来跟医生说,我好了,我现在很幸福。因为昨晚在酒吧认识一个女人,她说她爱我。我现在很好。)总是苦思如何获得别人的爱,却没有精力去爱别人。就像饥肠辘辘的人,总想着向别人讨要食物,却拿不出食物来帮助别人。他们永远孤独寂寞,永远无法体会到满足感。尤其可怕的是,他们不知道自己患上了「消极性依赖人格失调症」。其造成原因多是童年缺乏爱,然后总觉的自己「没资格被爱」。人要感觉自己是被爱的,才有资格跟别人平起平坐,独立地生活和对话。患有这种心理疾病的人,他根本没有感觉到自己的资格,永远都在怀疑别人不爱他。所以只要别人拒绝他,就会感到无比的痛苦和伤心。而他永远需要找到一个紧紧拉住的,依赖的对象。这不是爱,这是占有。

    \n
  • \n
\n

坠入情网

\n

坠入情网是欲望。是你体内的激素分泌。因为我们的基因要求我们要生殖,见到异性感觉自己爱上他了。实际上是自己的一种欲望。一段时间后当你的欲望被释放掉了,体内的激素的大潮开始退去的时候,会发现这个人看起啦那么讨厌。坠入情网实际上是「自我界限的短暂崩溃」。除了自我界限的理论,还有以下几个点:

\n
    \n
  • 不是出于主管意愿,它不是一个有计划有意识的选择。(很多人只把它看成一个感觉,而不是一个「动作」,爱是一个动词,不是感觉)
  • \n
  • 不是自我界限的扩展,而是自我界限的部分的暂时性的崩溃。扩展自我界限需要付出足够的努力,坠入情网却无需努力。
  • \n
  • 坠入情网唯一的作用是消除寂寞。而不是有目的的促进心灵的成长。
  • \n
  • 简单来说贪恋爱可能是「爱」的发端,可能能培养出来爱,但它不是「爱」本身。
  • \n
\n

精神贯注

\n

爱宠物、爱好这些也不是爱,而是「精神贯注」。就是当你把自己的精神贯注在一个事物上的时候,你以为这只狗“懂你”,其实上是“你投射在了它身上”,你在猜想它的想法。跟真正的爱不一样。为什么呢:

\n
    \n
  • 首先,我们跟宠物的沟通非常有限。我们不知道他们每天在想什么,却一厢情愿的把自己的想法和感受投射在它们身上。实际上这只是我们的主观愿望罢了。
  • \n
  • 其次,我们喜欢宠物的原因是因为它们表现乖巧,任凭摆弄。如果宠物不听话,破坏家具,随意大小便,甚至咬上我们几口。我们就可能把它赶出家门。如果要改变宠物的心智,我们只能把它送到宠物学校。如果与某个人相处,局面就完全不同了。
  • \n
\n

有一种精神贯注叫「婴儿之爱」。 很多妈妈只喜欢婴儿期的孩子。等孩子三四岁以后妈妈开始烦了。赶紧推给爷爷奶奶带。反过来呢,母爱很充沛,喜欢别人家的孩子,刚生的小婴儿。 这种不是爱,而是「唯命是从的追求」。 比如二战后美国的「战争新娘」。一开始新娘对丈夫唯命是从,当她们懂得英语,开始融入美国社会以后,矛盾就渐渐开始产生,离婚率开始上升。

\n

以上几种感情我们误以为是爱,其实不是。它们都有共同的特征,就是以「爱」作为幌子,只想满足自己的需要。却从来不把对方的心智成熟当一回事。

\n

自我牺牲

\n

甚至还有人人会发展出来「自我牺牲式的爱」。有个妻子,她老公总是欺骗她,总是有外遇。每次闹完,老公回来道歉,她又开始接受他。五六次以后,妻子去找心理医生谈。心理医生告诉她要想清楚,不能老是这样接受他。有一次这个妻子说,我又原谅他了,这次他是真的改好了。他特别怎么怎么样。结果医生发现这个妻子有“受虐倾向”。有受虐倾向的人,会把「自我牺牲」当作是「爱」。他们觉得只要我能够牺牲、奉献就好。

\n

这些东西也是来自童年的经历,就是他童年当中如果有一个这样的“楷模”,总是以自我牺牲为标榜,总是以为我为别人牺牲了那么多,所以 “你看我多好,多高尚”,他在潜意识当中就会慢慢接受“自我牺牲就是爱”这种想法。

\n
\n **自我界限**:\n小孩子刚出生的时候是没有自我界限的。他在挥动胳膊的时候,觉得整个房间都在动,他与这个世界没有是分割的。到了两三岁发现自己挥动胳膊的时候,房间没有动,甚至他发现自己哭的时候,别人并不饿。 才能慢慢感受到原来自己跟他人是不一样的。到青春期这个人的自我界限已经开始完全封闭起来了。原来这个世界只有我自己,连我的父母都不了解我,我的喜怒哀乐他们根本不知道。所以人们开始陷入深深的孤独。青春期的孩子觉得自己最“孤独”,他觉得没人理解他,我是一个完全独一无二的个体,谁跟我都不一样,他的自我界限完全封闭起来。\n到了谈恋爱。谈恋爱是需要冒风险的,你是需要有勇气打开自我的界限,和另外一个人融为一体的。所以初恋的时候,很多人会有「**圣洁**」的感觉。就是“我打开了”,有一个人竟然“完全懂我”。有一个人可以跟我融为一体,那种水乳交融的感觉,他以为自己找到了「真爱」。因为他的边界在短期的崩溃。当他的自我边界崩溃以后,他感受到了生命的狂喜,那个就是短暂的获得了「爱」的感觉。但是那是假象。`因为那个并不建立在令我和对方人格不断成熟的一个过程当中。他并不是希望达成心智的成熟,他只是自我边界的短暂崩溃`。所以过了一两个月以后,这个自我界限慢慢弥合起来,他发现说“这个人怎么跟我也不一样”?“这个人的想法跟我也不同”。 现在的孩子谈恋爱特别快,有感觉就谈,没感觉了就分。把「感觉」当成了「爱」,事实上感觉只是欲望,是性欲。\n 但不要觉得欲望不是一件好事,无论是欲望,还是依赖,或者过度关注这样的东西,都是`培养爱的基础`。\n正是因为两个人打破了边界,走到一起,双方有可能为对方作出了承诺。接下来为了完成自己的承诺,需要不断的努力,需要有自律性。当你的自律性跟承诺相结合在起来的时候,你的这个短暂的恋爱的感觉爱,会慢慢滋生出真正的爱。 能够带来对方和自己心智共同的成熟。\n
\n
\n

真正的「爱」 :爱是实际行动,是真正的付出。

\n

爱的感觉与精神贯注密不可分。后者是把情感与兴趣贯注在对外的对象上,将其当作属于自己的一部分。精神贯注虽然跟真正的爱容易混淆,但是依然有显著的区别。首先,精神贯注的对象不一定是有生命的事物。因此就不见得会有心灵的感受。其次,对某种事物产生精神贯注的人,未必会重视其心智的成熟。(比如无原则溺爱孩子的父母)第三,精神贯注可能与智慧和责任无关。(酒吧认识一个人,立刻就情有所钟。但没有任何计划性,没有后续责任)。最后,精神贯注随时都有可能消失。今晚还很开心,明天不开心就分手啰。

\n

真正的爱需要投入和奉献,需要付出全部的智慧与力量。要使爱的对象得到成长,就必须付出足够多的努力,不然爱的愿望就会落空。 唯有真正的投入与奉献,才是实现爱的有效方式。真正的爱是自主的选择,无论「爱」的「感觉」是否存在, 都要奉献出情感和智慧。

\n
\n

「爱」的表现

\n
    \n
  1. 倾听。我们真的能够拿出时间来,认真倾听对方的说话。最起码的尊重是通过倾听来展开的,我们要做一个良好的「倾听者」。
  2. \n
  3. 要有心里准备,接受爱的时候,就要准备承担风险。(有人经历过丧失亲人,之后就特别怕建立亲密关系。因为怕失去,「失去」的痛苦吓坏了他。)(爱还要面临冲突的风险。)
  4. \n
  5. 需要尊重对方的独立性。否则就是占有,就是依赖。
  6. \n
\n

信仰

\n

科学也是信仰

\n

科学也是一种信仰。这个世界上上信科学的人比信宗教的人多。人不是生活在一个真实的世界当中的,人是生活在思想家为我们所设定的思想通道当中的。科学家在不断的拓宽我们人类的视线,建立了科学的信仰。 作者认为宗教的信仰在某种程度上可能会导致人的某些情况下的精神分裂。但是在某些情况下也会带来信念,帮助人们解决心理的问题。比喻:倒洗澡水的时候,千万不要把婴儿也倒出去。对待信仰的时候,不能过于简单化。

\n

原罪

\n

作者认为人类的「原罪」就是「懒惰」

\n

自律需要用力,爱需要用力,这个世界天然的方向是「熵增」,屋子一定会变乱。我花力气把屋子整理干净十个「逆熵」的过程,逆熵是需要话费气力的。 人天生喜欢熵增,喜欢懒惰。在伊甸园,其实上帝经常在园子里散步。这两孩子如果能去问一下,这玩意儿能吃吗?人类的命运就改变了。这两个人为什么不去问 一下上帝呢?因为这两孩子「懒惰」,而「懒惰」的背后是「恐惧」。他们担心问了上帝以后受到上帝的责罚。

\n
\n

(天涯:我认为这个解释不对。那个时候的亚当和夏娃没有罪恶感,也从来没有受过责罚,怎么会有这个恐惧呢?而恐惧则是被赶出伊甸园以后人类才有的心智。)

\n
\n

有人不好好学习,是因为就算好好学习了也未必学得好啊。如果好好学了而没有学好,就会面对失去「我不是没能力,只是不愿学而已」这块遮羞布的恐惧。

\n

尽量要做到潜意识和意识「合一」。因为潜意识里面有很多的能量,而我们由于“懒惰”以及“恐惧”不愿意去开发的,不愿意去面对的。

\n

这本书为什么叫【少有人走的路】呢?因为人人都喜欢熵增的方向,都喜欢轻松的方向,人人都喜欢懒惰的方向。喜欢部分什么劲,就得到一切的这种感觉。如果你想要变得成熟,就要费力去做一些逆熵的行为,自律的事,延迟满足的事,用行动表达「爱」的 过程。

\n

两种力量

\n

这个世界始终是由两种力量来统治的,分别是「政治的力量」和「心灵的力量」。

\n

【政治的力量】:以公开或者隐秘的方式,去强迫别人遵循自己的意愿。这种力量既存在于权力之中,也存在于金钱之中。然而他并不属于拥有权力或者金钱的人。归根到底,政治的力量和德行以及智慧无关,最愚蠢最邪恶的人也可能成为地球的统治者。
\n【心灵的力量】:则完全存在于人类的心中,它和强迫、控制别人的力量没有关系。它是在意识基础上作出决定的力量。也就是「意识的力量」。

\n

如果我们的心理能够得到力量,我们就会感到舒适和愉快,在人生的旅途上稳扎稳打,循序渐进。 进步带给我们的愉悦感难以言喻。没有什么比成为人生的专家,熟知自己所做的事情,更让人感觉到幸福。我们的心灵越是成熟,就越有可能成为人生的专家。当我们的心智成熟到一定的阶段,我们就会更加谦逊而快乐。

\n
"},{"title":"JavaScript & Typescript技术摘要","date":"2019-09-14T07:32:15.000Z","urlname":"javascript-typescript-skills","toc":true,"notshow":false,"_content":"\nJavasript 和 Typescript 的重要技巧。\n\n\n\n\n### 零散知识点\n\n- 列举 [Enum](https://www.typescriptlang.org/docs/handbook/enums.html) \n\n### Promise\n\n##### 输出链条\n\n文档 [Promises chaning](https://javascript.info/promise-chaining) \n\n:pencil2: 可以在 `then` 函数里面跑出 结果 `或者` 第二个 `Promise` \n\n##### 等待多个 Promise\n\n```javascript\nlet p1 = promise1\nlet p2 = promise2\nconst promises = Promise.all([p1, p2])\nreturn promises\n```\n\n### 声明以及定义扩展\n\n在 `*.d.ts` 文件中声明类型 \n\n```javascript\ndeclare type Book = {\n\ttitle: string,\n\tcomment?: string\n}\n```\n\n 对 JavaScript 的原型进行扩展, 在一个 TS 文件进行定义和实现\n\n```typescript\n// ...path/common.ts\nexport {} // this will make it module\ndeclare global {\n interface String {\n IsNullOrEmpty():boolean;\n Latex(color?:string):string;\n }\n}\n\nString.prototype.IsNullOrEmpty = function(){\n return this == undefined || this == null || this == \"\"\n}\n```\n\n在需要的地方引用\n\n```typescript\nimport '..path/common';\n\nlet str = \"\"\nconst is_it_empty = str.IsNullOrEmpty()\n```\n\n\n\n### 读取文本\n\n###### Html5 标准按钮\n\n```html\n
\n```\n\nJavascript 读取文本内容并转为数据库 (*使用 sql.js*)\n\n```javascript\nLoadLocalFile(file) {\n const fileurl: File = file.target.files[0];\n const reader = new FileReader();\n reader.onload = () => {\n console.log('read file:', reader.result);\n const buffer = reader.result;\n const Uints = new Uint8Array(buffer as ArrayBuffer);\n const db = new SQL.Database(Uints);\n const nodes = db.exec('SELECT * From node');\n console.log(nodes);\n };\n\n reader.readAsArrayBuffer(fileurl);\n }\n```\n\n###### 使用nix-file-helpers 插件\n\n[文档地址](https://www.npmjs.com/package/ngx-file-helpers)\n\n[演示地址](https://www.npmjs.com/package/ngx-file-helpers)\n\nHtml\n\n```html\n导入案例\n```\n\n代码,读取文件\n\n```javascript\nonFilePicked(file: ReadFile) {\n const Uints = new Uint8Array(file.content as ArrayBuffer);\n const db = new SQL.Database(Uints);\n const nodes = db.exec('SELECT * From node');\n console.log(nodes);\n }\n```\n\n\n\n\n\n### 测试\n\n###### 引用第三方js文件\n\n在 **angular.json** 文件的 `test-->scripts` 中添加需要引用的文件。","source":"_posts/IT/Code/Javascript技术摘要.md","raw":"---\ntitle: JavaScript & Typescript技术摘要\ndate: 2019-09-14 09:32:15\nurlname: javascript-typescript-skills\ntoc: true\ntags: [Hexo]\ncategories: [IT, Code]\nnotshow: false\n---\n\nJavasript 和 Typescript 的重要技巧。\n\n\n\n\n### 零散知识点\n\n- 列举 [Enum](https://www.typescriptlang.org/docs/handbook/enums.html) \n\n### Promise\n\n##### 输出链条\n\n文档 [Promises chaning](https://javascript.info/promise-chaining) \n\n:pencil2: 可以在 `then` 函数里面跑出 结果 `或者` 第二个 `Promise` \n\n##### 等待多个 Promise\n\n```javascript\nlet p1 = promise1\nlet p2 = promise2\nconst promises = Promise.all([p1, p2])\nreturn promises\n```\n\n### 声明以及定义扩展\n\n在 `*.d.ts` 文件中声明类型 \n\n```javascript\ndeclare type Book = {\n\ttitle: string,\n\tcomment?: string\n}\n```\n\n 对 JavaScript 的原型进行扩展, 在一个 TS 文件进行定义和实现\n\n```typescript\n// ...path/common.ts\nexport {} // this will make it module\ndeclare global {\n interface String {\n IsNullOrEmpty():boolean;\n Latex(color?:string):string;\n }\n}\n\nString.prototype.IsNullOrEmpty = function(){\n return this == undefined || this == null || this == \"\"\n}\n```\n\n在需要的地方引用\n\n```typescript\nimport '..path/common';\n\nlet str = \"\"\nconst is_it_empty = str.IsNullOrEmpty()\n```\n\n\n\n### 读取文本\n\n###### Html5 标准按钮\n\n```html\n
\n```\n\nJavascript 读取文本内容并转为数据库 (*使用 sql.js*)\n\n```javascript\nLoadLocalFile(file) {\n const fileurl: File = file.target.files[0];\n const reader = new FileReader();\n reader.onload = () => {\n console.log('read file:', reader.result);\n const buffer = reader.result;\n const Uints = new Uint8Array(buffer as ArrayBuffer);\n const db = new SQL.Database(Uints);\n const nodes = db.exec('SELECT * From node');\n console.log(nodes);\n };\n\n reader.readAsArrayBuffer(fileurl);\n }\n```\n\n###### 使用nix-file-helpers 插件\n\n[文档地址](https://www.npmjs.com/package/ngx-file-helpers)\n\n[演示地址](https://www.npmjs.com/package/ngx-file-helpers)\n\nHtml\n\n```html\n导入案例\n```\n\n代码,读取文件\n\n```javascript\nonFilePicked(file: ReadFile) {\n const Uints = new Uint8Array(file.content as ArrayBuffer);\n const db = new SQL.Database(Uints);\n const nodes = db.exec('SELECT * From node');\n console.log(nodes);\n }\n```\n\n\n\n\n\n### 测试\n\n###### 引用第三方js文件\n\n在 **angular.json** 文件的 `test-->scripts` 中添加需要引用的文件。","slug":"IT/Code/Javascript技术摘要","published":1,"updated":"2020-05-11T03:54:03.957Z","_id":"cka1y597r00154huu5w41rgul","comments":1,"layout":"post","photos":[],"link":"","content":"

Javasript 和 Typescript 的重要技巧。

\n\n

零散知识点

\n\n

Promise

\n
输出链条
\n

文档 Promises chaning

\n

:pencil2: 可以在 then 函数里面跑出 结果 或者 第二个 Promise

\n
等待多个 Promise
\n
1
2
3
4
let p1 = promise1
let p2 = promise2
const promises = Promise.all([p1, p2])
return promises
\n

声明以及定义扩展

\n

*.d.ts 文件中声明类型

\n
1
2
3
4
declare type Book = {
\ttitle: string,
\tcomment?: string
}
\n

对 JavaScript 的原型进行扩展, 在一个 TS 文件进行定义和实现

\n
1
2
3
4
5
6
7
8
9
10
11
12
// ...path/common.ts
export {} // this will make it module
declare global {
interface String {
IsNullOrEmpty():boolean;
Latex(color?:string):string;
}
}

String.prototype.IsNullOrEmpty = function(){
return this == undefined || this == null || this == \"\"
}
\n

在需要的地方引用

\n
1
2
3
4
import '..path/common';

let str = \"\"
const is_it_empty = str.IsNullOrEmpty()
\n

读取文本

\n
Html5 标准按钮
\n
1
<div type='file' (change)='LoadLocalFile($event)'></div>
\n

Javascript 读取文本内容并转为数据库 (使用 sql.js)

\n
1
2
3
4
5
6
7
8
9
10
11
12
13
14
LoadLocalFile(file) {
const fileurl: File = file.target.files[0];
const reader = new FileReader();
reader.onload = () => {
console.log('read file:', reader.result);
const buffer = reader.result;
const Uints = new Uint8Array(buffer as ArrayBuffer);
const db = new SQL.Database(Uints);
const nodes = db.exec('SELECT * From node');
console.log(nodes);
};

reader.readAsArrayBuffer(fileurl);
}
\n
使用nix-file-helpers 插件
\n

文档地址

\n

演示地址

\n

Html

\n
1
2
3
4
5
<ion-button   ngxFilePicker #filePicker=\"ngxFilePicker\" 
[readMode]=\"readMode\"
(readStart)=\"onReadStart($event)\"
(filePick)=\"onFilePicked($event)\"
(readEnd)=\"onReadEnd($event)\">导入案例</ion-button>
\n

代码,读取文件

\n
1
2
3
4
5
6
onFilePicked(file: ReadFile) {
const Uints = new Uint8Array(file.content as ArrayBuffer);
const db = new SQL.Database(Uints);
const nodes = db.exec('SELECT * From node');
console.log(nodes);
}
\n

测试

\n
引用第三方js文件
\n

angular.json 文件的 test-->scripts 中添加需要引用的文件。

\n","site":{"data":{}},"excerpt":"

Javasript 和 Typescript 的重要技巧。

","more":"

零散知识点

\n\n

Promise

\n
输出链条
\n

文档 Promises chaning

\n

:pencil2: 可以在 then 函数里面跑出 结果 或者 第二个 Promise

\n
等待多个 Promise
\n\n

声明以及定义扩展

\n

*.d.ts 文件中声明类型

\n\n

对 JavaScript 的原型进行扩展, 在一个 TS 文件进行定义和实现

\n\n

在需要的地方引用

\n\n

读取文本

\n
Html5 标准按钮
\n\n

Javascript 读取文本内容并转为数据库 (使用 sql.js)

\n\n
使用nix-file-helpers 插件
\n

文档地址

\n

演示地址

\n

Html

\n\n

代码,读取文件

\n\n

测试

\n
引用第三方js文件
\n

angular.json 文件的 test-->scripts 中添加需要引用的文件。

"},{"title":"Mac使用标签","date":"2019-07-22T16:58:50.000Z","urlname":"mac-using-tags","toc":true,"notshow":true,"_content":"## 使用标签\n在 Mac 上,执行以下任一项操作:\n\n- 给打开的文件添加标签:将鼠标指针悬停在文稿标题右侧,点按箭头,在“标签”栏中点按,然后输入新标签,或者从列表中选取一个标签。\n- 存储新文件时添加标签:点按“文件”>“存储”。在“存储”对话框中,在“标签”栏中点按,然后输入新标签,或者从列表中选取一个标签。\n- 给桌面上或“访达”中的文件添加标签:选择项目,然后打开“文件”菜单。也可以按住 Control 键点按该项目,或用双指轻点它。在“标签”下方选取颜色![img](https://www.macdaxue.com/wp-content/uploads/2018/10/icon_blue_circle.png),或点按“标签”以从更多标签中进行选择或输入新标签。在“访达”窗口中,也可以选择该项目,点按“标签”按钮 ![img](https://www.macdaxue.com/wp-content/uploads/2018/10/icon_tag.png),然后输入新标签,或从列表中选取一个标签。\n\n## 查找含有标签的项目\n\n1. 在 Mac 上,点按程序坞中的“访达”图标 ![img](https://www.macdaxue.com/wp-content/uploads/2018/10/icon_finder.png)以打开“访达”窗口。\n2. 请执行以下一项操作:\n - 搜索标签:在搜索栏中输入标签颜色或名称,然后从建议中选择该标签。\n - 在边栏中选择标签:若要查看带有某个标签的所有项目,请在“访达”边栏中点按标签![img](https://www.macdaxue.com/wp-content/uploads/2018/10/icon_blue_circle.png)。若要更改在边栏中看到的项目,请选取“访达”>“偏好设置”,点按“标签”,然后选择想要查看的标签。\n - 按标签将项目分组: 点按“分组”按钮![img](https://www.macdaxue.com/wp-content/uploads/2018/10/icon_group.png),然后选取“标签”。\n - 按标签排序项目:在任何显示方式下,选取“显示”>“查看显示选项”,点按“排序方式”弹出式菜单,然后选取“标签”。在“列表显示”下,选择“标签”复选框以显示分栏,将指针移到“标签”分栏上方,然后点按。再次点按分栏名称来倒序排列。\n\n## 移除标签\n\n在 Mac 上,请执行以下一项操作:\n\n- 从项目中移除标签:按住 Control 键点按项目或使用双指轻点项目,然后点按“标签”。选择您想要移除的标签,然后按下 Delete 键。\n- 从 Mac 中移除标签:在“访达”中,选取“访达”>“偏好设置”,然后点按“标签”。选择您想要移除的标签,然后点按移除按钮——。\n\n## 编辑标签\n\n1. 在 Mac 上的“访达”![img](https://www.macdaxue.com/wp-content/uploads/2018/10/icon_finder.png)中,选取“访达”>“偏好设置”,然后点按“标签”。\n2. 请执行以下一项操作:\n - 在“访达”边栏中查看标签:选择标签右侧的蓝色复选框。\n - 更改标签颜色:点按标签![img](https://www.macdaxue.com/wp-content/uploads/2018/10/icon_blue_circle.png)\n - 旁边的颜色,然后选取新的颜色。\n - 更改标签名称:点按标签,点按标签名称,然后输入新名称。\n - 创建新标签:点按添加按钮 ![img](https://www.macdaxue.com/wp-content/uploads/2018/06/IL_AddiOS.png)。\n - 删除标签:选择标签,然后点按移除按钮 ——。\n - 将标签添加到[快捷键](https://www.macdaxue.com/os-x-key/)菜单中:在列表中选择标签,然后将它拖到您想要在窗口底部的个人收藏部分中替换的标签上方。当您按下 Control 键点按文件时,在出现的[快捷键](https://www.macdaxue.com/os-x-key/)菜单中可至多有七个标签。\n - 从快捷键菜单中移除标签:将标签拖出“个人收藏标签”部分,直到看到移除符号![img](https://www.macdaxue.com/wp-content/uploads/2018/10/icon_x.png)。","source":"_posts/IT/Mac/Mac使用标签.md","raw":"---\ntitle: Mac使用标签\ndate: 2019-07-22 18:58:50\nurlname: mac-using-tags\ntoc: true\ntags: [Mac]\ncategories: [IT, Mac]\nnotshow: true\n\n---\n## 使用标签\n在 Mac 上,执行以下任一项操作:\n\n- 给打开的文件添加标签:将鼠标指针悬停在文稿标题右侧,点按箭头,在“标签”栏中点按,然后输入新标签,或者从列表中选取一个标签。\n- 存储新文件时添加标签:点按“文件”>“存储”。在“存储”对话框中,在“标签”栏中点按,然后输入新标签,或者从列表中选取一个标签。\n- 给桌面上或“访达”中的文件添加标签:选择项目,然后打开“文件”菜单。也可以按住 Control 键点按该项目,或用双指轻点它。在“标签”下方选取颜色![img](https://www.macdaxue.com/wp-content/uploads/2018/10/icon_blue_circle.png),或点按“标签”以从更多标签中进行选择或输入新标签。在“访达”窗口中,也可以选择该项目,点按“标签”按钮 ![img](https://www.macdaxue.com/wp-content/uploads/2018/10/icon_tag.png),然后输入新标签,或从列表中选取一个标签。\n\n## 查找含有标签的项目\n\n1. 在 Mac 上,点按程序坞中的“访达”图标 ![img](https://www.macdaxue.com/wp-content/uploads/2018/10/icon_finder.png)以打开“访达”窗口。\n2. 请执行以下一项操作:\n - 搜索标签:在搜索栏中输入标签颜色或名称,然后从建议中选择该标签。\n - 在边栏中选择标签:若要查看带有某个标签的所有项目,请在“访达”边栏中点按标签![img](https://www.macdaxue.com/wp-content/uploads/2018/10/icon_blue_circle.png)。若要更改在边栏中看到的项目,请选取“访达”>“偏好设置”,点按“标签”,然后选择想要查看的标签。\n - 按标签将项目分组: 点按“分组”按钮![img](https://www.macdaxue.com/wp-content/uploads/2018/10/icon_group.png),然后选取“标签”。\n - 按标签排序项目:在任何显示方式下,选取“显示”>“查看显示选项”,点按“排序方式”弹出式菜单,然后选取“标签”。在“列表显示”下,选择“标签”复选框以显示分栏,将指针移到“标签”分栏上方,然后点按。再次点按分栏名称来倒序排列。\n\n## 移除标签\n\n在 Mac 上,请执行以下一项操作:\n\n- 从项目中移除标签:按住 Control 键点按项目或使用双指轻点项目,然后点按“标签”。选择您想要移除的标签,然后按下 Delete 键。\n- 从 Mac 中移除标签:在“访达”中,选取“访达”>“偏好设置”,然后点按“标签”。选择您想要移除的标签,然后点按移除按钮——。\n\n## 编辑标签\n\n1. 在 Mac 上的“访达”![img](https://www.macdaxue.com/wp-content/uploads/2018/10/icon_finder.png)中,选取“访达”>“偏好设置”,然后点按“标签”。\n2. 请执行以下一项操作:\n - 在“访达”边栏中查看标签:选择标签右侧的蓝色复选框。\n - 更改标签颜色:点按标签![img](https://www.macdaxue.com/wp-content/uploads/2018/10/icon_blue_circle.png)\n - 旁边的颜色,然后选取新的颜色。\n - 更改标签名称:点按标签,点按标签名称,然后输入新名称。\n - 创建新标签:点按添加按钮 ![img](https://www.macdaxue.com/wp-content/uploads/2018/06/IL_AddiOS.png)。\n - 删除标签:选择标签,然后点按移除按钮 ——。\n - 将标签添加到[快捷键](https://www.macdaxue.com/os-x-key/)菜单中:在列表中选择标签,然后将它拖到您想要在窗口底部的个人收藏部分中替换的标签上方。当您按下 Control 键点按文件时,在出现的[快捷键](https://www.macdaxue.com/os-x-key/)菜单中可至多有七个标签。\n - 从快捷键菜单中移除标签:将标签拖出“个人收藏标签”部分,直到看到移除符号![img](https://www.macdaxue.com/wp-content/uploads/2018/10/icon_x.png)。","slug":"IT/Mac/Mac使用标签","published":1,"updated":"2019-07-31T03:51:34.000Z","_id":"cka1y597t00164huuyti606sh","comments":1,"layout":"post","photos":[],"link":"","content":"

使用标签

\n

在 Mac 上,执行以下任一项操作:

\n
    \n
  • 给打开的文件添加标签:将鼠标指针悬停在文稿标题右侧,点按箭头,在“标签”栏中点按,然后输入新标签,或者从列表中选取一个标签。
  • \n
  • 存储新文件时添加标签:点按“文件”>“存储”。在“存储”对话框中,在“标签”栏中点按,然后输入新标签,或者从列表中选取一个标签。
  • \n
  • 给桌面上或“访达”中的文件添加标签:选择项目,然后打开“文件”菜单。也可以按住 Control 键点按该项目,或用双指轻点它。在“标签”下方选取颜色\"img\",或点按“标签”以从更多标签中进行选择或输入新标签。在“访达”窗口中,也可以选择该项目,点按“标签”按钮 \"img\",然后输入新标签,或从列表中选取一个标签。
  • \n
\n

查找含有标签的项目

\n
    \n
  1. 在 Mac 上,点按程序坞中的“访达”图标 \"img\"以打开“访达”窗口。
  2. \n
  3. 请执行以下一项操作:\n
      \n
    • 搜索标签:在搜索栏中输入标签颜色或名称,然后从建议中选择该标签。
    • \n
    • 在边栏中选择标签:若要查看带有某个标签的所有项目,请在“访达”边栏中点按标签\"img\"。若要更改在边栏中看到的项目,请选取“访达”>“偏好设置”,点按“标签”,然后选择想要查看的标签。
    • \n
    • 按标签将项目分组: 点按“分组”按钮\"img\",然后选取“标签”。
    • \n
    • 按标签排序项目:在任何显示方式下,选取“显示”>“查看显示选项”,点按“排序方式”弹出式菜单,然后选取“标签”。在“列表显示”下,选择“标签”复选框以显示分栏,将指针移到“标签”分栏上方,然后点按。再次点按分栏名称来倒序排列。
    • \n
    \n
  4. \n
\n

移除标签

\n

在 Mac 上,请执行以下一项操作:

\n
    \n
  • 从项目中移除标签:按住 Control 键点按项目或使用双指轻点项目,然后点按“标签”。选择您想要移除的标签,然后按下 Delete 键。
  • \n
  • 从 Mac 中移除标签:在“访达”中,选取“访达”>“偏好设置”,然后点按“标签”。选择您想要移除的标签,然后点按移除按钮——。
  • \n
\n

编辑标签

\n
    \n
  1. 在 Mac 上的“访达”\"img\"中,选取“访达”>“偏好设置”,然后点按“标签”。
  2. \n
  3. 请执行以下一项操作:\n
      \n
    • 在“访达”边栏中查看标签:选择标签右侧的蓝色复选框。
    • \n
    • 更改标签颜色:点按标签\"img\"
    • \n
    • 旁边的颜色,然后选取新的颜色。
    • \n
    • 更改标签名称:点按标签,点按标签名称,然后输入新名称。
    • \n
    • 创建新标签:点按添加按钮 \"img\"
    • \n
    • 删除标签:选择标签,然后点按移除按钮 ——。
    • \n
    • 将标签添加到快捷键菜单中:在列表中选择标签,然后将它拖到您想要在窗口底部的个人收藏部分中替换的标签上方。当您按下 Control 键点按文件时,在出现的快捷键菜单中可至多有七个标签。
    • \n
    • 从快捷键菜单中移除标签:将标签拖出“个人收藏标签”部分,直到看到移除符号\"img\"
    • \n
    \n
  4. \n
\n","site":{"data":{}},"excerpt":"","more":"

使用标签

\n

在 Mac 上,执行以下任一项操作:

\n
    \n
  • 给打开的文件添加标签:将鼠标指针悬停在文稿标题右侧,点按箭头,在“标签”栏中点按,然后输入新标签,或者从列表中选取一个标签。
  • \n
  • 存储新文件时添加标签:点按“文件”>“存储”。在“存储”对话框中,在“标签”栏中点按,然后输入新标签,或者从列表中选取一个标签。
  • \n
  • 给桌面上或“访达”中的文件添加标签:选择项目,然后打开“文件”菜单。也可以按住 Control 键点按该项目,或用双指轻点它。在“标签”下方选取颜色\"img\",或点按“标签”以从更多标签中进行选择或输入新标签。在“访达”窗口中,也可以选择该项目,点按“标签”按钮 \"img\",然后输入新标签,或从列表中选取一个标签。
  • \n
\n

查找含有标签的项目

\n
    \n
  1. 在 Mac 上,点按程序坞中的“访达”图标 \"img\"以打开“访达”窗口。
  2. \n
  3. 请执行以下一项操作:\n
      \n
    • 搜索标签:在搜索栏中输入标签颜色或名称,然后从建议中选择该标签。
    • \n
    • 在边栏中选择标签:若要查看带有某个标签的所有项目,请在“访达”边栏中点按标签\"img\"。若要更改在边栏中看到的项目,请选取“访达”>“偏好设置”,点按“标签”,然后选择想要查看的标签。
    • \n
    • 按标签将项目分组: 点按“分组”按钮\"img\",然后选取“标签”。
    • \n
    • 按标签排序项目:在任何显示方式下,选取“显示”>“查看显示选项”,点按“排序方式”弹出式菜单,然后选取“标签”。在“列表显示”下,选择“标签”复选框以显示分栏,将指针移到“标签”分栏上方,然后点按。再次点按分栏名称来倒序排列。
    • \n
    \n
  4. \n
\n

移除标签

\n

在 Mac 上,请执行以下一项操作:

\n
    \n
  • 从项目中移除标签:按住 Control 键点按项目或使用双指轻点项目,然后点按“标签”。选择您想要移除的标签,然后按下 Delete 键。
  • \n
  • 从 Mac 中移除标签:在“访达”中,选取“访达”>“偏好设置”,然后点按“标签”。选择您想要移除的标签,然后点按移除按钮——。
  • \n
\n

编辑标签

\n
    \n
  1. 在 Mac 上的“访达”\"img\"中,选取“访达”>“偏好设置”,然后点按“标签”。
  2. \n
  3. 请执行以下一项操作:\n
      \n
    • 在“访达”边栏中查看标签:选择标签右侧的蓝色复选框。
    • \n
    • 更改标签颜色:点按标签\"img\"
    • \n
    • 旁边的颜色,然后选取新的颜色。
    • \n
    • 更改标签名称:点按标签,点按标签名称,然后输入新名称。
    • \n
    • 创建新标签:点按添加按钮 \"img\"
    • \n
    • 删除标签:选择标签,然后点按移除按钮 ——。
    • \n
    • 将标签添加到快捷键菜单中:在列表中选择标签,然后将它拖到您想要在窗口底部的个人收藏部分中替换的标签上方。当您按下 Control 键点按文件时,在出现的快捷键菜单中可至多有七个标签。
    • \n
    • 从快捷键菜单中移除标签:将标签拖出“个人收藏标签”部分,直到看到移除符号\"img\"
    • \n
    \n
  4. \n
\n"},{"title":"Gitbook攻略","date":"2019-08-14T21:02:14.000Z","urlname":"gitbook_with_typora_gh-pages","toc":true,"_content":"\n本文为你介绍如何使用利用 **Typora + gitbook-cli + Github Pages** 书写Gitbook. 在本地用 Typora 书写 md 文件, 用 gitbook-cli 编译, 最后发布到 Github Pages 上.\n\n\n\n\n\n# 安装\n\n前提是已经安装了Node, 直接用npm包管理工具安装:\n\n```sh\nsudo npm install -g gitbook-cli\ngitbook -V # 注意是大写V\n```\n\n> CLI version: 2.3.2\n> GitBook version: 3.2.3\n\n# 新建书籍\n\n1. 为新书建立一个根目录 `mkdir pytho_finance`\n\n2. 在该目录下执行(命令行下):`gitbook init`,之后会在该目录下产生2个文件,分别是README.md(书籍的介绍)和SUMMARY.md(书籍的目录结构)。\n\n![gitbook目录的写法](https://github.com/maiernte/img/raw/master/Tech/gitbook目录的写法.png)\n\n3. 按照上图格式填写目录和文件, 然后再次执行 `gitbook init` , GitBook 会查找 SUMMARY.md 文件中描述的目录和文件,如果没有则会将其创建. \n\n4. 然后就可以预览书籍了 `gitbook serve`. 执行命令后会对 Markdown 格式的文档进行转换,默认转换为 html 格式,提示Serving book on http://localhost:4000,打开网址即可查看.\n5. 构建书籍\n\n```sh\ngitbook build\n```\n\n默认将生成的静态网站输出到 _book 目录。实际上,这一步也包含在 gitbook serve 里面,因为它们是 HTML,所以 GitBook 通过 Node.js 给你提供服务了。\n\nbuild 命令可以指定路径, 或者指定端口, 或者生产 pdf , epub, mobi 等格式. [具体参考文章](https://www.cnblogs.com/eveblog/p/10003217.html). \n\n# 发布到Github Pages\n\n```sh\ngit init\ngit remote add origin https://github.com/maiernte/gitbook_python_finance.git\ngit add .\ngit commit -m \"new book\"\ngit push -u origin master # 将源代码推送到master\n```\n\n在GitHub的仓库中新添一个 **gh-pages** 的Branch. \n\n```sh\nmkdir new_fold\ncd new_fold\nrm -rf . # 删除这个目录下所有文件, 注意那 .git 文件夹不能删除\n\n# 在源代码目录中,也就是md文件的目录\ngitbook build \n\n# 将会产生一个 _book 目录\n# 添加忽略, 以免下次推送的时候 _book 目录被推送.\necho \"*~\" > .gitignore\necho \"_book\" >> .gitignore\necho \"/node_modules\" >> .gitignore\n\ncp -r _book/* path_to/new_fold\n```\n\n:pen: 忽略文件夹,windows下的测试是 `/node_modules`, 不加双引号。\n\n进入新目录, 推送编译后的html 和 js 文件到 gh-pages 的分支中去.\n\n```sh\ncd path_to/new_fold\ngit add .\ngit commit -m \"to gh-pages\"\ngit push -u origin gh-pages\n```\n\n如此实现了将源代码保存到master, 将静态网站推送到gh-pages, 一个仓库搞定! 在浏览器输入仓库地址, 就可以看到自己的Gitbook. 比如我新书地址\n\n> https://maiernte.github.io/gitbook_python_finance/\n\n\n\n## 更新和维护\n\n因为master 和 gh-pages 上存放的是不同的文档,所以拉取的时候也有指定 branch\n\n```sh\n# 拉取源代码\ngit clone https://github.com/maiernte/gitbook_python_finance.git --branch master new_fold\n\n# 拉取静态网站\ngit clone https://github.com/maiernte/gitbook_python_finance.git --branch gh-pages new_fold\n```\n\n\n\n# 个性化配置\n\n在项目的根目录上添加一个 `book.json` 文件, 用来更全面的配置项目. 比如头文件, 插件等等.\n\n```json\n{\n \"title\": \"使用Python处理金融数据\",\n \"author\": \"鎏金天涯 \",\n \"description\": \"使用Python处理金融数据的各种技术\",\n \"generator\": \"site\",\n \"plugins\": [\"mathjax\"],\n \"links\": {\n \"sidebar\": {\n \"鎏金天涯个人博客\": \"http://goldentianya.pub\"\n }\n }\n}\n```\n\n## 数学插件\n\n在上述文件添加了 `\"plugins\": [\"mathjax\"]`, 并执行命令\n\n```sh\ngitbook install ./ # 会添加一堆 node_modules 包\n```\n\n更详细的配置请参阅[官方文档](https://chrisniael.gitbooks.io/gitbook-documentation/content/).\n\n## 目录插件\n\n[项目地址和文档](https://www.npmjs.com/package/gitbook-plugin-page-toc)\n\n将 ***book.json*** 文件修改为 `\"plugins\": [\"mathjax\", \"page-toc\" ], ​` 每一页的目录就会出现在右上角。\n\n\n\n# 编译错误列表\n\n版本\n\n```\nCLI version: 2.3.2\nGitBook version: 3.2.3\n```\n\n## sharing 插件出错\n\n添加了 `page-toc` 插件后,`gitbook serve` 的时候总是出现错误。就算把文章改回原来的样子也无补于事。\n\n> info: 7 plugins are installed\n> info: loading plugin \"livereload\"... OK\n> info: loading plugin \"highlight\"... OK\n> info: loading plugin \"search\"... OK\n> info: loading plugin \"lunr\"... OK\n> info: loading plugin \"sharing\"... OK\n> info: loading plugin \"fontsettings\"... OK\n> info: loading plugin \"theme-default\"... OK\n> info: found 1 pages\n> info: found 0 asset files\n>\n> Error: ENOENT: no such file or directory, stat 'D:\\f040371\\git_book\\plattform_finance\\_book\\gitbook\\gitbook-plugin-sharing\\buttons.js'\n\n### 解决方法\n\n修改 `C:\\Users\\f040371\\.gitbook\\versions\\3.2.3\\lib\\output\\website\\copyPluginAssets.js` 文件中的 112 行\n\n![copyPluginAssets.js](https://images2018.cnblogs.com/blog/623717/201808/623717-20180815170921683-2030924288.png)\n\n将 `confirm: true` 改为 `confirm: false`\n\n\n\n参考文章:\n\n---\n\n[使用GitBook和Typora写知识库](https://beihaionline.com/11523.html)\n\n[gitbook+git+typora 的使用过程](https://www.cnblogs.com/eveblog/p/10003217.html)\n\n[GitBook + Typora + Git 编写电子文档](https://www.jianshu.com/p/02caaaaa97ef)\n\n[Gitbook 发布到 Github Pages](http://www.chengweiyang.cn/gitbook/github-pages/README.html)\n\n","source":"_posts/IT/Tools/Gitbook攻略.md","raw":"---\ntitle: Gitbook攻略\ndate: 2019-08-14 23:02:14\nurlname: gitbook_with_typora_gh-pages\ntoc: true\ntags: [工具]\ncategories: [IT, Tools]\n\n---\n\n本文为你介绍如何使用利用 **Typora + gitbook-cli + Github Pages** 书写Gitbook. 在本地用 Typora 书写 md 文件, 用 gitbook-cli 编译, 最后发布到 Github Pages 上.\n\n\n\n\n\n# 安装\n\n前提是已经安装了Node, 直接用npm包管理工具安装:\n\n```sh\nsudo npm install -g gitbook-cli\ngitbook -V # 注意是大写V\n```\n\n> CLI version: 2.3.2\n> GitBook version: 3.2.3\n\n# 新建书籍\n\n1. 为新书建立一个根目录 `mkdir pytho_finance`\n\n2. 在该目录下执行(命令行下):`gitbook init`,之后会在该目录下产生2个文件,分别是README.md(书籍的介绍)和SUMMARY.md(书籍的目录结构)。\n\n![gitbook目录的写法](https://github.com/maiernte/img/raw/master/Tech/gitbook目录的写法.png)\n\n3. 按照上图格式填写目录和文件, 然后再次执行 `gitbook init` , GitBook 会查找 SUMMARY.md 文件中描述的目录和文件,如果没有则会将其创建. \n\n4. 然后就可以预览书籍了 `gitbook serve`. 执行命令后会对 Markdown 格式的文档进行转换,默认转换为 html 格式,提示Serving book on http://localhost:4000,打开网址即可查看.\n5. 构建书籍\n\n```sh\ngitbook build\n```\n\n默认将生成的静态网站输出到 _book 目录。实际上,这一步也包含在 gitbook serve 里面,因为它们是 HTML,所以 GitBook 通过 Node.js 给你提供服务了。\n\nbuild 命令可以指定路径, 或者指定端口, 或者生产 pdf , epub, mobi 等格式. [具体参考文章](https://www.cnblogs.com/eveblog/p/10003217.html). \n\n# 发布到Github Pages\n\n```sh\ngit init\ngit remote add origin https://github.com/maiernte/gitbook_python_finance.git\ngit add .\ngit commit -m \"new book\"\ngit push -u origin master # 将源代码推送到master\n```\n\n在GitHub的仓库中新添一个 **gh-pages** 的Branch. \n\n```sh\nmkdir new_fold\ncd new_fold\nrm -rf . # 删除这个目录下所有文件, 注意那 .git 文件夹不能删除\n\n# 在源代码目录中,也就是md文件的目录\ngitbook build \n\n# 将会产生一个 _book 目录\n# 添加忽略, 以免下次推送的时候 _book 目录被推送.\necho \"*~\" > .gitignore\necho \"_book\" >> .gitignore\necho \"/node_modules\" >> .gitignore\n\ncp -r _book/* path_to/new_fold\n```\n\n:pen: 忽略文件夹,windows下的测试是 `/node_modules`, 不加双引号。\n\n进入新目录, 推送编译后的html 和 js 文件到 gh-pages 的分支中去.\n\n```sh\ncd path_to/new_fold\ngit add .\ngit commit -m \"to gh-pages\"\ngit push -u origin gh-pages\n```\n\n如此实现了将源代码保存到master, 将静态网站推送到gh-pages, 一个仓库搞定! 在浏览器输入仓库地址, 就可以看到自己的Gitbook. 比如我新书地址\n\n> https://maiernte.github.io/gitbook_python_finance/\n\n\n\n## 更新和维护\n\n因为master 和 gh-pages 上存放的是不同的文档,所以拉取的时候也有指定 branch\n\n```sh\n# 拉取源代码\ngit clone https://github.com/maiernte/gitbook_python_finance.git --branch master new_fold\n\n# 拉取静态网站\ngit clone https://github.com/maiernte/gitbook_python_finance.git --branch gh-pages new_fold\n```\n\n\n\n# 个性化配置\n\n在项目的根目录上添加一个 `book.json` 文件, 用来更全面的配置项目. 比如头文件, 插件等等.\n\n```json\n{\n \"title\": \"使用Python处理金融数据\",\n \"author\": \"鎏金天涯 \",\n \"description\": \"使用Python处理金融数据的各种技术\",\n \"generator\": \"site\",\n \"plugins\": [\"mathjax\"],\n \"links\": {\n \"sidebar\": {\n \"鎏金天涯个人博客\": \"http://goldentianya.pub\"\n }\n }\n}\n```\n\n## 数学插件\n\n在上述文件添加了 `\"plugins\": [\"mathjax\"]`, 并执行命令\n\n```sh\ngitbook install ./ # 会添加一堆 node_modules 包\n```\n\n更详细的配置请参阅[官方文档](https://chrisniael.gitbooks.io/gitbook-documentation/content/).\n\n## 目录插件\n\n[项目地址和文档](https://www.npmjs.com/package/gitbook-plugin-page-toc)\n\n将 ***book.json*** 文件修改为 `\"plugins\": [\"mathjax\", \"page-toc\" ], ​` 每一页的目录就会出现在右上角。\n\n\n\n# 编译错误列表\n\n版本\n\n```\nCLI version: 2.3.2\nGitBook version: 3.2.3\n```\n\n## sharing 插件出错\n\n添加了 `page-toc` 插件后,`gitbook serve` 的时候总是出现错误。就算把文章改回原来的样子也无补于事。\n\n> info: 7 plugins are installed\n> info: loading plugin \"livereload\"... OK\n> info: loading plugin \"highlight\"... OK\n> info: loading plugin \"search\"... OK\n> info: loading plugin \"lunr\"... OK\n> info: loading plugin \"sharing\"... OK\n> info: loading plugin \"fontsettings\"... OK\n> info: loading plugin \"theme-default\"... OK\n> info: found 1 pages\n> info: found 0 asset files\n>\n> Error: ENOENT: no such file or directory, stat 'D:\\f040371\\git_book\\plattform_finance\\_book\\gitbook\\gitbook-plugin-sharing\\buttons.js'\n\n### 解决方法\n\n修改 `C:\\Users\\f040371\\.gitbook\\versions\\3.2.3\\lib\\output\\website\\copyPluginAssets.js` 文件中的 112 行\n\n![copyPluginAssets.js](https://images2018.cnblogs.com/blog/623717/201808/623717-20180815170921683-2030924288.png)\n\n将 `confirm: true` 改为 `confirm: false`\n\n\n\n参考文章:\n\n---\n\n[使用GitBook和Typora写知识库](https://beihaionline.com/11523.html)\n\n[gitbook+git+typora 的使用过程](https://www.cnblogs.com/eveblog/p/10003217.html)\n\n[GitBook + Typora + Git 编写电子文档](https://www.jianshu.com/p/02caaaaa97ef)\n\n[Gitbook 发布到 Github Pages](http://www.chengweiyang.cn/gitbook/github-pages/README.html)\n\n","slug":"IT/Tools/Gitbook攻略","published":1,"updated":"2019-08-15T09:46:18.000Z","_id":"cka1y597u001a4huuspnhsflr","comments":1,"layout":"post","photos":[],"link":"","content":"

本文为你介绍如何使用利用 Typora + gitbook-cli + Github Pages 书写Gitbook. 在本地用 Typora 书写 md 文件, 用 gitbook-cli 编译, 最后发布到 Github Pages 上.

\n\n

安装

\n

前提是已经安装了Node, 直接用npm包管理工具安装:

\n
1
2
sudo npm install -g gitbook-cli
gitbook -V # 注意是大写V
\n
\n

CLI version: 2.3.2
\nGitBook version: 3.2.3

\n
\n

新建书籍

\n
    \n
  1. \n

    为新书建立一个根目录 mkdir pytho_finance

    \n
  2. \n
  3. \n

    在该目录下执行(命令行下):gitbook init,之后会在该目录下产生2个文件,分别是README.md(书籍的介绍)和SUMMARY.md(书籍的目录结构)。

    \n
  4. \n
\n

\"gitbook目录的写法\"

\n
    \n
  1. \n

    按照上图格式填写目录和文件, 然后再次执行 gitbook init , GitBook 会查找 SUMMARY.md 文件中描述的目录和文件,如果没有则会将其创建.

    \n
  2. \n
  3. \n

    然后就可以预览书籍了 gitbook serve. 执行命令后会对 Markdown 格式的文档进行转换,默认转换为 html 格式,提示Serving book on http://localhost:4000,打开网址即可查看.

    \n
  4. \n
  5. \n

    构建书籍

    \n
  6. \n
\n
1
gitbook build
\n

默认将生成的静态网站输出到 _book 目录。实际上,这一步也包含在 gitbook serve 里面,因为它们是 HTML,所以 GitBook 通过 Node.js 给你提供服务了。

\n

build 命令可以指定路径, 或者指定端口, 或者生产 pdf , epub, mobi 等格式. 具体参考文章.

\n

发布到Github Pages

\n
1
2
3
4
5
git init
git remote add origin https://github.com/maiernte/gitbook_python_finance.git
git add .
git commit -m \"new book\"
git push -u origin master # 将源代码推送到master
\n

在GitHub的仓库中新添一个 gh-pages 的Branch.

\n
1
2
3
4
5
6
7
8
9
10
11
12
13
14
mkdir new_fold
cd new_fold
rm -rf . # 删除这个目录下所有文件, 注意那 .git 文件夹不能删除

# 在源代码目录中,也就是md文件的目录
gitbook build

# 将会产生一个 _book 目录
# 添加忽略, 以免下次推送的时候 _book 目录被推送.
echo \"*~\" > .gitignore
echo \"_book\" >> .gitignore
echo \"/node_modules\" >> .gitignore

cp -r _book/* path_to/new_fold
\n

:pen: 忽略文件夹,windows下的测试是 /node_modules, 不加双引号。

\n

进入新目录, 推送编译后的html 和 js 文件到 gh-pages 的分支中去.

\n
1
2
3
4
cd path_to/new_fold
git add .
git commit -m \"to gh-pages\"
git push -u origin gh-pages
\n

如此实现了将源代码保存到master, 将静态网站推送到gh-pages, 一个仓库搞定! 在浏览器输入仓库地址, 就可以看到自己的Gitbook. 比如我新书地址

\n
\n

https://maiernte.github.io/gitbook_python_finance/

\n
\n

更新和维护

\n

因为master 和 gh-pages 上存放的是不同的文档,所以拉取的时候也有指定 branch

\n
1
2
3
4
5
# 拉取源代码
git clone https://github.com/maiernte/gitbook_python_finance.git --branch master new_fold

# 拉取静态网站
git clone https://github.com/maiernte/gitbook_python_finance.git --branch gh-pages new_fold
\n

个性化配置

\n

在项目的根目录上添加一个 book.json 文件, 用来更全面的配置项目. 比如头文件, 插件等等.

\n
1
2
3
4
5
6
7
8
9
10
11
12
{
\"title\": \"使用Python处理金融数据\",
\"author\": \"鎏金天涯 <mai.yongfeng@gmail.com>\",
\"description\": \"使用Python处理金融数据的各种技术\",
\"generator\": \"site\",
\"plugins\": [\"mathjax\"],
\"links\": {
\"sidebar\": {
\"鎏金天涯个人博客\": \"http://goldentianya.pub\"
}
}
}
\n

数学插件

\n

在上述文件添加了 "plugins": ["mathjax"], 并执行命令

\n
1
gitbook install ./ # 会添加一堆 node_modules 包
\n

更详细的配置请参阅官方文档.

\n

目录插件

\n

项目地址和文档

\n

book.json 文件修改为 "plugins": ["mathjax", "page-toc" ], ​ 每一页的目录就会出现在右上角。

\n

编译错误列表

\n

版本

\n
1
2
CLI version: 2.3.2
GitBook version: 3.2.3
\n

sharing 插件出错

\n

添加了 page-toc 插件后,gitbook serve 的时候总是出现错误。就算把文章改回原来的样子也无补于事。

\n
\n

info: 7 plugins are installed
\ninfo: loading plugin “livereload”… OK
\ninfo: loading plugin “highlight”… OK
\ninfo: loading plugin “search”… OK
\ninfo: loading plugin “lunr”… OK
\ninfo: loading plugin “sharing”… OK
\ninfo: loading plugin “fontsettings”… OK
\ninfo: loading plugin “theme-default”… OK
\ninfo: found 1 pages
\ninfo: found 0 asset files

\n

Error: ENOENT: no such file or directory, stat ‘D:\\f040371\\git_book\\plattform_finance_book\\gitbook\\gitbook-plugin-sharing\\buttons.js’

\n
\n

解决方法

\n

修改 C:\\Users\\f040371\\.gitbook\\versions\\3.2.3\\lib\\output\\website\\copyPluginAssets.js 文件中的 112 行

\n

\"copyPluginAssets.js\"

\n

confirm: true 改为 confirm: false

\n

参考文章:

\n
\n

使用GitBook和Typora写知识库

\n

gitbook+git+typora 的使用过程

\n

GitBook + Typora + Git 编写电子文档

\n

Gitbook 发布到 Github Pages

\n","site":{"data":{}},"excerpt":"

本文为你介绍如何使用利用 Typora + gitbook-cli + Github Pages 书写Gitbook. 在本地用 Typora 书写 md 文件, 用 gitbook-cli 编译, 最后发布到 Github Pages 上.

","more":"

安装

\n

前提是已经安装了Node, 直接用npm包管理工具安装:

\n\n
\n

CLI version: 2.3.2
\nGitBook version: 3.2.3

\n
\n

新建书籍

\n
    \n
  1. \n

    为新书建立一个根目录 mkdir pytho_finance

    \n
  2. \n
  3. \n

    在该目录下执行(命令行下):gitbook init,之后会在该目录下产生2个文件,分别是README.md(书籍的介绍)和SUMMARY.md(书籍的目录结构)。

    \n
  4. \n
\n

\"gitbook目录的写法\"

\n
    \n
  1. \n

    按照上图格式填写目录和文件, 然后再次执行 gitbook init , GitBook 会查找 SUMMARY.md 文件中描述的目录和文件,如果没有则会将其创建.

    \n
  2. \n
  3. \n

    然后就可以预览书籍了 gitbook serve. 执行命令后会对 Markdown 格式的文档进行转换,默认转换为 html 格式,提示Serving book on http://localhost:4000,打开网址即可查看.

    \n
  4. \n
  5. \n

    构建书籍

    \n
  6. \n
\n\n

默认将生成的静态网站输出到 _book 目录。实际上,这一步也包含在 gitbook serve 里面,因为它们是 HTML,所以 GitBook 通过 Node.js 给你提供服务了。

\n

build 命令可以指定路径, 或者指定端口, 或者生产 pdf , epub, mobi 等格式. 具体参考文章.

\n

发布到Github Pages

\n\n

在GitHub的仓库中新添一个 gh-pages 的Branch.

\n\n

:pen: 忽略文件夹,windows下的测试是 /node_modules, 不加双引号。

\n

进入新目录, 推送编译后的html 和 js 文件到 gh-pages 的分支中去.

\n\n

如此实现了将源代码保存到master, 将静态网站推送到gh-pages, 一个仓库搞定! 在浏览器输入仓库地址, 就可以看到自己的Gitbook. 比如我新书地址

\n
\n

https://maiernte.github.io/gitbook_python_finance/

\n
\n

更新和维护

\n

因为master 和 gh-pages 上存放的是不同的文档,所以拉取的时候也有指定 branch

\n\n

个性化配置

\n

在项目的根目录上添加一个 book.json 文件, 用来更全面的配置项目. 比如头文件, 插件等等.

\n\n

数学插件

\n

在上述文件添加了 "plugins": ["mathjax"], 并执行命令

\n\n

更详细的配置请参阅官方文档.

\n

目录插件

\n

项目地址和文档

\n

book.json 文件修改为 "plugins": ["mathjax", "page-toc" ], ​ 每一页的目录就会出现在右上角。

\n

编译错误列表

\n

版本

\n\n

sharing 插件出错

\n

添加了 page-toc 插件后,gitbook serve 的时候总是出现错误。就算把文章改回原来的样子也无补于事。

\n
\n

info: 7 plugins are installed
\ninfo: loading plugin “livereload”… OK
\ninfo: loading plugin “highlight”… OK
\ninfo: loading plugin “search”… OK
\ninfo: loading plugin “lunr”… OK
\ninfo: loading plugin “sharing”… OK
\ninfo: loading plugin “fontsettings”… OK
\ninfo: loading plugin “theme-default”… OK
\ninfo: found 1 pages
\ninfo: found 0 asset files

\n

Error: ENOENT: no such file or directory, stat ‘D:\\f040371\\git_book\\plattform_finance_book\\gitbook\\gitbook-plugin-sharing\\buttons.js’

\n
\n

解决方法

\n

修改 C:\\Users\\f040371\\.gitbook\\versions\\3.2.3\\lib\\output\\website\\copyPluginAssets.js 文件中的 112 行

\n

\"copyPluginAssets.js\"

\n

confirm: true 改为 confirm: false

\n

参考文章:

\n
\n

使用GitBook和Typora写知识库

\n

gitbook+git+typora 的使用过程

\n

GitBook + Typora + Git 编写电子文档

\n

Gitbook 发布到 Github Pages

"},{"title":"Mac备忘录","date":"2019-07-22T16:47:47.000Z","urlname":"mac-memo","toc":true,"notshow":true,"_content":"\n# 指令和任务\n\n## 隐藏文件夹\n\nTerminal 命令\n\n```bash\n//显示隐藏文件\ndefaults write com.apple.finder AppleShowAllFiles -bool true\n//不显示隐藏文件\ndefaults write com.apple.finder AppleShowAllFiles -bool false\n```\n\n快速命令,打开访达窗口,然后 ⌘ + ⇧ + . 就可以隐藏/显示。\n\n\n\n需要重启Finder使设置生效 :\n\n> 重启Finder:窗口左上角的苹果标志-->强制退出-->Finder-->重新启动\n\n## 允许任何来源软件\n\n系统默认在 **安全与隐私** 里只显示 “App Store” 和 “App Store 和被认可的开发者”,没有 “任何来源”。开启的话需要在终端输入\n\n`sudo spctl --master-disable` \n\n并输入开机密码。\n\n\n\n## 任务控制\n\n- 将任务放在后台运行:`command + &` \n\n- 将任务丢到后台暂停:`ctrl-z` \n\n- 查看后台所有任务状态:`jobs -l` (会列出 1、2、3序列号)\n\n- 将后台的任务拿到前台处理:`fg %jobnumber` (指序列号,而不是任务id)\n\n- 将后台的任务变成运行中:`bg %jobnumber` \n\n- 管理后台当中的任务:`kill -signal %jobnumber`\n\n# 文件管理\n\n## 标签的使用\n\n参看 [mac 标签的使用](mac-using-tags.html)\n\n# 通用技巧\n\n## 输入法\n\n### 查看按键字符\n\n1. 偏好设置 → 键盘 → 输入法,窗口右面会显示键盘⌨️图案,按住shift⇧键或者option⌥,会显示在不同功能键下面的字符。\n\n\n\n## 通过Automator添加快捷键\n\n[文章来源](https://zhidao.baidu.com/question/1514898183998822540.html)\n\n1. 一次打开 ***Finder —> 应用程序 —> automator***\n2. 选取 ***服务***\n3. 从左边的双栏选取 ***使用工具—>运行AppleScript***, 并双击运行。\n4. 出现文本框后选定(右栏最上边)***没有输入***\n\n```objective-c\non run {input, parameters}\n (* Your script goes here *)\n tell application \"Safari\"\n reopen\n activate\n end tell\nend run\n```\n\n5. ⌘+S 保存,命名为 *Open Safari*。关闭automator\n6. 转到 ***系统偏好设置—>键盘—>快捷键—>服务—>通用—>open safari*** ,然后设定快捷键就好了。\n\n\n\n## 电源管理\n\n`pmset`是**macOS**下用来操作、电源管理的工具,可设定休眠模式、时间和唤醒时间或显示电源信息,不过因为它是一个命令列的指令,因此得透过终端机察看或修改设定。当你开启「终端机」输入p`mset -g` 会看到具体设置。\n\n- `Standbydelay 28800` :将系统储存于內存中休眠,会消耗一些电力。\n- `Autopowerofdelay 28800` : 把系统写入SSD硬盘中,将內存暂存关闭,依照这篇文章的说法,两者延迟时间28800秒(约八小时)会让电脑多维持內存八小时左右的电力。\n- `tcpkeepalive` :设定睡眠后是否还保持网络连接, 以便可以透过TCP唤醒系统\n- `hibernatemode` :睡眠模式。数字越小,耗电越高。可以设置为 25\n\n```sh\nsudo pmset -b autopoweroffdelay 300 # 将睡眠时间缩短为300秒(五分钟)\nsudo pmset -b standbydelay 300 # 然后将系统储存到SSD硬盘\nsudo pmset -b tcpkeepalive 0 # 将透过TCP唤醒系统的功能关闭\nsudo pmset -a hibernatemode 25 \n```\n\n> 中间的参数-b是使用电池下的参数,-c为外接电源下的参数设定, -a 为所有情况下的设定。\n\n\n\n## 升级到Mojave后鼠标发飘\n\n前往***偏好设置-->网络-->设定服务顺序(左下角齿轮)***,然后将***蓝牙PAN***拖到最上面。\n\n\n\n# 网络资源\n\n## 应用软件\n\n1. 大量破解资源分享的网站 [MacEnjoy](https://www.macenjoy.co/)\n\n## 在线文档\n\n[iMac 2012 规格](https://support.apple.com/kb/SP665?locale=zh_CN&viewlocale=zh_CN)\n\n### 升级SSD固态硬盘\n\n[iMac 2012 21.5吋 拆卸指南](https://zh.ifixit.com/Teardown/iMac+Intel+21.5-Inch+EMC+2544+Teardown/11936)\n\n[Mac升级外挂SSD硬盘](https://luolei.org/imac-5k-external-usb-ssd-update/)\n\n[如何选择另一个启动磁盘](https://support.apple.com/zh-cn/HT202796) :pen: 官方说明\n\n[更换SSD固态硬盘攻略](http://www.mac52ipod.cn/post/apple-mac-macbook-pro-change-ssd-hardisk-tutorial.php)\n\n1. 固态硬盘通过USB 3连接到电脑,并格式化成 **Mac OS 扩展** 格式。\n\n ![](http://www.mac52ipod.cn/attachment.php?fid=5823)\n\n2. 用 Carbon Copy Cloner([官网下载](https://bombich.com/))把原硬盘的数据镜像到 SSD。完成后要制作恢复分区「Recovery HD」[破解版下载地址](https://www.macenjoy.co/blog/carbon-copy-cloner-for-mac-v5-1-9)\n\n 或者 [SuperDuper](https://www.shirt-pocket.com/SuperDuper/SuperDuperDescription.html) :pen: 免费版可以全盘备份,而不支持增量操作。\n\n ![](http://www.mac52ipod.cn/attachment.php?fid=5824)\n\n3. 重启,听到 「当 」一声后按住 `Option` 键(windows 键盘上的 Alt)。然后选择SSD作为启动硬盘。\n\n4. 开机后用 **Trim Enabler**([官网下载](http://www.cindori.org/software/trimenabler/))开启 **Trim** 读写加速。:+1:","source":"_posts/IT/Mac/Mac备忘录.md","raw":"---\ntitle: Mac备忘录\ndate: 2019-07-22 18:47:47\nurlname: mac-memo\ntoc: true\ntags: [Mac]\ncategories: [IT, Mac]\nnotshow: true\n\n---\n\n# 指令和任务\n\n## 隐藏文件夹\n\nTerminal 命令\n\n```bash\n//显示隐藏文件\ndefaults write com.apple.finder AppleShowAllFiles -bool true\n//不显示隐藏文件\ndefaults write com.apple.finder AppleShowAllFiles -bool false\n```\n\n快速命令,打开访达窗口,然后 ⌘ + ⇧ + . 就可以隐藏/显示。\n\n\n\n需要重启Finder使设置生效 :\n\n> 重启Finder:窗口左上角的苹果标志-->强制退出-->Finder-->重新启动\n\n## 允许任何来源软件\n\n系统默认在 **安全与隐私** 里只显示 “App Store” 和 “App Store 和被认可的开发者”,没有 “任何来源”。开启的话需要在终端输入\n\n`sudo spctl --master-disable` \n\n并输入开机密码。\n\n\n\n## 任务控制\n\n- 将任务放在后台运行:`command + &` \n\n- 将任务丢到后台暂停:`ctrl-z` \n\n- 查看后台所有任务状态:`jobs -l` (会列出 1、2、3序列号)\n\n- 将后台的任务拿到前台处理:`fg %jobnumber` (指序列号,而不是任务id)\n\n- 将后台的任务变成运行中:`bg %jobnumber` \n\n- 管理后台当中的任务:`kill -signal %jobnumber`\n\n# 文件管理\n\n## 标签的使用\n\n参看 [mac 标签的使用](mac-using-tags.html)\n\n# 通用技巧\n\n## 输入法\n\n### 查看按键字符\n\n1. 偏好设置 → 键盘 → 输入法,窗口右面会显示键盘⌨️图案,按住shift⇧键或者option⌥,会显示在不同功能键下面的字符。\n\n\n\n## 通过Automator添加快捷键\n\n[文章来源](https://zhidao.baidu.com/question/1514898183998822540.html)\n\n1. 一次打开 ***Finder —> 应用程序 —> automator***\n2. 选取 ***服务***\n3. 从左边的双栏选取 ***使用工具—>运行AppleScript***, 并双击运行。\n4. 出现文本框后选定(右栏最上边)***没有输入***\n\n```objective-c\non run {input, parameters}\n (* Your script goes here *)\n tell application \"Safari\"\n reopen\n activate\n end tell\nend run\n```\n\n5. ⌘+S 保存,命名为 *Open Safari*。关闭automator\n6. 转到 ***系统偏好设置—>键盘—>快捷键—>服务—>通用—>open safari*** ,然后设定快捷键就好了。\n\n\n\n## 电源管理\n\n`pmset`是**macOS**下用来操作、电源管理的工具,可设定休眠模式、时间和唤醒时间或显示电源信息,不过因为它是一个命令列的指令,因此得透过终端机察看或修改设定。当你开启「终端机」输入p`mset -g` 会看到具体设置。\n\n- `Standbydelay 28800` :将系统储存于內存中休眠,会消耗一些电力。\n- `Autopowerofdelay 28800` : 把系统写入SSD硬盘中,将內存暂存关闭,依照这篇文章的说法,两者延迟时间28800秒(约八小时)会让电脑多维持內存八小时左右的电力。\n- `tcpkeepalive` :设定睡眠后是否还保持网络连接, 以便可以透过TCP唤醒系统\n- `hibernatemode` :睡眠模式。数字越小,耗电越高。可以设置为 25\n\n```sh\nsudo pmset -b autopoweroffdelay 300 # 将睡眠时间缩短为300秒(五分钟)\nsudo pmset -b standbydelay 300 # 然后将系统储存到SSD硬盘\nsudo pmset -b tcpkeepalive 0 # 将透过TCP唤醒系统的功能关闭\nsudo pmset -a hibernatemode 25 \n```\n\n> 中间的参数-b是使用电池下的参数,-c为外接电源下的参数设定, -a 为所有情况下的设定。\n\n\n\n## 升级到Mojave后鼠标发飘\n\n前往***偏好设置-->网络-->设定服务顺序(左下角齿轮)***,然后将***蓝牙PAN***拖到最上面。\n\n\n\n# 网络资源\n\n## 应用软件\n\n1. 大量破解资源分享的网站 [MacEnjoy](https://www.macenjoy.co/)\n\n## 在线文档\n\n[iMac 2012 规格](https://support.apple.com/kb/SP665?locale=zh_CN&viewlocale=zh_CN)\n\n### 升级SSD固态硬盘\n\n[iMac 2012 21.5吋 拆卸指南](https://zh.ifixit.com/Teardown/iMac+Intel+21.5-Inch+EMC+2544+Teardown/11936)\n\n[Mac升级外挂SSD硬盘](https://luolei.org/imac-5k-external-usb-ssd-update/)\n\n[如何选择另一个启动磁盘](https://support.apple.com/zh-cn/HT202796) :pen: 官方说明\n\n[更换SSD固态硬盘攻略](http://www.mac52ipod.cn/post/apple-mac-macbook-pro-change-ssd-hardisk-tutorial.php)\n\n1. 固态硬盘通过USB 3连接到电脑,并格式化成 **Mac OS 扩展** 格式。\n\n ![](http://www.mac52ipod.cn/attachment.php?fid=5823)\n\n2. 用 Carbon Copy Cloner([官网下载](https://bombich.com/))把原硬盘的数据镜像到 SSD。完成后要制作恢复分区「Recovery HD」[破解版下载地址](https://www.macenjoy.co/blog/carbon-copy-cloner-for-mac-v5-1-9)\n\n 或者 [SuperDuper](https://www.shirt-pocket.com/SuperDuper/SuperDuperDescription.html) :pen: 免费版可以全盘备份,而不支持增量操作。\n\n ![](http://www.mac52ipod.cn/attachment.php?fid=5824)\n\n3. 重启,听到 「当 」一声后按住 `Option` 键(windows 键盘上的 Alt)。然后选择SSD作为启动硬盘。\n\n4. 开机后用 **Trim Enabler**([官网下载](http://www.cindori.org/software/trimenabler/))开启 **Trim** 读写加速。:+1:","slug":"IT/Mac/Mac备忘录","published":1,"updated":"2020-05-07T07:28:37.649Z","_id":"cka1y597w001d4huu070sswhu","comments":1,"layout":"post","photos":[],"link":"","content":"

指令和任务

\n

隐藏文件夹

\n

Terminal 命令

\n
1
2
3
4
//显示隐藏文件
defaults write com.apple.finder AppleShowAllFiles -bool true
//不显示隐藏文件
defaults write com.apple.finder AppleShowAllFiles -bool false
\n

快速命令,打开访达窗口,然后 ⌘ + ⇧ + . 就可以隐藏/显示。

\n

需要重启Finder使设置生效 :

\n
\n

重启Finder:窗口左上角的苹果标志–>强制退出–>Finder–>重新启动

\n
\n

允许任何来源软件

\n

系统默认在 安全与隐私 里只显示 “App Store” 和 “App Store 和被认可的开发者”,没有 “任何来源”。开启的话需要在终端输入

\n

sudo spctl --master-disable

\n

并输入开机密码。

\n

任务控制

\n
    \n
  • \n

    将任务放在后台运行:command + &

    \n
  • \n
  • \n

    将任务丢到后台暂停:ctrl-z

    \n
  • \n
  • \n

    查看后台所有任务状态:jobs -l (会列出 1、2、3序列号)

    \n
  • \n
  • \n

    将后台的任务拿到前台处理:fg %jobnumber (指序列号,而不是任务id)

    \n
  • \n
  • \n

    将后台的任务变成运行中:bg %jobnumber

    \n
  • \n
  • \n

    管理后台当中的任务:kill -signal %jobnumber

    \n
  • \n
\n

文件管理

\n

标签的使用

\n

参看 mac 标签的使用

\n

通用技巧

\n

输入法

\n

查看按键字符

\n
    \n
  1. 偏好设置 → 键盘 → 输入法,窗口右面会显示键盘⌨️图案,按住shift⇧键或者option⌥,会显示在不同功能键下面的字符。
  2. \n
\n

通过Automator添加快捷键

\n

文章来源

\n
    \n
  1. 一次打开 Finder —> 应用程序 —> automator
  2. \n
  3. 选取 服务
  4. \n
  5. 从左边的双栏选取 使用工具—>运行AppleScript, 并双击运行。
  6. \n
  7. 出现文本框后选定(右栏最上边)没有输入
  8. \n
\n
1
2
3
4
5
6
7
on run {input, parameters}
(* Your script goes here *)
tell application "Safari"
reopen
activate
end tell
end run
\n
    \n
  1. ⌘+S 保存,命名为 Open Safari。关闭automator
  2. \n
  3. 转到 系统偏好设置—>键盘—>快捷键—>服务—>通用—>open safari ,然后设定快捷键就好了。
  4. \n
\n

电源管理

\n

pmsetmacOS下用来操作、电源管理的工具,可设定休眠模式、时间和唤醒时间或显示电源信息,不过因为它是一个命令列的指令,因此得透过终端机察看或修改设定。当你开启「终端机」输入pmset -g 会看到具体设置。

\n
    \n
  • Standbydelay 28800 :将系统储存于內存中休眠,会消耗一些电力。
  • \n
  • Autopowerofdelay 28800 : 把系统写入SSD硬盘中,将內存暂存关闭,依照这篇文章的说法,两者延迟时间28800秒(约八小时)会让电脑多维持內存八小时左右的电力。
  • \n
  • tcpkeepalive :设定睡眠后是否还保持网络连接, 以便可以透过TCP唤醒系统
  • \n
  • hibernatemode :睡眠模式。数字越小,耗电越高。可以设置为 25
  • \n
\n
1
2
3
4
sudo pmset -b autopoweroffdelay 300 # 将睡眠时间缩短为300秒(五分钟)
sudo pmset -b standbydelay 300 # 然后将系统储存到SSD硬盘
sudo pmset -b tcpkeepalive 0 # 将透过TCP唤醒系统的功能关闭
sudo pmset -a hibernatemode 25
\n
\n

中间的参数-b是使用电池下的参数,-c为外接电源下的参数设定, -a 为所有情况下的设定。

\n
\n

升级到Mojave后鼠标发飘

\n

前往偏好设置–>网络–>设定服务顺序(左下角齿轮),然后将蓝牙PAN拖到最上面。

\n

网络资源

\n

应用软件

\n
    \n
  1. 大量破解资源分享的网站 MacEnjoy
  2. \n
\n

在线文档

\n

iMac 2012 规格

\n

升级SSD固态硬盘

\n

iMac 2012 21.5吋 拆卸指南

\n

Mac升级外挂SSD硬盘

\n

如何选择另一个启动磁盘 :pen: 官方说明

\n

更换SSD固态硬盘攻略

\n
    \n
  1. \n

    固态硬盘通过USB 3连接到电脑,并格式化成 Mac OS 扩展 格式。

    \n

    \n
  2. \n
  3. \n

    用 Carbon Copy Cloner(官网下载)把原硬盘的数据镜像到 SSD。完成后要制作恢复分区「Recovery HD」破解版下载地址

    \n

    或者 SuperDuper :pen: 免费版可以全盘备份,而不支持增量操作。

    \n

    \n
  4. \n
  5. \n

    重启,听到 「当 」一声后按住 Option 键(windows 键盘上的 Alt)。然后选择SSD作为启动硬盘。

    \n
  6. \n
  7. \n

    开机后用 Trim Enabler官网下载)开启 Trim 读写加速。:+1:

    \n
  8. \n
\n","site":{"data":{}},"excerpt":"","more":"

指令和任务

\n

隐藏文件夹

\n

Terminal 命令

\n\n

快速命令,打开访达窗口,然后 ⌘ + ⇧ + . 就可以隐藏/显示。

\n

需要重启Finder使设置生效 :

\n
\n

重启Finder:窗口左上角的苹果标志–>强制退出–>Finder–>重新启动

\n
\n

允许任何来源软件

\n

系统默认在 安全与隐私 里只显示 “App Store” 和 “App Store 和被认可的开发者”,没有 “任何来源”。开启的话需要在终端输入

\n

sudo spctl --master-disable

\n

并输入开机密码。

\n

任务控制

\n
    \n
  • \n

    将任务放在后台运行:command + &

    \n
  • \n
  • \n

    将任务丢到后台暂停:ctrl-z

    \n
  • \n
  • \n

    查看后台所有任务状态:jobs -l (会列出 1、2、3序列号)

    \n
  • \n
  • \n

    将后台的任务拿到前台处理:fg %jobnumber (指序列号,而不是任务id)

    \n
  • \n
  • \n

    将后台的任务变成运行中:bg %jobnumber

    \n
  • \n
  • \n

    管理后台当中的任务:kill -signal %jobnumber

    \n
  • \n
\n

文件管理

\n

标签的使用

\n

参看 mac 标签的使用

\n

通用技巧

\n

输入法

\n

查看按键字符

\n
    \n
  1. 偏好设置 → 键盘 → 输入法,窗口右面会显示键盘⌨️图案,按住shift⇧键或者option⌥,会显示在不同功能键下面的字符。
  2. \n
\n

通过Automator添加快捷键

\n

文章来源

\n
    \n
  1. 一次打开 Finder —> 应用程序 —> automator
  2. \n
  3. 选取 服务
  4. \n
  5. 从左边的双栏选取 使用工具—>运行AppleScript, 并双击运行。
  6. \n
  7. 出现文本框后选定(右栏最上边)没有输入
  8. \n
\n\n
    \n
  1. ⌘+S 保存,命名为 Open Safari。关闭automator
  2. \n
  3. 转到 系统偏好设置—>键盘—>快捷键—>服务—>通用—>open safari ,然后设定快捷键就好了。
  4. \n
\n

电源管理

\n

pmsetmacOS下用来操作、电源管理的工具,可设定休眠模式、时间和唤醒时间或显示电源信息,不过因为它是一个命令列的指令,因此得透过终端机察看或修改设定。当你开启「终端机」输入pmset -g 会看到具体设置。

\n
    \n
  • Standbydelay 28800 :将系统储存于內存中休眠,会消耗一些电力。
  • \n
  • Autopowerofdelay 28800 : 把系统写入SSD硬盘中,将內存暂存关闭,依照这篇文章的说法,两者延迟时间28800秒(约八小时)会让电脑多维持內存八小时左右的电力。
  • \n
  • tcpkeepalive :设定睡眠后是否还保持网络连接, 以便可以透过TCP唤醒系统
  • \n
  • hibernatemode :睡眠模式。数字越小,耗电越高。可以设置为 25
  • \n
\n\n
\n

中间的参数-b是使用电池下的参数,-c为外接电源下的参数设定, -a 为所有情况下的设定。

\n
\n

升级到Mojave后鼠标发飘

\n

前往偏好设置–>网络–>设定服务顺序(左下角齿轮),然后将蓝牙PAN拖到最上面。

\n

网络资源

\n

应用软件

\n
    \n
  1. 大量破解资源分享的网站 MacEnjoy
  2. \n
\n

在线文档

\n

iMac 2012 规格

\n

升级SSD固态硬盘

\n

iMac 2012 21.5吋 拆卸指南

\n

Mac升级外挂SSD硬盘

\n

如何选择另一个启动磁盘 :pen: 官方说明

\n

更换SSD固态硬盘攻略

\n
    \n
  1. \n

    固态硬盘通过USB 3连接到电脑,并格式化成 Mac OS 扩展 格式。

    \n

    \n
  2. \n
  3. \n

    用 Carbon Copy Cloner(官网下载)把原硬盘的数据镜像到 SSD。完成后要制作恢复分区「Recovery HD」破解版下载地址

    \n

    或者 SuperDuper :pen: 免费版可以全盘备份,而不支持增量操作。

    \n

    \n
  4. \n
  5. \n

    重启,听到 「当 」一声后按住 Option 键(windows 键盘上的 Alt)。然后选择SSD作为启动硬盘。

    \n
  6. \n
  7. \n

    开机后用 Trim Enabler官网下载)开启 Trim 读写加速。:+1:

    \n
  8. \n
\n"},{"title":"Ubuntu重设root用户密码","date":"2019-07-26T15:51:03.000Z","urlname":"ubuntu-reset-root-pw","toc":true,"notshow":true,"_content":"\n# 重设密码\n\n原理上参考这份[中文指引][Chinese]就好。由于我的服务器是IONOS公司的,这里主要记录[IONOS][IONOS]的官方指引。(严格按照步骤)\n\n```sh\n网址 www.ionos.de/hilfe\n# 选择 Server & Cloud Infrastructure\n```\n\n\n\n1. 打开 KVM-Konsole\n2. 在用户管理平台软重启系统 Soft-Restart\n3. 在 KVM-Konsole 这边按 ``ESC`` 键\n4. 当出现类似一下界面,按 ``E`` 键\n\n![](https://github.com/maiernte/img/raw/master/Tech/ubuntu-reset-root-1.png)\n\n5. 然后会来到这个界面。\n6. ![](https://github.com/maiernte/img/raw/master/Tech/ubuntu-reset-root-2.png)\n\n7. 用上下键移动到“linux。。。”开始的那一行,并左右键移动到这行的末尾,空格,输入 `init=/bin/bash`\n\n![](https://github.com/maiernte/img/raw/master/Tech/ubuntu-reset-root-3.png)\n\n8. 按 `F10` 开始重启。等完成,进入命令模式后,输入以下命令。\n\n ```sh\n mount -o remount,rw /\n passwd\n Enter new UNIX password:\n Retype new UNIX password:\n passwd: password updated successfull\n ```\n\n \n\n9. 最后输入命令重启系统!\n\n ```sh\n reboot -f \n ```\n\n# 设置公共SSH\n\n在配置 github 的时候已经生成了 ssh-key ,可以用以下方法。\n\n```sh\ncd ~/.ssh\ncp id_rsa.pub authorized_keys\nssh-copy-id -i ~/.ssh/id_rsa.pub root@217.160.61.19 # 我的用户名和服务器地址,默认端口 22\n# 指定端口号为2212:ssh-copy-id -i ~/.ssh/id_rsa.pub -p 2212 user@ip\n\nssh root@217.160.61.19 # 登录并输入密码,第二次就不再需要密码了。\n\n```\n\n\n\n---\n\n[Chinese]: https://ifmx.cc/linux/398.html \"中文指引\"\n[IONOS]: https://www.ionos.de/hilfe/server-cloud-infrastructure/erste-schritte/root-passwort-zuruecksetzen/root-passwort-zuruecksetzen-ubuntu/ \"IONOS官方指引\"\n\n\n","source":"_posts/IT/Tools/Ubuntu重设root用户密码.md","raw":"---\n\ntitle: Ubuntu重设root用户密码\ndate: 2019-07-26 17:51:03\nurlname: ubuntu-reset-root-pw\ntoc: true\ntags: [工具]\ncategories: [IT, Tools]\nnotshow: true\n\n---\n\n# 重设密码\n\n原理上参考这份[中文指引][Chinese]就好。由于我的服务器是IONOS公司的,这里主要记录[IONOS][IONOS]的官方指引。(严格按照步骤)\n\n```sh\n网址 www.ionos.de/hilfe\n# 选择 Server & Cloud Infrastructure\n```\n\n\n\n1. 打开 KVM-Konsole\n2. 在用户管理平台软重启系统 Soft-Restart\n3. 在 KVM-Konsole 这边按 ``ESC`` 键\n4. 当出现类似一下界面,按 ``E`` 键\n\n![](https://github.com/maiernte/img/raw/master/Tech/ubuntu-reset-root-1.png)\n\n5. 然后会来到这个界面。\n6. ![](https://github.com/maiernte/img/raw/master/Tech/ubuntu-reset-root-2.png)\n\n7. 用上下键移动到“linux。。。”开始的那一行,并左右键移动到这行的末尾,空格,输入 `init=/bin/bash`\n\n![](https://github.com/maiernte/img/raw/master/Tech/ubuntu-reset-root-3.png)\n\n8. 按 `F10` 开始重启。等完成,进入命令模式后,输入以下命令。\n\n ```sh\n mount -o remount,rw /\n passwd\n Enter new UNIX password:\n Retype new UNIX password:\n passwd: password updated successfull\n ```\n\n \n\n9. 最后输入命令重启系统!\n\n ```sh\n reboot -f \n ```\n\n# 设置公共SSH\n\n在配置 github 的时候已经生成了 ssh-key ,可以用以下方法。\n\n```sh\ncd ~/.ssh\ncp id_rsa.pub authorized_keys\nssh-copy-id -i ~/.ssh/id_rsa.pub root@217.160.61.19 # 我的用户名和服务器地址,默认端口 22\n# 指定端口号为2212:ssh-copy-id -i ~/.ssh/id_rsa.pub -p 2212 user@ip\n\nssh root@217.160.61.19 # 登录并输入密码,第二次就不再需要密码了。\n\n```\n\n\n\n---\n\n[Chinese]: https://ifmx.cc/linux/398.html \"中文指引\"\n[IONOS]: https://www.ionos.de/hilfe/server-cloud-infrastructure/erste-schritte/root-passwort-zuruecksetzen/root-passwort-zuruecksetzen-ubuntu/ \"IONOS官方指引\"\n\n\n","slug":"IT/Tools/Ubuntu重设root用户密码","published":1,"updated":"2019-08-14T06:34:27.000Z","_id":"cka1y597x001e4huuv3ebsp4j","comments":1,"layout":"post","photos":[],"link":"","content":"

重设密码

\n

原理上参考这份中文指引就好。由于我的服务器是IONOS公司的,这里主要记录IONOS的官方指引。(严格按照步骤)

\n
1
2
网址 www.ionos.de/hilfe
# 选择 Server & Cloud Infrastructure
\n
    \n
  1. 打开 KVM-Konsole
  2. \n
  3. 在用户管理平台软重启系统 Soft-Restart
  4. \n
  5. 在 KVM-Konsole 这边按 ESC
  6. \n
  7. 当出现类似一下界面,按 E
  8. \n
\n

\n
    \n
  1. \n

    然后会来到这个界面。

    \n
  2. \n
  3. \n

    \n
  4. \n
  5. \n

    用上下键移动到“linux。。。”开始的那一行,并左右键移动到这行的末尾,空格,输入 init=/bin/bash

    \n
  6. \n
\n

\n
    \n
  1. \n

    F10 开始重启。等完成,进入命令模式后,输入以下命令。

    \n
    1
    2
    3
    4
    5
    mount -o remount,rw /
    passwd
    Enter new UNIX password:
    Retype new UNIX password:
    passwd: password updated successfull
    \n
  2. \n
  3. \n

    最后输入命令重启系统!

    \n
    1
    reboot -f
    \n
  4. \n
\n

设置公共SSH

\n

在配置 github 的时候已经生成了 ssh-key ,可以用以下方法。

\n
1
2
3
4
5
6
cd ~/.ssh
cp id_rsa.pub authorized_keys
ssh-copy-id -i ~/.ssh/id_rsa.pub root@217.160.61.19 # 我的用户名和服务器地址,默认端口 22
# 指定端口号为2212:ssh-copy-id -i ~/.ssh/id_rsa.pub -p 2212 user@ip

ssh root@217.160.61.19 # 登录并输入密码,第二次就不再需要密码了。
\n
\n","site":{"data":{}},"excerpt":"","more":"

重设密码

\n

原理上参考这份中文指引就好。由于我的服务器是IONOS公司的,这里主要记录IONOS的官方指引。(严格按照步骤)

\n\n
    \n
  1. 打开 KVM-Konsole
  2. \n
  3. 在用户管理平台软重启系统 Soft-Restart
  4. \n
  5. 在 KVM-Konsole 这边按 ESC
  6. \n
  7. 当出现类似一下界面,按 E
  8. \n
\n

\n
    \n
  1. \n

    然后会来到这个界面。

    \n
  2. \n
  3. \n

    \n
  4. \n
  5. \n

    用上下键移动到“linux。。。”开始的那一行,并左右键移动到这行的末尾,空格,输入 init=/bin/bash

    \n
  6. \n
\n

\n
    \n
  1. \n

    F10 开始重启。等完成,进入命令模式后,输入以下命令。

    \n\n
  2. \n
  3. \n

    最后输入命令重启系统!

    \n\n
  4. \n
\n

设置公共SSH

\n

在配置 github 的时候已经生成了 ssh-key ,可以用以下方法。

\n\n
\n"},{"title":"使用Github维护知识库","date":"2019-07-24T21:02:14.000Z","urlname":"use-github-in-wiki","toc":true,"notshow":true,"_content":"\n### 部署以及更新\n\n- **初建**:将文件夹设置为仓库。只是第一次需要,以后就基本不用。\n``git init``\n\n- **更新**:更新所有的文件。\n``git add .``\n\n- **描述**:更新描述(optional 不是必须的)\n``git commit -m \"my command...\"``\n\n- **推送**:上传到云仓库\n``git push -u origin master``\n\n\n\n#### 详细指令\n\n```bash\ngit remote add origin https://github.com/maiernte/NewAngular.git\n\ngit push -u origin master\n\n# For the next commit\n$ git add . # add to index only files created/modified and not those deleted\n$ git add -u # add to index only files deleted/modified and not those created\n$ git add -A # do both operation at once, add to index all files\n```\n下载及更新\n\n```bash\n#下载整个项目\ngit clone XXXXX\n#从服务器更新\ngit pull [xxxxxx]\n#Help\ngit hepl VERB\ngit VERB -h\n```\n\n克隆指定 Branch, 因为有时候 master 和 gh-pages 上存放的是不同的文档。\n\n```sh\ngit clone https://github.com/maiernte/gitbook_python_finance.git --branch master new_fold\n```\n\n设置忽略文件夹以及文件\n\n```sh\ntouch .gitignore\nvim .gitignore\n```\n\n并添加类似的行\n\n```\n# See https://help.github.com/ignore-files/ for more about ignoring files.\n# dependencies\n/node_modules\n\n# testing\n/coverage\n# production\n/build\n# misc\n.DS_Store\n.env.local\nnpm-debug.log*\nyarn-debug.log*\n```\n\n\n\n### 设置git身份信息\n\n```bash\ngit config --global user.name \"你的用户名\"\ngit config --global user.email \"你的邮箱\" \n```\n\n\n\n### 密码和凭证\n\n#### 保存 Github 用户名和密码\n\nMac 下面每次 `push` 都要询问用户名和密码,很麻烦。而且将来不利于用脚本控制部署。有个解决的办法:进入项目根目录,执行一下命令\n\n```sh\ngit config --global credential.helper store\n```\n\n然后推送一次,输入账号和密码后,第二次推送就不需要了!\n\n\n\n#### SSH Key 凭证\n\n```sh\n# 加入 SSH Agent\nssh-agent -s\n```\n\n如果出现类似`Agent pid XXXX`这样的字样,则跳过下一步,否则输入:\n\n```sh\neval `ssh-agent -s`\n```\n\n直到出现`Agent pid XXXX`这样的提示之后,输入:\n\n```sh\nssh-add ~/.ssh/id_rsa\n```\n\n这样,你成功的在本地生成了一个可用的SSH key。\n\n下面将这个key添加到github网站。 打开https://github.com/settings/ssh,点击`Add SSH Key`,复制`id_rsa.pub`中的所有内容到`Key`框中,在`Title`框中输入方便自己记忆的名字(建议输入能让自己明白是哪台电脑的名字,方便以后管理)。 当网页显示添加成功后,就已经完成了全部的操作。 下面进行一些测试,同样是打开Git Bash,输入:\n\n```\nssh -T git@github.com\n```\n\nbash中会显示如下字样:\n\n```\nThe authenticity of host 'github.com (207.97.227.239)' can't be established.\nRSA key fingerprint is 16:27:ac:a5:76:28:2d:36:63:1b:56:4d:eb:df:a6:48.\nAre you sure you want to continue connecting (yes/no)?\n```\n\n输入yes之后,计算机会自动将`github.com`列入已知的host,然后会出现如下提示:\n\n```\nHi username! You've successfully authenticated, but GitHub does not\nprovide shell access.\n```\n\n如果成功看见,说明你已经配置好了,快去享受爽快的hexo一键部署吧; 如果出现任何错误提示,请仔细检查自己的操作,或者将错误信息发给我。\n\n[参阅:十步轻松搞定Hexo]([https://gavinlee1.github.io/2017/02/25/%E5%8D%81%E6%AD%A5%E4%B9%8B%E5%86%85%E8%BD%BB%E6%9D%BE%E6%90%9E%E5%AE%9A-Hexo-GitHub%E6%90%AD%E5%BB%BA%E4%B8%AA%E4%BA%BA%E5%8D%9A%E5%AE%A2/](https://gavinlee1.github.io/2017/02/25/十步之内轻松搞定-Hexo-GitHub搭建个人博客/))\n\n如果要多台电脑共同使用同一个SSH-Key,先在第二台电脑上用这个key的相同邮件生成一个新的key\n```\nssh-keygen -t rsa -b 4096 -C \"username@gmail.com\"\n```\n用第一台电脑上的两个key文件 `id_rsa, id_rsa.pub` 覆盖第二台电脑的文件(*注意备份*)。确保NEW上的两个文件的权限是正确的,id_rsa是600,id_rsa.pub是644,比如:\n```sh\n-rw------- 1 fancy fancy 1675 2013-03-19 12:55 id_rsa\n-rw-r--r-- 1 fancy fancy 406 2013-03-19 12:55 id_rsa.pub\n# 查看权限命令是 \nls -l\n# 更改权限命令是\nchmod 600 ~/.ssh/id_rsa\nchmod 644 ~/.ssh/id_rsa.pub\n```\n\n\n### 删除仓库\n\n1. 点开仓库\n2. 点击右上角的 `Settings`\n3. 滚动到最下面 `Done Zone`, 选择 `Delete this repository`。\n\n### 恢复所有修改\n\n```sh\ngit checkout . #本地所有修改的。没有的提交的,都返回到原来的状态\ngit stash #把所有没有提交的修改暂存到stash里面。可用git stash pop回复。\ngit reset --hard HASH #返回到HASH点,不保留修改。\ngit reset --soft HASH #同上,保留修改。HASH 是节点号,z.B. 7d593c5\n\ngit clean -df #返回到某个节点\ngit clean 参数\n -n 显示 将要 删除的 文件 和 目录\n -f 删除 文件\n -df 删除 文件 和 目录\n--------------------- \ngit describe --always # 查看当前节点号\ngit log # 查看所有HEAD号和Commit描述\n```\n\n更加暴力的方式是\n\n```sh\nit checkout . && git clean -xdf\n```\n\n\n\n#### 清除历史记录\n\n{% fold 代码 %}\n```\n1. Checkout\n git checkout --orphan latest_branch\n\n2. Add all the files\n git add -A\n\n3. Commit the changes\n git commit -am \"commit message\"\n\n4. Delete the branch\n git branch -D master\n\n5. Rename the current branch to master\n git branch -m master\n\n6. Finally, force update your repository\n\n git push -f origin master\n```\n{% endfold %}\n\n### 私人仓库\n\n作为个人笔记,不应该设为public,这样别人可以浏览。==2019== 年Github更新了[新的政策](https://www.infoq.cn/article/aKm94Aw1RmDL_9Gysm8D\n):\n> GitHub Free:包含无限制的私人存储库。有了 GitHub Free,开发人员可以将 GitHub 用于私有项目,每个存储库最多可以有三个协作者。许多开发人员希望使用私人仓库申请工作,做一些 side project,或者在公开发布之前先私下尝试一些东西。从今天开始,这些场景在 GitHub 上可以免费实现(未来可能有更多场景)。 公共存储库仍然是免费的,并包括无限合作者。\n\n\n\n1. 点开仓库\n2. 点击右上角的 `Settings`\n3. 滚动到最下面 `Done Zone`, 选择 `Make this repository private`。\n\n## 文摘资源\n\n[Git submodule 子模块的管理和使用](https://www.jianshu.com/p/9000cd49822c)","source":"_posts/IT/Tools/使用Github维护知识库.md","raw":"---\ntitle: 使用Github维护知识库\ndate: 2019-07-24 23:02:14\nurlname: use-github-in-wiki\ntoc: true\ntags: [工具]\ncategories: [IT, Tools]\nnotshow: true\n\n---\n\n### 部署以及更新\n\n- **初建**:将文件夹设置为仓库。只是第一次需要,以后就基本不用。\n``git init``\n\n- **更新**:更新所有的文件。\n``git add .``\n\n- **描述**:更新描述(optional 不是必须的)\n``git commit -m \"my command...\"``\n\n- **推送**:上传到云仓库\n``git push -u origin master``\n\n\n\n#### 详细指令\n\n```bash\ngit remote add origin https://github.com/maiernte/NewAngular.git\n\ngit push -u origin master\n\n# For the next commit\n$ git add . # add to index only files created/modified and not those deleted\n$ git add -u # add to index only files deleted/modified and not those created\n$ git add -A # do both operation at once, add to index all files\n```\n下载及更新\n\n```bash\n#下载整个项目\ngit clone XXXXX\n#从服务器更新\ngit pull [xxxxxx]\n#Help\ngit hepl VERB\ngit VERB -h\n```\n\n克隆指定 Branch, 因为有时候 master 和 gh-pages 上存放的是不同的文档。\n\n```sh\ngit clone https://github.com/maiernte/gitbook_python_finance.git --branch master new_fold\n```\n\n设置忽略文件夹以及文件\n\n```sh\ntouch .gitignore\nvim .gitignore\n```\n\n并添加类似的行\n\n```\n# See https://help.github.com/ignore-files/ for more about ignoring files.\n# dependencies\n/node_modules\n\n# testing\n/coverage\n# production\n/build\n# misc\n.DS_Store\n.env.local\nnpm-debug.log*\nyarn-debug.log*\n```\n\n\n\n### 设置git身份信息\n\n```bash\ngit config --global user.name \"你的用户名\"\ngit config --global user.email \"你的邮箱\" \n```\n\n\n\n### 密码和凭证\n\n#### 保存 Github 用户名和密码\n\nMac 下面每次 `push` 都要询问用户名和密码,很麻烦。而且将来不利于用脚本控制部署。有个解决的办法:进入项目根目录,执行一下命令\n\n```sh\ngit config --global credential.helper store\n```\n\n然后推送一次,输入账号和密码后,第二次推送就不需要了!\n\n\n\n#### SSH Key 凭证\n\n```sh\n# 加入 SSH Agent\nssh-agent -s\n```\n\n如果出现类似`Agent pid XXXX`这样的字样,则跳过下一步,否则输入:\n\n```sh\neval `ssh-agent -s`\n```\n\n直到出现`Agent pid XXXX`这样的提示之后,输入:\n\n```sh\nssh-add ~/.ssh/id_rsa\n```\n\n这样,你成功的在本地生成了一个可用的SSH key。\n\n下面将这个key添加到github网站。 打开https://github.com/settings/ssh,点击`Add SSH Key`,复制`id_rsa.pub`中的所有内容到`Key`框中,在`Title`框中输入方便自己记忆的名字(建议输入能让自己明白是哪台电脑的名字,方便以后管理)。 当网页显示添加成功后,就已经完成了全部的操作。 下面进行一些测试,同样是打开Git Bash,输入:\n\n```\nssh -T git@github.com\n```\n\nbash中会显示如下字样:\n\n```\nThe authenticity of host 'github.com (207.97.227.239)' can't be established.\nRSA key fingerprint is 16:27:ac:a5:76:28:2d:36:63:1b:56:4d:eb:df:a6:48.\nAre you sure you want to continue connecting (yes/no)?\n```\n\n输入yes之后,计算机会自动将`github.com`列入已知的host,然后会出现如下提示:\n\n```\nHi username! You've successfully authenticated, but GitHub does not\nprovide shell access.\n```\n\n如果成功看见,说明你已经配置好了,快去享受爽快的hexo一键部署吧; 如果出现任何错误提示,请仔细检查自己的操作,或者将错误信息发给我。\n\n[参阅:十步轻松搞定Hexo]([https://gavinlee1.github.io/2017/02/25/%E5%8D%81%E6%AD%A5%E4%B9%8B%E5%86%85%E8%BD%BB%E6%9D%BE%E6%90%9E%E5%AE%9A-Hexo-GitHub%E6%90%AD%E5%BB%BA%E4%B8%AA%E4%BA%BA%E5%8D%9A%E5%AE%A2/](https://gavinlee1.github.io/2017/02/25/十步之内轻松搞定-Hexo-GitHub搭建个人博客/))\n\n如果要多台电脑共同使用同一个SSH-Key,先在第二台电脑上用这个key的相同邮件生成一个新的key\n```\nssh-keygen -t rsa -b 4096 -C \"username@gmail.com\"\n```\n用第一台电脑上的两个key文件 `id_rsa, id_rsa.pub` 覆盖第二台电脑的文件(*注意备份*)。确保NEW上的两个文件的权限是正确的,id_rsa是600,id_rsa.pub是644,比如:\n```sh\n-rw------- 1 fancy fancy 1675 2013-03-19 12:55 id_rsa\n-rw-r--r-- 1 fancy fancy 406 2013-03-19 12:55 id_rsa.pub\n# 查看权限命令是 \nls -l\n# 更改权限命令是\nchmod 600 ~/.ssh/id_rsa\nchmod 644 ~/.ssh/id_rsa.pub\n```\n\n\n### 删除仓库\n\n1. 点开仓库\n2. 点击右上角的 `Settings`\n3. 滚动到最下面 `Done Zone`, 选择 `Delete this repository`。\n\n### 恢复所有修改\n\n```sh\ngit checkout . #本地所有修改的。没有的提交的,都返回到原来的状态\ngit stash #把所有没有提交的修改暂存到stash里面。可用git stash pop回复。\ngit reset --hard HASH #返回到HASH点,不保留修改。\ngit reset --soft HASH #同上,保留修改。HASH 是节点号,z.B. 7d593c5\n\ngit clean -df #返回到某个节点\ngit clean 参数\n -n 显示 将要 删除的 文件 和 目录\n -f 删除 文件\n -df 删除 文件 和 目录\n--------------------- \ngit describe --always # 查看当前节点号\ngit log # 查看所有HEAD号和Commit描述\n```\n\n更加暴力的方式是\n\n```sh\nit checkout . && git clean -xdf\n```\n\n\n\n#### 清除历史记录\n\n{% fold 代码 %}\n```\n1. Checkout\n git checkout --orphan latest_branch\n\n2. Add all the files\n git add -A\n\n3. Commit the changes\n git commit -am \"commit message\"\n\n4. Delete the branch\n git branch -D master\n\n5. Rename the current branch to master\n git branch -m master\n\n6. Finally, force update your repository\n\n git push -f origin master\n```\n{% endfold %}\n\n### 私人仓库\n\n作为个人笔记,不应该设为public,这样别人可以浏览。==2019== 年Github更新了[新的政策](https://www.infoq.cn/article/aKm94Aw1RmDL_9Gysm8D\n):\n> GitHub Free:包含无限制的私人存储库。有了 GitHub Free,开发人员可以将 GitHub 用于私有项目,每个存储库最多可以有三个协作者。许多开发人员希望使用私人仓库申请工作,做一些 side project,或者在公开发布之前先私下尝试一些东西。从今天开始,这些场景在 GitHub 上可以免费实现(未来可能有更多场景)。 公共存储库仍然是免费的,并包括无限合作者。\n\n\n\n1. 点开仓库\n2. 点击右上角的 `Settings`\n3. 滚动到最下面 `Done Zone`, 选择 `Make this repository private`。\n\n## 文摘资源\n\n[Git submodule 子模块的管理和使用](https://www.jianshu.com/p/9000cd49822c)","slug":"IT/Tools/使用Github维护知识库","published":1,"updated":"2019-08-15T09:40:53.000Z","_id":"cka1y597z001h4huur126uc0a","comments":1,"layout":"post","photos":[],"link":"","content":"

部署以及更新

\n
    \n
  • \n

    初建:将文件夹设置为仓库。只是第一次需要,以后就基本不用。
    \ngit init

    \n
  • \n
  • \n

    更新:更新所有的文件。
    \ngit add .

    \n
  • \n
  • \n

    描述:更新描述(optional 不是必须的)
    \ngit commit -m "my command..."

    \n
  • \n
  • \n

    推送:上传到云仓库
    \ngit push -u origin master

    \n
  • \n
\n\n

详细指令

\n
1
2
3
4
5
6
7
8
git remote add origin https://github.com/maiernte/NewAngular.git

git push -u origin master

# For the next commit
$ git add . # add to index only files created/modified and not those deleted
$ git add -u # add to index only files deleted/modified and not those created
$ git add -A # do both operation at once, add to index all files
\n

下载及更新

\n
1
2
3
4
5
6
7
#下载整个项目
git clone XXXXX
#从服务器更新
git pull [xxxxxx]
#Help
git hepl VERB
git VERB -h
\n

克隆指定 Branch, 因为有时候 master 和 gh-pages 上存放的是不同的文档。

\n
1
git clone https://github.com/maiernte/gitbook_python_finance.git --branch master new_fold
\n

设置忽略文件夹以及文件

\n
1
2
touch .gitignore
vim .gitignore
\n

并添加类似的行

\n
1
2
3
4
5
6
7
8
9
10
11
12
13
# See https://help.github.com/ignore-files/ for more about ignoring files.
# dependencies
/node_modules

# testing
/coverage
# production
/build
# misc
.DS_Store
.env.local
npm-debug.log*
yarn-debug.log*
\n

设置git身份信息

\n
1
2
git config --global user.name \"你的用户名\"
git config --global user.email \"你的邮箱\"
\n

密码和凭证

\n

保存 Github 用户名和密码

\n

Mac 下面每次 push 都要询问用户名和密码,很麻烦。而且将来不利于用脚本控制部署。有个解决的办法:进入项目根目录,执行一下命令

\n
1
git config --global credential.helper store
\n

然后推送一次,输入账号和密码后,第二次推送就不需要了!

\n

SSH Key 凭证

\n
1
2
# 加入 SSH Agent
ssh-agent -s
\n

如果出现类似Agent pid XXXX这样的字样,则跳过下一步,否则输入:

\n
1
eval `ssh-agent -s`
\n

直到出现Agent pid XXXX这样的提示之后,输入:

\n
1
ssh-add ~/.ssh/id_rsa
\n

这样,你成功的在本地生成了一个可用的SSH key。

\n

下面将这个key添加到github网站。 打开https://github.com/settings/ssh,点击Add SSH Key,复制id_rsa.pub中的所有内容到Key框中,在Title框中输入方便自己记忆的名字(建议输入能让自己明白是哪台电脑的名字,方便以后管理)。 当网页显示添加成功后,就已经完成了全部的操作。 下面进行一些测试,同样是打开Git Bash,输入:

\n
1
ssh -T git@github.com
\n

bash中会显示如下字样:

\n
1
2
3
The authenticity of host 'github.com (207.97.227.239)' can't be established.
RSA key fingerprint is 16:27:ac:a5:76:28:2d:36:63:1b:56:4d:eb:df:a6:48.
Are you sure you want to continue connecting (yes/no)?
\n

输入yes之后,计算机会自动将github.com列入已知的host,然后会出现如下提示:

\n
1
2
Hi username! You've successfully authenticated, but GitHub does not
provide shell access.
\n

如果成功看见,说明你已经配置好了,快去享受爽快的hexo一键部署吧; 如果出现任何错误提示,请仔细检查自己的操作,或者将错误信息发给我。

\n

参阅:十步轻松搞定Hexo

\n

如果要多台电脑共同使用同一个SSH-Key,先在第二台电脑上用这个key的相同邮件生成一个新的key

\n
1
ssh-keygen -t rsa -b 4096 -C "username@gmail.com"
\n

用第一台电脑上的两个key文件 id_rsa, id_rsa.pub 覆盖第二台电脑的文件(注意备份)。确保NEW上的两个文件的权限是正确的,id_rsa是600,id_rsa.pub是644,比如:

\n
1
2
3
4
5
6
7
-rw------- 1 fancy fancy 1675 2013-03-19 12:55 id_rsa
-rw-r--r-- 1 fancy fancy 406 2013-03-19 12:55 id_rsa.pub
# 查看权限命令是
ls -l
# 更改权限命令是
chmod 600 ~/.ssh/id_rsa
chmod 644 ~/.ssh/id_rsa.pub
\n

删除仓库

\n
    \n
  1. 点开仓库
  2. \n
  3. 点击右上角的 Settings
  4. \n
  5. 滚动到最下面 Done Zone, 选择 Delete this repository
  6. \n
\n

恢复所有修改

\n
1
2
3
4
5
6
7
8
9
10
11
12
13
git checkout . #本地所有修改的。没有的提交的,都返回到原来的状态
git stash #把所有没有提交的修改暂存到stash里面。可用git stash pop回复。
git reset --hard HASH #返回到HASH点,不保留修改。
git reset --soft HASH #同上,保留修改。HASH 是节点号,z.B. 7d593c5

git clean -df #返回到某个节点
git clean 参数
-n 显示 将要 删除的 文件 和 目录
-f 删除 文件
-df 删除 文件 和 目录
---------------------
git describe --always # 查看当前节点号
git log # 查看所有HEAD号和Commit描述
\n

更加暴力的方式是

\n
1
it checkout . && git clean -xdf
\n

清除历史记录

\n
代码
\n
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
1. Checkout
git checkout --orphan latest_branch

2. Add all the files
git add -A

3. Commit the changes
git commit -am "commit message"

4. Delete the branch
git branch -D master

5. Rename the current branch to master
git branch -m master

6. Finally, force update your repository

git push -f origin master
\n\n
\n

私人仓库

\n

作为个人笔记,不应该设为public,这样别人可以浏览。==2019== 年Github更新了新的政策

\n
\n

GitHub Free:包含无限制的私人存储库。有了 GitHub Free,开发人员可以将 GitHub 用于私有项目,每个存储库最多可以有三个协作者。许多开发人员希望使用私人仓库申请工作,做一些 side project,或者在公开发布之前先私下尝试一些东西。从今天开始,这些场景在 GitHub 上可以免费实现(未来可能有更多场景)。 公共存储库仍然是免费的,并包括无限合作者。

\n
\n
    \n
  1. 点开仓库
  2. \n
  3. 点击右上角的 Settings
  4. \n
  5. 滚动到最下面 Done Zone, 选择 Make this repository private
  6. \n
\n

文摘资源

\n

Git submodule 子模块的管理和使用

\n","site":{"data":{}},"excerpt":"

部署以及更新

\n
    \n
  • \n

    初建:将文件夹设置为仓库。只是第一次需要,以后就基本不用。
    \ngit init

    \n
  • \n
  • \n

    更新:更新所有的文件。
    \ngit add .

    \n
  • \n
  • \n

    描述:更新描述(optional 不是必须的)
    \ngit commit -m "my command..."

    \n
  • \n
  • \n

    推送:上传到云仓库
    \ngit push -u origin master

    \n
  • \n
","more":"

详细指令

\n\n

下载及更新

\n\n

克隆指定 Branch, 因为有时候 master 和 gh-pages 上存放的是不同的文档。

\n\n

设置忽略文件夹以及文件

\n\n

并添加类似的行

\n\n

设置git身份信息

\n\n

密码和凭证

\n

保存 Github 用户名和密码

\n

Mac 下面每次 push 都要询问用户名和密码,很麻烦。而且将来不利于用脚本控制部署。有个解决的办法:进入项目根目录,执行一下命令

\n\n

然后推送一次,输入账号和密码后,第二次推送就不需要了!

\n

SSH Key 凭证

\n\n

如果出现类似Agent pid XXXX这样的字样,则跳过下一步,否则输入:

\n\n

直到出现Agent pid XXXX这样的提示之后,输入:

\n\n

这样,你成功的在本地生成了一个可用的SSH key。

\n

下面将这个key添加到github网站。 打开https://github.com/settings/ssh,点击Add SSH Key,复制id_rsa.pub中的所有内容到Key框中,在Title框中输入方便自己记忆的名字(建议输入能让自己明白是哪台电脑的名字,方便以后管理)。 当网页显示添加成功后,就已经完成了全部的操作。 下面进行一些测试,同样是打开Git Bash,输入:

\n\n

bash中会显示如下字样:

\n\n

输入yes之后,计算机会自动将github.com列入已知的host,然后会出现如下提示:

\n\n

如果成功看见,说明你已经配置好了,快去享受爽快的hexo一键部署吧; 如果出现任何错误提示,请仔细检查自己的操作,或者将错误信息发给我。

\n

参阅:十步轻松搞定Hexo

\n

如果要多台电脑共同使用同一个SSH-Key,先在第二台电脑上用这个key的相同邮件生成一个新的key

\n\n

用第一台电脑上的两个key文件 id_rsa, id_rsa.pub 覆盖第二台电脑的文件(注意备份)。确保NEW上的两个文件的权限是正确的,id_rsa是600,id_rsa.pub是644,比如:

\n\n

删除仓库

\n
    \n
  1. 点开仓库
  2. \n
  3. 点击右上角的 Settings
  4. \n
  5. 滚动到最下面 Done Zone, 选择 Delete this repository
  6. \n
\n

恢复所有修改

\n\n

更加暴力的方式是

\n\n

清除历史记录

\n
代码
\n\n\n
\n

私人仓库

\n

作为个人笔记,不应该设为public,这样别人可以浏览。==2019== 年Github更新了新的政策

\n
\n

GitHub Free:包含无限制的私人存储库。有了 GitHub Free,开发人员可以将 GitHub 用于私有项目,每个存储库最多可以有三个协作者。许多开发人员希望使用私人仓库申请工作,做一些 side project,或者在公开发布之前先私下尝试一些东西。从今天开始,这些场景在 GitHub 上可以免费实现(未来可能有更多场景)。 公共存储库仍然是免费的,并包括无限合作者。

\n
\n
    \n
  1. 点开仓库
  2. \n
  3. 点击右上角的 Settings
  4. \n
  5. 滚动到最下面 Done Zone, 选择 Make this repository private
  6. \n
\n

文摘资源

\n

Git submodule 子模块的管理和使用

"},{"title":"坚果云有关","date":"2019-07-25T03:41:28.000Z","urlname":"about-jianguoyu","toc":true,"notshow":true,"_content":"\n\n\n##### 忽略文件\n\n配置文件 `customExtRules.conf`。在 Window 版可以在软件直接打开,在 Mac App 里面没有这个选项,要自行查找这个配置文件。[官方说明](http://www.jianguoyun.com/s/content/2219.html)\n\n> 在 Windows 和 Mac 下面目录可能不一样。\n\n\n\nMac 系统或 Linux 系统这个文件通常位于\n\n```sh\nvim ~/.nutstore/db/customExtRules.conf\nfold/to/ignore # 文件夹的绝对路径\n```\n\n\n\n##### 安卓系统上同步文件夹\n\n安卓版的坚果云客户端只会打开临时指定的文件。如果希望跟在PC上一样的操作,将整个文件库都同步到指定的文件夹内,就要用[FolderSync](http://help.jianguoyun.com/?p=2887)软件。\n\n登陆坚果云官网,账户信息-->安全选项-->第三方应用管理,生成一个新的第三方应用 **androidSync**,密码为 `xxxxxxxxxxxxxxxx`,然后按照上述官网的指南一步一步配置 FolderSync 就可以了。回头还是用 「坚果云 Markdown」这款软件来阅读md文档。\n\n##### 托管密码\n\n设置为 SafeInClound 的托管云盘。用户名是坚果云的登陆账户,密码为专门为其开通的第三方应用 *mypass* 的专门密码。`Local Pfad` 填写云盘内存储数据库文件的文件夹。 \n\n![](https://github.com/maiernte/img/raw/master/Tech/safeInCloudToJianguo.png)","source":"_posts/IT/Tools/坚果云有关.md","raw":"---\ntitle: 坚果云有关\ndate: 2019-07-25 05:41:28\nurlname: about-jianguoyu\ntoc: true\ntags: [工具]\ncategories: [IT, Tools]\nnotshow: true\n\n---\n\n\n\n##### 忽略文件\n\n配置文件 `customExtRules.conf`。在 Window 版可以在软件直接打开,在 Mac App 里面没有这个选项,要自行查找这个配置文件。[官方说明](http://www.jianguoyun.com/s/content/2219.html)\n\n> 在 Windows 和 Mac 下面目录可能不一样。\n\n\n\nMac 系统或 Linux 系统这个文件通常位于\n\n```sh\nvim ~/.nutstore/db/customExtRules.conf\nfold/to/ignore # 文件夹的绝对路径\n```\n\n\n\n##### 安卓系统上同步文件夹\n\n安卓版的坚果云客户端只会打开临时指定的文件。如果希望跟在PC上一样的操作,将整个文件库都同步到指定的文件夹内,就要用[FolderSync](http://help.jianguoyun.com/?p=2887)软件。\n\n登陆坚果云官网,账户信息-->安全选项-->第三方应用管理,生成一个新的第三方应用 **androidSync**,密码为 `xxxxxxxxxxxxxxxx`,然后按照上述官网的指南一步一步配置 FolderSync 就可以了。回头还是用 「坚果云 Markdown」这款软件来阅读md文档。\n\n##### 托管密码\n\n设置为 SafeInClound 的托管云盘。用户名是坚果云的登陆账户,密码为专门为其开通的第三方应用 *mypass* 的专门密码。`Local Pfad` 填写云盘内存储数据库文件的文件夹。 \n\n![](https://github.com/maiernte/img/raw/master/Tech/safeInCloudToJianguo.png)","slug":"IT/Tools/坚果云有关","published":1,"updated":"2019-08-14T22:10:30.000Z","_id":"cka1y5981001j4huuk1yz6awj","comments":1,"layout":"post","photos":[],"link":"","content":"
忽略文件
\n

配置文件 customExtRules.conf。在 Window 版可以在软件直接打开,在 Mac App 里面没有这个选项,要自行查找这个配置文件。官方说明

\n
\n

在 Windows 和 Mac 下面目录可能不一样。

\n
\n\n

Mac 系统或 Linux 系统这个文件通常位于

\n
1
2
vim ~/.nutstore/db/customExtRules.conf
fold/to/ignore # 文件夹的绝对路径
\n
安卓系统上同步文件夹
\n

安卓版的坚果云客户端只会打开临时指定的文件。如果希望跟在PC上一样的操作,将整个文件库都同步到指定的文件夹内,就要用FolderSync软件。

\n

登陆坚果云官网,账户信息–>安全选项–>第三方应用管理,生成一个新的第三方应用 androidSync,密码为 xxxxxxxxxxxxxxxx,然后按照上述官网的指南一步一步配置 FolderSync 就可以了。回头还是用 「坚果云 Markdown」这款软件来阅读md文档。

\n
托管密码
\n

设置为 SafeInClound 的托管云盘。用户名是坚果云的登陆账户,密码为专门为其开通的第三方应用 mypass 的专门密码。Local Pfad 填写云盘内存储数据库文件的文件夹。

\n

\n","site":{"data":{}},"excerpt":"
忽略文件
\n

配置文件 customExtRules.conf。在 Window 版可以在软件直接打开,在 Mac App 里面没有这个选项,要自行查找这个配置文件。官方说明

\n
\n

在 Windows 和 Mac 下面目录可能不一样。

\n
","more":"

Mac 系统或 Linux 系统这个文件通常位于

\n\n
安卓系统上同步文件夹
\n

安卓版的坚果云客户端只会打开临时指定的文件。如果希望跟在PC上一样的操作,将整个文件库都同步到指定的文件夹内,就要用FolderSync软件。

\n

登陆坚果云官网,账户信息–>安全选项–>第三方应用管理,生成一个新的第三方应用 androidSync,密码为 xxxxxxxxxxxxxxxx,然后按照上述官网的指南一步一步配置 FolderSync 就可以了。回头还是用 「坚果云 Markdown」这款软件来阅读md文档。

\n
托管密码
\n

设置为 SafeInClound 的托管云盘。用户名是坚果云的登陆账户,密码为专门为其开通的第三方应用 mypass 的专门密码。Local Pfad 填写云盘内存储数据库文件的文件夹。

\n

"},{"title":"编辑器工具使用技巧汇总","date":"2019-07-27T06:24:33.000Z","urlname":"Editor-Skills-Summary","toc":true,"notshow":true,"_content":"\n# VSCode\n\n1. Wechseln zwischen Text-Editor und Terminal\n 1. `Command+K+S` oder in Menü `Code->Pereferenc->Hotky`, öffnet Hot-Key Editor Fenster.\n 2. Tip `terminal` in Suchfeld, findet die Binding `^\\``, löscht diese Einstellung.\n 3. Sucht den \"workbench.action.terminal.focus\", bindet es mit Key `⌃<`.\n 4. Sucht den \"workbench.action.focusActiveEditorGroup\", bindet es wiederum mit Schlüssel `⌃<`, und Wenn-Kondition \"terminalFocus\".\n\n\n\n# Typora\n\n更多更详细的内容请参阅 Typora Wiki\n\n[Typora Wiki](http://support.typora.io/) ([wiki-website Project](https://github.com/typora/wiki-website))\n\n\n\n## 个性化快捷键\n\n**Windows**\n\n*文件--->偏好设置--->往高级设置* ,点击看到两个`json`格式的文件,打开第二个(**conf.user.json**), 用记事本打开,第17行`keyBinding`,在大括号中写 `代码块`:“你要设置的快捷键”,比如我的是**代码块**:`Ctrl+Alt+P`,保存文件,重启`typora`即可生效。[更详细介绍](https://github.com/itcastWsy/typora_copy_images)\n\n\n```json\n// Custom key binding, which will override the default ones.\n \"keyBinding\": {\n // for example: \n // \"Always on Top\": \"Ctrl+Shift+P\"\n \"注释\":\"Ctrl+Alt+/\",\n \"代码块\":\"Ctrl+Alt+P\",\n \"打开文件夹…\":\"Ctrl+Alt+O\"\n },\n```\n\n**Mac**\n\n[官方说明](http://support.typora.io/Shortcut-Keys/#macos)\n\n需要到`系统偏好设置—>键盘-->快捷键-->应用快捷键`那边设置。找到 ***Typora.App***,菜单名称填 ***代码***,然后输入希望的快捷键。我的设置是***⌃+⌘+C***。\n\n\n\n## 更改风格\n\n[开发好的工具](https://github.com/typora/typora-theme-toolkit) [如何客制化格式](https://pjchender.github.io/2018/04/24/note-%E5%A6%82%E4%BD%95%E7%82%BA-typora-%E6%92%B0%E5%AF%AB%E5%AE%A2%E8%A3%BD%E5%8C%96%E6%A8%A3%E5%BC%8F/)\n\n简单使用:添加 `base.user.css` 文件,并改变行内代码的颜色,以及公式颜色\n\n```css\n# 行内代码\ncode {\n\tcolor: red\n}\n\n# 行内公式\n.MathJax_SVG{\n\tcolor: DarkBlue;\n}\n```\n\n \n\nTypora的代码使用 [CodeMirror](https://codemirror.net/) 项目,尝试了一下修改 `base.user.css` 文件确实可以改变代码段的高度,并带滚动。但同时也限定了进行代码编辑时的整个窗口高度。所以没有用\n\n```css\n# 缺点:打开源代码模式的时候,整个页面也被限制成了只有300px高\n.CodeMirror {\n max-height: 300px;\n}\n.CodeMirror-scroll {\n overflow-y: auto;\n \toverflow-x: auto;\n\tmax-height: 300px;\n}\n```\n\n注意到书写模式的时候,整个编辑器都被包裹在 `
` 里面。在源代码模式的时候,没有这个 `write` 元素的包裹,而整个源代码窗口都被作用为一个 `CodeMirror` 元素对待。因此,作一些改变就能满足要求\n\n```scss\n#write .CodeMirror {\n max-height: 350px;\n}\n# 设定上下 padding 会让滚动条在小代码区消失\n#write .CodeMirror-scroll {\n overflow-y: auto;\n \toverflow-x: auto;\n\tmax-height: 330px;\n\tpadding-top: 10px;\n\tpadding-bottom: 10px;\n}\n```\n\n```\n# 避免只有一行的代码区,因为会显示滚动条,不好看。一行代码就用行内代码好了。\n```\n\n如果要限制来自 `GistHub` 的代码高度,只能限定其父元素 `iframe`\n\n```css\niframe {\n\tmax-height: 500px;\n}\n```\n\nWindows版的 Typora 的数学模块保存在 `path/resource/app/lib.asar` 压缩文件中。需要用asar解压\n\n[如何查看 asar 内部结构](https://newsn.net/say/electron-asar-explorer.html)\n\n[asar 如何加密解密](https://newsn.net/say/electron-asar-explorer.html)\n\n```sh\nnpm install -g asar\nasar extract 压缩文件 解压文件夹\nasar pack 文件夹 压缩文件名\n```\n\n\n\n\n## 文本搜索\n\n打开的单篇文章内搜索:\n\n> Windows `Control + F`\n>\n> Mac `⌘+F`\n\n文件夹内的搜索\n\n> Windows `Control + Shift + F`\n>\n> Mac `⇧+⌘+F`","source":"_posts/IT/Tools/编辑器工具使用技巧汇总.md","raw":"---\ntitle: 编辑器工具使用技巧汇总\ndate: 2019-07-27 08:24:33\nurlname: Editor-Skills-Summary\ntoc: true\ntags: [工具]\ncategories: [IT, Tools]\nnotshow: true\n\n---\n\n# VSCode\n\n1. Wechseln zwischen Text-Editor und Terminal\n 1. `Command+K+S` oder in Menü `Code->Pereferenc->Hotky`, öffnet Hot-Key Editor Fenster.\n 2. Tip `terminal` in Suchfeld, findet die Binding `^\\``, löscht diese Einstellung.\n 3. Sucht den \"workbench.action.terminal.focus\", bindet es mit Key `⌃<`.\n 4. Sucht den \"workbench.action.focusActiveEditorGroup\", bindet es wiederum mit Schlüssel `⌃<`, und Wenn-Kondition \"terminalFocus\".\n\n\n\n# Typora\n\n更多更详细的内容请参阅 Typora Wiki\n\n[Typora Wiki](http://support.typora.io/) ([wiki-website Project](https://github.com/typora/wiki-website))\n\n\n\n## 个性化快捷键\n\n**Windows**\n\n*文件--->偏好设置--->往高级设置* ,点击看到两个`json`格式的文件,打开第二个(**conf.user.json**), 用记事本打开,第17行`keyBinding`,在大括号中写 `代码块`:“你要设置的快捷键”,比如我的是**代码块**:`Ctrl+Alt+P`,保存文件,重启`typora`即可生效。[更详细介绍](https://github.com/itcastWsy/typora_copy_images)\n\n\n```json\n// Custom key binding, which will override the default ones.\n \"keyBinding\": {\n // for example: \n // \"Always on Top\": \"Ctrl+Shift+P\"\n \"注释\":\"Ctrl+Alt+/\",\n \"代码块\":\"Ctrl+Alt+P\",\n \"打开文件夹…\":\"Ctrl+Alt+O\"\n },\n```\n\n**Mac**\n\n[官方说明](http://support.typora.io/Shortcut-Keys/#macos)\n\n需要到`系统偏好设置—>键盘-->快捷键-->应用快捷键`那边设置。找到 ***Typora.App***,菜单名称填 ***代码***,然后输入希望的快捷键。我的设置是***⌃+⌘+C***。\n\n\n\n## 更改风格\n\n[开发好的工具](https://github.com/typora/typora-theme-toolkit) [如何客制化格式](https://pjchender.github.io/2018/04/24/note-%E5%A6%82%E4%BD%95%E7%82%BA-typora-%E6%92%B0%E5%AF%AB%E5%AE%A2%E8%A3%BD%E5%8C%96%E6%A8%A3%E5%BC%8F/)\n\n简单使用:添加 `base.user.css` 文件,并改变行内代码的颜色,以及公式颜色\n\n```css\n# 行内代码\ncode {\n\tcolor: red\n}\n\n# 行内公式\n.MathJax_SVG{\n\tcolor: DarkBlue;\n}\n```\n\n \n\nTypora的代码使用 [CodeMirror](https://codemirror.net/) 项目,尝试了一下修改 `base.user.css` 文件确实可以改变代码段的高度,并带滚动。但同时也限定了进行代码编辑时的整个窗口高度。所以没有用\n\n```css\n# 缺点:打开源代码模式的时候,整个页面也被限制成了只有300px高\n.CodeMirror {\n max-height: 300px;\n}\n.CodeMirror-scroll {\n overflow-y: auto;\n \toverflow-x: auto;\n\tmax-height: 300px;\n}\n```\n\n注意到书写模式的时候,整个编辑器都被包裹在 `
` 里面。在源代码模式的时候,没有这个 `write` 元素的包裹,而整个源代码窗口都被作用为一个 `CodeMirror` 元素对待。因此,作一些改变就能满足要求\n\n```scss\n#write .CodeMirror {\n max-height: 350px;\n}\n# 设定上下 padding 会让滚动条在小代码区消失\n#write .CodeMirror-scroll {\n overflow-y: auto;\n \toverflow-x: auto;\n\tmax-height: 330px;\n\tpadding-top: 10px;\n\tpadding-bottom: 10px;\n}\n```\n\n```\n# 避免只有一行的代码区,因为会显示滚动条,不好看。一行代码就用行内代码好了。\n```\n\n如果要限制来自 `GistHub` 的代码高度,只能限定其父元素 `iframe`\n\n```css\niframe {\n\tmax-height: 500px;\n}\n```\n\nWindows版的 Typora 的数学模块保存在 `path/resource/app/lib.asar` 压缩文件中。需要用asar解压\n\n[如何查看 asar 内部结构](https://newsn.net/say/electron-asar-explorer.html)\n\n[asar 如何加密解密](https://newsn.net/say/electron-asar-explorer.html)\n\n```sh\nnpm install -g asar\nasar extract 压缩文件 解压文件夹\nasar pack 文件夹 压缩文件名\n```\n\n\n\n\n## 文本搜索\n\n打开的单篇文章内搜索:\n\n> Windows `Control + F`\n>\n> Mac `⌘+F`\n\n文件夹内的搜索\n\n> Windows `Control + Shift + F`\n>\n> Mac `⇧+⌘+F`","slug":"IT/Tools/编辑器工具使用技巧汇总","published":1,"updated":"2019-09-01T17:11:47.000Z","_id":"cka1y5983001n4huuemw79ybo","comments":1,"layout":"post","photos":[],"link":"","content":"

VSCode

\n
    \n
  1. Wechseln zwischen Text-Editor und Terminal\n
      \n
    1. Command+K+S oder in Menü Code->Pereferenc->Hotky, öffnet Hot-Key Editor Fenster.
    2. \n
    3. Tip terminal in Suchfeld, findet die Binding `^``, löscht diese Einstellung.
    4. \n
    5. Sucht den “workbench.action.terminal.focus”, bindet es mit Key ⌃<.
    6. \n
    7. Sucht den “workbench.action.focusActiveEditorGroup”, bindet es wiederum mit Schlüssel ⌃<, und Wenn-Kondition “terminalFocus”.
    8. \n
    \n
  2. \n
\n\n

Typora

\n

更多更详细的内容请参阅 Typora Wiki

\n

Typora Wiki (wiki-website Project)

\n

个性化快捷键

\n

Windows

\n

文件—>偏好设置—>往高级设置 ,点击看到两个json格式的文件,打开第二个(conf.user.json), 用记事本打开,第17行keyBinding,在大括号中写 代码块:“你要设置的快捷键”,比如我的是代码块:Ctrl+Alt+P,保存文件,重启typora即可生效。更详细介绍

\n
1
2
3
4
5
6
7
8
// Custom key binding, which will override the default ones.
\"keyBinding\": {
// for example:
// \"Always on Top\": \"Ctrl+Shift+P\"
\"注释\":\"Ctrl+Alt+/\",
\"代码块\":\"Ctrl+Alt+P\",
\"打开文件夹…\":\"Ctrl+Alt+O\"
},
\n

Mac

\n

官方说明

\n

需要到系统偏好设置—>键盘-->快捷键-->应用快捷键那边设置。找到 Typora.App,菜单名称填 代码,然后输入希望的快捷键。我的设置是⌃+⌘+C

\n

更改风格

\n

开发好的工具 如何客制化格式

\n

简单使用:添加 base.user.css 文件,并改变行内代码的颜色,以及公式颜色

\n
1
2
3
4
5
6
7
8
9
# 行内代码
code {
\tcolor: red
}

# 行内公式
.MathJax_SVG{
\tcolor: DarkBlue;
}
\n

Typora的代码使用 CodeMirror 项目,尝试了一下修改 base.user.css 文件确实可以改变代码段的高度,并带滚动。但同时也限定了进行代码编辑时的整个窗口高度。所以没有用

\n
1
2
3
4
5
6
7
8
9
# 缺点:打开源代码模式的时候,整个页面也被限制成了只有300px
.CodeMirror {
max-height: 300px;
}
.CodeMirror-scroll {
overflow-y: auto;
\toverflow-x: auto;
\tmax-height: 300px;
}
\n

注意到书写模式的时候,整个编辑器都被包裹在 <div id="write"> </div> 里面。在源代码模式的时候,没有这个 write 元素的包裹,而整个源代码窗口都被作用为一个 CodeMirror 元素对待。因此,作一些改变就能满足要求

\n
1
2
3
4
5
6
7
8
9
10
11
#write .CodeMirror {
max-height: 350px;
}
# 设定上下 padding 会让滚动条在小代码区消失
#write .CodeMirror-scroll {
overflow-y: auto;
\toverflow-x: auto;
\tmax-height: 330px;
\tpadding-top: 10px;
\tpadding-bottom: 10px;
}
\n
1
# 避免只有一行的代码区,因为会显示滚动条,不好看。一行代码就用行内代码好了。
\n

如果要限制来自 GistHub 的代码高度,只能限定其父元素 iframe

\n
1
2
3
iframe {
\tmax-height: 500px;
}
\n

Windows版的 Typora 的数学模块保存在 path/resource/app/lib.asar 压缩文件中。需要用asar解压

\n

如何查看 asar 内部结构

\n

asar 如何加密解密

\n
1
2
3
npm install -g asar
asar extract 压缩文件 解压文件夹
asar pack 文件夹 压缩文件名
\n

文本搜索

\n

打开的单篇文章内搜索:

\n
\n

Windows Control + F

\n

Mac ⌘+F

\n
\n

文件夹内的搜索

\n
\n

Windows Control + Shift + F

\n

Mac ⇧+⌘+F

\n
\n","site":{"data":{}},"excerpt":"

VSCode

\n
    \n
  1. Wechseln zwischen Text-Editor und Terminal\n
      \n
    1. Command+K+S oder in Menü Code->Pereferenc->Hotky, öffnet Hot-Key Editor Fenster.
    2. \n
    3. Tip terminal in Suchfeld, findet die Binding `^``, löscht diese Einstellung.
    4. \n
    5. Sucht den “workbench.action.terminal.focus”, bindet es mit Key ⌃<.
    6. \n
    7. Sucht den “workbench.action.focusActiveEditorGroup”, bindet es wiederum mit Schlüssel ⌃<, und Wenn-Kondition “terminalFocus”.
    8. \n
    \n
  2. \n
","more":"

Typora

\n

更多更详细的内容请参阅 Typora Wiki

\n

Typora Wiki (wiki-website Project)

\n

个性化快捷键

\n

Windows

\n

文件—>偏好设置—>往高级设置 ,点击看到两个json格式的文件,打开第二个(conf.user.json), 用记事本打开,第17行keyBinding,在大括号中写 代码块:“你要设置的快捷键”,比如我的是代码块:Ctrl+Alt+P,保存文件,重启typora即可生效。更详细介绍

\n\n

Mac

\n

官方说明

\n

需要到系统偏好设置—>键盘-->快捷键-->应用快捷键那边设置。找到 Typora.App,菜单名称填 代码,然后输入希望的快捷键。我的设置是⌃+⌘+C

\n

更改风格

\n

开发好的工具 如何客制化格式

\n

简单使用:添加 base.user.css 文件,并改变行内代码的颜色,以及公式颜色

\n\n

Typora的代码使用 CodeMirror 项目,尝试了一下修改 base.user.css 文件确实可以改变代码段的高度,并带滚动。但同时也限定了进行代码编辑时的整个窗口高度。所以没有用

\n\n

注意到书写模式的时候,整个编辑器都被包裹在 <div id="write"> </div> 里面。在源代码模式的时候,没有这个 write 元素的包裹,而整个源代码窗口都被作用为一个 CodeMirror 元素对待。因此,作一些改变就能满足要求

\n\n\n

如果要限制来自 GistHub 的代码高度,只能限定其父元素 iframe

\n\n

Windows版的 Typora 的数学模块保存在 path/resource/app/lib.asar 压缩文件中。需要用asar解压

\n

如何查看 asar 内部结构

\n

asar 如何加密解密

\n\n

文本搜索

\n

打开的单篇文章内搜索:

\n
\n

Windows Control + F

\n

Mac ⌘+F

\n
\n

文件夹内的搜索

\n
\n

Windows Control + Shift + F

\n

Mac ⇧+⌘+F

\n
"},{"title":"配置服务器端MySQL","date":"2019-08-06T15:26:28.000Z","urlname":"config-mysql-access-privileges-on-vps","toc":true,"notshow":true,"_content":"\n[文章](https://blog.csdn.net/bird3014/article/details/78481104)\n\n###### 问题一:端口状态\n\n1. 查看 3306 端口状态 `sudo netstat -an | grep 3306`\n\n> tcp 0 0 127.0.0.1:3306 0.0.0.0:* \n\n3306端口是默认绑定在本地IP 127.0.0.1上的,所以外网无法访问该主机的3306端口。 \n打开MySQL的配置文件:`sudo vim /etc/mysql/mysql.conf.d/mysqld.cnf`\n\n2. 找到如下内容的一行并注释掉:\n\n> bind-address = 127.0.0.1\n\n3. 重启MySQL服务\n\n> sudo systemctl restart mysql\n\n然后使用如下命令查看端口绑定状态\n\n> `sudo netstat -an | grep 3306`\n\n----\n\n###### 问题二:用户权限\n\n查看用户权限\n\n```mysql\nsudo mysql -uroot -p[你的密码]\nuse mysql\nselect user,host from user\n```\n\n当显示如下,表示用户root只允许内网访问\n\n> root localhost\n\n给用户授权\n\n```mysql\ngrant all privileges on *.* to 'root'@'[允许的ip]' identified by '[密码]' with grant option;\nflush privileges;\n```\n\n其中*`[允许的ip]`*如果设置为**%**的话则表示所有$ip$都可以访问,*`[密码]`*表示外网访问的密码是什么。比如我设置成所有$ip$都可访问,密码是$root$,则命令如下:\n\n```mysql\ngrant all privileges on *.* to 'root'@'%' identified by 'root' with grant option;\nflush privileges;\nselect user,host from user;\n```\n\n重新查看,会显示 \n\n> root %\n>\n> root localhost\n\n\n\n###### 安装 phpMyAdmin\n\n","source":"_posts/IT/Tools/配置服务器端MySQL.md","raw":"---\ntitle: 配置服务器端MySQL\ndate: 2019-08-06 17:26:28\nurlname: config-mysql-access-privileges-on-vps\ntoc: true\ntags: [工具]\ncategories: [IT, Tools]\nnotshow: true\n\n---\n\n[文章](https://blog.csdn.net/bird3014/article/details/78481104)\n\n###### 问题一:端口状态\n\n1. 查看 3306 端口状态 `sudo netstat -an | grep 3306`\n\n> tcp 0 0 127.0.0.1:3306 0.0.0.0:* \n\n3306端口是默认绑定在本地IP 127.0.0.1上的,所以外网无法访问该主机的3306端口。 \n打开MySQL的配置文件:`sudo vim /etc/mysql/mysql.conf.d/mysqld.cnf`\n\n2. 找到如下内容的一行并注释掉:\n\n> bind-address = 127.0.0.1\n\n3. 重启MySQL服务\n\n> sudo systemctl restart mysql\n\n然后使用如下命令查看端口绑定状态\n\n> `sudo netstat -an | grep 3306`\n\n----\n\n###### 问题二:用户权限\n\n查看用户权限\n\n```mysql\nsudo mysql -uroot -p[你的密码]\nuse mysql\nselect user,host from user\n```\n\n当显示如下,表示用户root只允许内网访问\n\n> root localhost\n\n给用户授权\n\n```mysql\ngrant all privileges on *.* to 'root'@'[允许的ip]' identified by '[密码]' with grant option;\nflush privileges;\n```\n\n其中*`[允许的ip]`*如果设置为**%**的话则表示所有$ip$都可以访问,*`[密码]`*表示外网访问的密码是什么。比如我设置成所有$ip$都可访问,密码是$root$,则命令如下:\n\n```mysql\ngrant all privileges on *.* to 'root'@'%' identified by 'root' with grant option;\nflush privileges;\nselect user,host from user;\n```\n\n重新查看,会显示 \n\n> root %\n>\n> root localhost\n\n\n\n###### 安装 phpMyAdmin\n\n","slug":"IT/Tools/配置服务器端MySQL","published":1,"updated":"2019-08-14T13:10:45.000Z","_id":"cka1y5986001p4huuxt1btjua","comments":1,"layout":"post","photos":[],"link":"","content":"

文章

\n
问题一:端口状态
\n
    \n
  1. 查看 3306 端口状态 sudo netstat -an | grep 3306
  2. \n
\n
\n

tcp 0 0 127.0.0.1:3306 0.0.0.0:*

\n
\n

3306端口是默认绑定在本地IP 127.0.0.1上的,所以外网无法访问该主机的3306端口。
\n打开MySQL的配置文件:sudo vim /etc/mysql/mysql.conf.d/mysqld.cnf

\n
    \n
  1. 找到如下内容的一行并注释掉:
  2. \n
\n
\n

bind-address = 127.0.0.1

\n
\n
    \n
  1. 重启MySQL服务
  2. \n
\n
\n

sudo systemctl restart mysql

\n
\n

然后使用如下命令查看端口绑定状态

\n
\n

sudo netstat -an | grep 3306

\n
\n
\n
问题二:用户权限
\n

查看用户权限

\n
1
2
3
sudo mysql -uroot -p[你的密码]
use mysql
select user,host from user
\n

当显示如下,表示用户root只允许内网访问

\n
\n

root localhost

\n
\n

给用户授权

\n
1
2
grant all privileges on *.* to 'root'@'[允许的ip]' identified by '[密码]' with grant option;
flush privileges;
\n

其中*[允许的ip]如果设置为*%**的话则表示所有$ip$都可以访问,*[密码]*表示外网访问的密码是什么。比如我设置成所有$ip$都可访问,密码是$root$,则命令如下:

\n
1
2
3
grant all privileges on *.* to 'root'@'%' identified by 'root' with grant option;
flush privileges;
select user,host from user;
\n

重新查看,会显示

\n
\n

root %

\n

root localhost

\n
\n
安装 phpMyAdmin
\n","site":{"data":{}},"excerpt":"","more":"

文章

\n
问题一:端口状态
\n
    \n
  1. 查看 3306 端口状态 sudo netstat -an | grep 3306
  2. \n
\n
\n

tcp 0 0 127.0.0.1:3306 0.0.0.0:*

\n
\n

3306端口是默认绑定在本地IP 127.0.0.1上的,所以外网无法访问该主机的3306端口。
\n打开MySQL的配置文件:sudo vim /etc/mysql/mysql.conf.d/mysqld.cnf

\n
    \n
  1. 找到如下内容的一行并注释掉:
  2. \n
\n
\n

bind-address = 127.0.0.1

\n
\n
    \n
  1. 重启MySQL服务
  2. \n
\n
\n

sudo systemctl restart mysql

\n
\n

然后使用如下命令查看端口绑定状态

\n
\n

sudo netstat -an | grep 3306

\n
\n
\n
问题二:用户权限
\n

查看用户权限

\n\n

当显示如下,表示用户root只允许内网访问

\n
\n

root localhost

\n
\n

给用户授权

\n\n

其中*[允许的ip]如果设置为*%**的话则表示所有$ip$都可以访问,*[密码]*表示外网访问的密码是什么。比如我设置成所有$ip$都可访问,密码是$root$,则命令如下:

\n\n

重新查看,会显示

\n
\n

root %

\n

root localhost

\n
\n
安装 phpMyAdmin
\n"},{"title":"Next以及wikitten主题添加内容折叠","date":"2019-07-23T18:29:33.000Z","urlname":"next-collapse-block","toc":true,"_content":"\n# 添加代码\n\n当有大段的代码直接展示在页面时,看起来臃肿且不便于观看,此时将代码折叠式最好的选择。下面是在Hexo的Next主题上添加折叠功能。\n\n\n\n## 在main.js中添加折叠js\n\nNext主题的主要js位于 `themes/next/source/js/src/post-details.js`,在下面添加一下代码段:\n\n```javascript\n$(document).ready(function(){\n $(document).on('click', '.fold_hider', function(){\n $('>.fold', this.parentNode).slideToggle();\n $('>:first', this).toggleClass('open');\n });\n //默认情况下折叠\n $(\"div.fold\").css(\"display\",\"none\");\n});\n```\n\nWikitten 主题添加到 `themes/wikitten/source/js/main.js` 后面。\n\n## 自定义内建标签\n\n在主题scripts下添加一个tags.js,位于`themes/next/scripts/tags.js`\n\n```javascript\n/*\n @haohuawu\n 修复 Nunjucks 的 tag 里写 ```代码块```,最终都会渲染成 undefined 的问题\n https://github.com/hexojs/hexo/issues/2400\n*/\nconst rEscapeContent = /]*)>([\\s\\S]*?)<\\/escape>/g;\nconst placeholder = '\\uFFFD';\nconst rPlaceholder = /(?:<|<)\\!--\\uFFFD(\\d+)--(?:>|>)/g;\nconst cache = [];\nfunction escapeContent(str) {\n return '';\n}\nhexo.extend.filter.register('before_post_render', function(data) {\n data.content = data.content.replace(rEscapeContent, function(match, content) {\n return escapeContent(content);\n });\n return data;\n});\nhexo.extend.filter.register('after_post_render', function(data) {\n data.content = data.content.replace(rPlaceholder, function() {\n return cache[arguments[1]];\n });\n return data;\n});\n```\n\n再继续添加一个fold.js,位于`themes/next/scripts/fold.js`\n\n\n\n```javascript\n/* global hexo */\n// Usage: {% fold ???? %} Something {% endfold %}\nfunction fold (args, content) {\n var text = args[0];\n if(!text) text = \"点击显/隐\";\n return '
' + text + '
\\n' + hexo.render.renderSync({text: content, engine: 'markdown'}) + '\\n
';\n}\nhexo.extend.tag.register('fold', fold, {ends: true});\n```\n\nwikitten主题将这两个文件复制到 `themes/wikitten/scripts` 目录下。\n\n## 添加自定义样式\n\n位于`themes/next/source/css/_custom/custom.styl`\n\n```css\n.hider_title{\n font-family: \"Microsoft Yahei\";\n cursor: pointer;\n color: red;\n}\n.close:after{\n content: \"▼\";\n}\n.open:after{\n content: \"▲\";\n}\n```\n\nwikitten 主题将此代码添加到 `themes/wikitten/source/css/_partial/article.styl` 文件下面。在`next` 主题必须将==color: red==去掉,否则会影响大纲栏的颜色。\n\n## 使用\n\n在我们需要折叠的地方前后添加便签,示例用法:\n\n```\n{% fold 点击显/隐内容 %}\n需要隐藏的内容。。。\n{% endfold %}\n```\n\n\n\n## 参考\n\n[Hexo next博客添加折叠块功能添加折叠代码块](https://blog.rmiao.top/hexo-fold-block/) \n[Next主题实现内容折叠](http://zlingfly.com/2018/09/05/fold-test/) \n[jQuery 实现内容折叠功能](https://www.oyohyee.com/post/Note/fold/)\n\n[Hexo 标签插件 官方](https://hexo.io/zh-cn/docs/tag-plugins.html)\n\n# 实例\n\n## 嵌套代码\n\nSome Content\n\n{% fold 点击显/隐内容 %}\n{% blockquote Mai, Düsseldorf link http://google.de %}\n\n\n\tpo_bfa_swbh_laufbahn\n\t\n\\\n\n{% endblockquote %}\n{% endfold %}\n\n## Hexo 代码方式\n\n{% blockquote David, Levithan %}\nLorem ipsum dolor sit amet, consectetur adipiscing elit. Pellentesque hendrerit lacus ut purus iaculis feugiat. Sed nec tempor elit, quis aliquam neque. Curabitur sed diam eget dolor fermentum semper at eu lorem.\n{% endblockquote %}\n\n{% codeblock KOS xsl http://google.de downloadcode %}\n1 code snippet\n{% endcodeblock %}\n\n## Gist\n\n### Hexo 方式\n\nGist (\"48edcb5cfd92937ae61360b74852d4e1\" 就是id。 而 \"xml\" 是我创建时的文件名)。地址是 git.github.com\n\n{% gist 48edcb5cfd92937ae61360b74852d4e1 xml %}\n\n
\n\n### Javascript 方式\n\n\n\n","source":"_posts/IT/Web/Next主题添加内容折叠.md","raw":"---\ntitle: Next以及wikitten主题添加内容折叠\ndate: 2019-07-23 20:29:33\nurlname: next-collapse-block\ntoc: true\ntags: [Hexo]\ncategories: [IT, Web]\n\n---\n\n# 添加代码\n\n当有大段的代码直接展示在页面时,看起来臃肿且不便于观看,此时将代码折叠式最好的选择。下面是在Hexo的Next主题上添加折叠功能。\n\n\n\n## 在main.js中添加折叠js\n\nNext主题的主要js位于 `themes/next/source/js/src/post-details.js`,在下面添加一下代码段:\n\n```javascript\n$(document).ready(function(){\n $(document).on('click', '.fold_hider', function(){\n $('>.fold', this.parentNode).slideToggle();\n $('>:first', this).toggleClass('open');\n });\n //默认情况下折叠\n $(\"div.fold\").css(\"display\",\"none\");\n});\n```\n\nWikitten 主题添加到 `themes/wikitten/source/js/main.js` 后面。\n\n## 自定义内建标签\n\n在主题scripts下添加一个tags.js,位于`themes/next/scripts/tags.js`\n\n```javascript\n/*\n @haohuawu\n 修复 Nunjucks 的 tag 里写 ```代码块```,最终都会渲染成 undefined 的问题\n https://github.com/hexojs/hexo/issues/2400\n*/\nconst rEscapeContent = /]*)>([\\s\\S]*?)<\\/escape>/g;\nconst placeholder = '\\uFFFD';\nconst rPlaceholder = /(?:<|<)\\!--\\uFFFD(\\d+)--(?:>|>)/g;\nconst cache = [];\nfunction escapeContent(str) {\n return '';\n}\nhexo.extend.filter.register('before_post_render', function(data) {\n data.content = data.content.replace(rEscapeContent, function(match, content) {\n return escapeContent(content);\n });\n return data;\n});\nhexo.extend.filter.register('after_post_render', function(data) {\n data.content = data.content.replace(rPlaceholder, function() {\n return cache[arguments[1]];\n });\n return data;\n});\n```\n\n再继续添加一个fold.js,位于`themes/next/scripts/fold.js`\n\n\n\n```javascript\n/* global hexo */\n// Usage: {% fold ???? %} Something {% endfold %}\nfunction fold (args, content) {\n var text = args[0];\n if(!text) text = \"点击显/隐\";\n return '
' + text + '
\\n' + hexo.render.renderSync({text: content, engine: 'markdown'}) + '\\n
';\n}\nhexo.extend.tag.register('fold', fold, {ends: true});\n```\n\nwikitten主题将这两个文件复制到 `themes/wikitten/scripts` 目录下。\n\n## 添加自定义样式\n\n位于`themes/next/source/css/_custom/custom.styl`\n\n```css\n.hider_title{\n font-family: \"Microsoft Yahei\";\n cursor: pointer;\n color: red;\n}\n.close:after{\n content: \"▼\";\n}\n.open:after{\n content: \"▲\";\n}\n```\n\nwikitten 主题将此代码添加到 `themes/wikitten/source/css/_partial/article.styl` 文件下面。在`next` 主题必须将==color: red==去掉,否则会影响大纲栏的颜色。\n\n## 使用\n\n在我们需要折叠的地方前后添加便签,示例用法:\n\n```\n{% fold 点击显/隐内容 %}\n需要隐藏的内容。。。\n{% endfold %}\n```\n\n\n\n## 参考\n\n[Hexo next博客添加折叠块功能添加折叠代码块](https://blog.rmiao.top/hexo-fold-block/) \n[Next主题实现内容折叠](http://zlingfly.com/2018/09/05/fold-test/) \n[jQuery 实现内容折叠功能](https://www.oyohyee.com/post/Note/fold/)\n\n[Hexo 标签插件 官方](https://hexo.io/zh-cn/docs/tag-plugins.html)\n\n# 实例\n\n## 嵌套代码\n\nSome Content\n\n{% fold 点击显/隐内容 %}\n{% blockquote Mai, Düsseldorf link http://google.de %}\n\n\n\tpo_bfa_swbh_laufbahn\n\t\n\\\n\n{% endblockquote %}\n{% endfold %}\n\n## Hexo 代码方式\n\n{% blockquote David, Levithan %}\nLorem ipsum dolor sit amet, consectetur adipiscing elit. Pellentesque hendrerit lacus ut purus iaculis feugiat. Sed nec tempor elit, quis aliquam neque. Curabitur sed diam eget dolor fermentum semper at eu lorem.\n{% endblockquote %}\n\n{% codeblock KOS xsl http://google.de downloadcode %}\n1 code snippet\n{% endcodeblock %}\n\n## Gist\n\n### Hexo 方式\n\nGist (\"48edcb5cfd92937ae61360b74852d4e1\" 就是id。 而 \"xml\" 是我创建时的文件名)。地址是 git.github.com\n\n{% gist 48edcb5cfd92937ae61360b74852d4e1 xml %}\n\n
\n\n### Javascript 方式\n\n\n\n","slug":"IT/Web/Next主题添加内容折叠","published":1,"updated":"2019-07-31T03:51:34.000Z","_id":"cka1y5988001t4huux85puqey","comments":1,"layout":"post","photos":[],"link":"","content":"

添加代码

\n

当有大段的代码直接展示在页面时,看起来臃肿且不便于观看,此时将代码折叠式最好的选择。下面是在Hexo的Next主题上添加折叠功能。

\n\n

在main.js中添加折叠js

\n

Next主题的主要js位于 themes/next/source/js/src/post-details.js,在下面添加一下代码段:

\n
1
2
3
4
5
6
7
8
$(document).ready(function(){
$(document).on('click', '.fold_hider', function(){
$('>.fold', this.parentNode).slideToggle();
$('>:first', this).toggleClass('open');
});
//默认情况下折叠
$(\"div.fold\").css(\"display\",\"none\");
});
\n

Wikitten 主题添加到 themes/wikitten/source/js/main.js 后面。

\n

自定义内建标签

\n

在主题scripts下添加一个tags.js,位于themes/next/scripts/tags.js

\n
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
/*
@haohuawu
修复 Nunjucks 的 tag 里写 ```代码块```,最终都会渲染成 undefined 的问题
https://github.com/hexojs/hexo/issues/2400
*/
const rEscapeContent = /<escape(?:[^>]*)>([\\s\\S]*?)<\\/escape>/g;
const placeholder = '\\uFFFD';
const rPlaceholder = /(?:<|&lt;)\\!--\\uFFFD(\\d+)--(?:>|&gt;)/g;
const cache = [];
function escapeContent(str) {
return '<!--' + placeholder + (cache.push(str) - 1) + '-->';
}
hexo.extend.filter.register('before_post_render', function(data) {
data.content = data.content.replace(rEscapeContent, function(match, content) {
return escapeContent(content);
});
return data;
});
hexo.extend.filter.register('after_post_render', function(data) {
data.content = data.content.replace(rPlaceholder, function() {
return cache[arguments[1]];
});
return data;
});
\n

再继续添加一个fold.js,位于themes/next/scripts/fold.js

\n
1
2
3
4
5
6
7
8
/* global hexo */
// Usage: {% fold ???? %} Something {% endfold %}
function fold (args, content) {
var text = args[0];
if(!text) text = \"点击显/隐\";
return '<div><div class=\"fold_hider\"><div class=\"close hider_title\">' + text + '</div></div><div class=\"fold\">\\n' + hexo.render.renderSync({text: content, engine: 'markdown'}) + '\\n</div></div>';
}
hexo.extend.tag.register('fold', fold, {ends: true});
\n

wikitten主题将这两个文件复制到 themes/wikitten/scripts 目录下。

\n

添加自定义样式

\n

位于themes/next/source/css/_custom/custom.styl

\n
1
2
3
4
5
6
7
8
9
10
11
.hider_title{
font-family: \"Microsoft Yahei\";
cursor: pointer;
color: red;
}
.close:after{
content: \"▼\";
}
.open:after{
content: \"▲\";
}
\n

wikitten 主题将此代码添加到 themes/wikitten/source/css/_partial/article.styl 文件下面。在next 主题必须将==color: red==去掉,否则会影响大纲栏的颜色。

\n

使用

\n

在我们需要折叠的地方前后添加便签,示例用法:

\n
1
2
3
{% fold 点击显/隐内容 %}
需要隐藏的内容。。。
{% endfold %}
\n

参考

\n

Hexo next博客添加折叠块功能添加折叠代码块
\nNext主题实现内容折叠
\njQuery 实现内容折叠功能

\n

Hexo 标签插件 官方

\n

实例

\n

嵌套代码

\n

Some Content

\n
点击显/隐内容
\n

<xsl:call-template name=“SetGlobaleVariable”>
\n<xsl:with-param name=“name-variable”>po_bfa_swbh_laufbahn</xsl:with-param>
\n<xsl:with-param name=“wert-variable” select="$bf_laufbahnzulage"/>
\n</xsl:call-template>

\n
\n
\n

Hexo 代码方式

\n

Lorem ipsum dolor sit amet, consectetur adipiscing elit. Pellentesque hendrerit lacus ut purus iaculis feugiat. Sed nec tempor elit, quis aliquam neque. Curabitur sed diam eget dolor fermentum semper at eu lorem.

\n
DavidLevithan
\n
KOS xsldownloadcode
1
1 code snippet
\n

Gist

\n

Hexo 方式

\n

Gist (“48edcb5cfd92937ae61360b74852d4e1” 就是id。 而 “xml” 是我创建时的文件名)。地址是 git.github.com

\n\n
\n

Javascript 方式

\n\n","site":{"data":{}},"excerpt":"

添加代码

\n

当有大段的代码直接展示在页面时,看起来臃肿且不便于观看,此时将代码折叠式最好的选择。下面是在Hexo的Next主题上添加折叠功能。

","more":"

在main.js中添加折叠js

\n

Next主题的主要js位于 themes/next/source/js/src/post-details.js,在下面添加一下代码段:

\n\n

Wikitten 主题添加到 themes/wikitten/source/js/main.js 后面。

\n

自定义内建标签

\n

在主题scripts下添加一个tags.js,位于themes/next/scripts/tags.js

\n\n

再继续添加一个fold.js,位于themes/next/scripts/fold.js

\n\n

wikitten主题将这两个文件复制到 themes/wikitten/scripts 目录下。

\n

添加自定义样式

\n

位于themes/next/source/css/_custom/custom.styl

\n\n

wikitten 主题将此代码添加到 themes/wikitten/source/css/_partial/article.styl 文件下面。在next 主题必须将==color: red==去掉,否则会影响大纲栏的颜色。

\n

使用

\n

在我们需要折叠的地方前后添加便签,示例用法:

\n\n

参考

\n

Hexo next博客添加折叠块功能添加折叠代码块
\nNext主题实现内容折叠
\njQuery 实现内容折叠功能

\n

Hexo 标签插件 官方

\n

实例

\n

嵌套代码

\n

Some Content

\n
点击显/隐内容
\n

<xsl:call-template name=“SetGlobaleVariable”>
\n<xsl:with-param name=“name-variable”>po_bfa_swbh_laufbahn</xsl:with-param>
\n<xsl:with-param name=“wert-variable” select="$bf_laufbahnzulage"/>
\n</xsl:call-template>

\n
\n
\n

Hexo 代码方式

\n

Lorem ipsum dolor sit amet, consectetur adipiscing elit. Pellentesque hendrerit lacus ut purus iaculis feugiat. Sed nec tempor elit, quis aliquam neque. Curabitur sed diam eget dolor fermentum semper at eu lorem.

\n
DavidLevithan
\n
KOS xsldownloadcode
1
1 code snippet
\n

Gist

\n

Hexo 方式

\n

Gist (“48edcb5cfd92937ae61360b74852d4e1” 就是id。 而 “xml” 是我创建时的文件名)。地址是 git.github.com

\n\n
\n

Javascript 方式

\n"},{"title":"同步Hexo文章与Mac上原笔记的分类和标签","date":"2019-08-01T15:30:00.000Z","urlname":"synchron-the-tag-and-categories-btw-pc-hexo","toc":true,"_content":"\n\n\n最近才搞明白,原来**Hexo**博客的`_post`文件夹里面的Markdown原文件是可以按照分级嵌套的目录结构摆放的。编译的时候才放到**public**这个单一目录下。如果能让文章在Hexo的==分类==严格跟md文件的存储目录一一对应,将来需要找原文件的时侯会方便很多。😄\n\n\n\n使用**Mac**系统的同学也知道,mac有个很风骚的操作,就是给文件分配不同颜色的标签,非常方便文件寻找。我也希望博客上的文章标签,能跟Mac系统里的标签统一起来。:smile: \n\n\n\n实现物理存储目录与`Hexo分类`统一很简单,将源md文件的相对存储路径写到文件meta元素的`categories`里面就行了。比如源文件放在`我的博客-->IT-->前端`,文章的头文件就写成这样:`categories:[IT, 前端]`。\n\n\n\n实现标签的统一稍微麻烦一点,需要先读取文件实际分配到的标签。网上已经有一个公开的项目, [tag](https://github.com/jdberry/tag) 。下载并安装,就可以通过 `tag` 命令读取文件和文件夹的标签。\n\n```sh\n# 安装\nbrew install tag\n# 查看版本\ntag --version\n# 读取文件标签\ntag --list fileUrl\n```\n\n\n\n我已经写好了相应的脚本文件,下载并执行脚本文件就好了。脚本文件里的`dirPath`变量是我的统一存放md源文件的文件夹,你需要改成自己的存放路径,那样就不用每次运行的时候输入一遍。\n\n> 我在Hexo项目的根目录新添一个文件夹专门存放管理的脚本文件,每次都在终端运行这个脚本,所以默认执行路径是 `./source/_post`。\n\n\n\n运行脚本的时候可以设定时间参数,过滤掉太久远的文件。默认情况不会更改文件内容,只查看文件的实际分类和标签是否与文内头文件相同。然后按照给出的列表手动更改。如果想让程序自动更改,按照提示输入`fix`参数就好。\n\n","source":"_posts/IT/Web/同步Hexo文章与Mac上原笔记的分类和标签.md","raw":"---\ntitle: 同步Hexo文章与Mac上原笔记的分类和标签\ndate: 2019-08-01 17:30:00\nurlname: synchron-the-tag-and-categories-btw-pc-hexo\ntoc: true\ntags: [Hexo, Mac]\ncategories: [IT, Web]\n---\n\n\n\n最近才搞明白,原来**Hexo**博客的`_post`文件夹里面的Markdown原文件是可以按照分级嵌套的目录结构摆放的。编译的时候才放到**public**这个单一目录下。如果能让文章在Hexo的==分类==严格跟md文件的存储目录一一对应,将来需要找原文件的时侯会方便很多。😄\n\n\n\n使用**Mac**系统的同学也知道,mac有个很风骚的操作,就是给文件分配不同颜色的标签,非常方便文件寻找。我也希望博客上的文章标签,能跟Mac系统里的标签统一起来。:smile: \n\n\n\n实现物理存储目录与`Hexo分类`统一很简单,将源md文件的相对存储路径写到文件meta元素的`categories`里面就行了。比如源文件放在`我的博客-->IT-->前端`,文章的头文件就写成这样:`categories:[IT, 前端]`。\n\n\n\n实现标签的统一稍微麻烦一点,需要先读取文件实际分配到的标签。网上已经有一个公开的项目, [tag](https://github.com/jdberry/tag) 。下载并安装,就可以通过 `tag` 命令读取文件和文件夹的标签。\n\n```sh\n# 安装\nbrew install tag\n# 查看版本\ntag --version\n# 读取文件标签\ntag --list fileUrl\n```\n\n\n\n我已经写好了相应的脚本文件,下载并执行脚本文件就好了。脚本文件里的`dirPath`变量是我的统一存放md源文件的文件夹,你需要改成自己的存放路径,那样就不用每次运行的时候输入一遍。\n\n> 我在Hexo项目的根目录新添一个文件夹专门存放管理的脚本文件,每次都在终端运行这个脚本,所以默认执行路径是 `./source/_post`。\n\n\n\n运行脚本的时候可以设定时间参数,过滤掉太久远的文件。默认情况不会更改文件内容,只查看文件的实际分类和标签是否与文内头文件相同。然后按照给出的列表手动更改。如果想让程序自动更改,按照提示输入`fix`参数就好。\n\n","slug":"IT/Web/同步Hexo文章与Mac上原笔记的分类和标签","published":1,"updated":"2019-08-03T12:58:26.000Z","_id":"cka1y598a001v4huunsgdb908","comments":1,"layout":"post","photos":[],"link":"","content":"

最近才搞明白,原来Hexo博客的_post文件夹里面的Markdown原文件是可以按照分级嵌套的目录结构摆放的。编译的时候才放到public这个单一目录下。如果能让文章在Hexo的==分类==严格跟md文件的存储目录一一对应,将来需要找原文件的时侯会方便很多。😄

\n

使用Mac系统的同学也知道,mac有个很风骚的操作,就是给文件分配不同颜色的标签,非常方便文件寻找。我也希望博客上的文章标签,能跟Mac系统里的标签统一起来。:smile:

\n

实现物理存储目录与Hexo分类统一很简单,将源md文件的相对存储路径写到文件meta元素的categories里面就行了。比如源文件放在我的博客-->IT-->前端,文章的头文件就写成这样:categories:[IT, 前端]

\n

实现标签的统一稍微麻烦一点,需要先读取文件实际分配到的标签。网上已经有一个公开的项目, tag 。下载并安装,就可以通过 tag 命令读取文件和文件夹的标签。

\n
1
2
3
4
5
6
# 安装
brew install tag
# 查看版本
tag --version
# 读取文件标签
tag --list fileUrl
\n

我已经写好了相应的脚本文件,下载并执行脚本文件就好了。脚本文件里的dirPath变量是我的统一存放md源文件的文件夹,你需要改成自己的存放路径,那样就不用每次运行的时候输入一遍。

\n
\n

我在Hexo项目的根目录新添一个文件夹专门存放管理的脚本文件,每次都在终端运行这个脚本,所以默认执行路径是 ./source/_post

\n
\n

运行脚本的时候可以设定时间参数,过滤掉太久远的文件。默认情况不会更改文件内容,只查看文件的实际分类和标签是否与文内头文件相同。然后按照给出的列表手动更改。如果想让程序自动更改,按照提示输入fix参数就好。

\n","site":{"data":{}},"excerpt":"","more":"

最近才搞明白,原来Hexo博客的_post文件夹里面的Markdown原文件是可以按照分级嵌套的目录结构摆放的。编译的时候才放到public这个单一目录下。如果能让文章在Hexo的==分类==严格跟md文件的存储目录一一对应,将来需要找原文件的时侯会方便很多。😄

\n

使用Mac系统的同学也知道,mac有个很风骚的操作,就是给文件分配不同颜色的标签,非常方便文件寻找。我也希望博客上的文章标签,能跟Mac系统里的标签统一起来。:smile:

\n

实现物理存储目录与Hexo分类统一很简单,将源md文件的相对存储路径写到文件meta元素的categories里面就行了。比如源文件放在我的博客-->IT-->前端,文章的头文件就写成这样:categories:[IT, 前端]

\n

实现标签的统一稍微麻烦一点,需要先读取文件实际分配到的标签。网上已经有一个公开的项目, tag 。下载并安装,就可以通过 tag 命令读取文件和文件夹的标签。

\n\n

我已经写好了相应的脚本文件,下载并执行脚本文件就好了。脚本文件里的dirPath变量是我的统一存放md源文件的文件夹,你需要改成自己的存放路径,那样就不用每次运行的时候输入一遍。

\n
\n

我在Hexo项目的根目录新添一个文件夹专门存放管理的脚本文件,每次都在终端运行这个脚本,所以默认执行路径是 ./source/_post

\n
\n

运行脚本的时候可以设定时间参数,过滤掉太久远的文件。默认情况不会更改文件内容,只查看文件的实际分类和标签是否与文内头文件相同。然后按照给出的列表手动更改。如果想让程序自动更改,按照提示输入fix参数就好。

\n"},{"title":"如何系统化管理Hexo博客","date":"2019-07-28T19:30:00.000Z","urlname":"how-to-manage-big-hexo-blog","toc":true,"contentpw":123456,"_content":"\n

管理?

\n\n![](https://github.com/maiernte/img/raw/master/fun/what.jpg)\n\n\n\n# 建立博客的初衷\n虽说这篇笔记的题目是「如何管理」,为了更好的回答这个问题,必须要回到最原始问题上来——我为何要建一个博客,而且是费那么大劲。而我的初衷是建立和维护一个属于自己的「知识库」。通常来说,为了达成这个目的,更好的选择是笔记APP,而不是博客。我确实也是这么做的。一开始用印象笔记,因为它死活不支持多级目录,我又转到国内的为知笔记,做了五年的VIP用户。但它五年来似乎从没改进过。随着近年来有道云异军突起,以及IOS生态圈中琳琅满目的APP,如熊掌记、Notion、谷歌的Keep、阿里的语雀。。。。。。各有各的惊艳,各有各的槽点。\n\n随着国外的Github和国内的Coding等公司,相继开放永久免费、不限流量的静态网页托管平台,如Github Pages。我走上了自建Bolg的不归路。当然不是说,搭博客这条路完全没有槽点。而是——自己造的孽,含着泪也会继续造下去。至少它满足了我以下几点「必不可少」的要求:\n\n- [x] 多级目录\n- [x] 支持Markdown文本\n- [x] 支持分类、标签、以及站内全文检索\n- [x] 没有IOS、Windows、Android等平台限制\n\n说白了,我是利用Github提供的免费平台,把Blog当笔记本来用。最后选了Hexo,简单易用、界面绚丽、插件丰富。除开自用的「知识平台」功能以外,偶尔还能发发博文装大尾巴狼,也是蛮不错的感觉。\n\n网上介绍怎么搭建Hexo以及添加绚丽功能的帖子海了去了,但我基本没有发现分享「如何管理」的。因为绝大多数这些博主,搭建Hexo只是用来玩一阵子。回头有更新更好玩的东西,就跑去玩别的了。极少数有博客,站内文章超过50篇的。所以,对他们来说,根本不存在——管理——这个议题。\n\n虽然Hexo在逻辑上支持`分类`和`标签`,但物理上它把所有的Post都放到一个单一的目录下面。而我是打算把它当作知识库,长期、密集使用的。可预见的将来,站内笔记会非常多。不但写新贴,还可能经常更改旧贴。那势必会带来一个问题:如何管理数量少日益膨胀的笔记?\n\n# 解决思路\n\n我能想到的办法很简单,也很传统。就是不但逻辑分类,而且也必须物理上分目录存放。理论上在自己的PC分目录保存就好了。但我有好几台电脑,单位一台、自己Windows一台、Mac一台,还有平板。为了让能在不同的电脑上能随时修改、添加笔记,必须放在托管在云端。\n\n## 硬件\n没有必要租用传统的VPS,太贵了,而且连10%的运算能力都用不上。用共享的Web Hosting就完全能解决需求。比如百度云,或者Azure的Web App。而我是租用 1&1 公司的Web Hosting,每个月 1€\n- 1 CPU\n- 500M 内存\n- 20G SSD\n\n就算那么低的运算能力,平时我的网站也用不到25%的运算能力。应付起啦,绰绰有余。\n\n## 软件\n我采用了`MM-Wiki` 管理平台(以下简称维基平台)。这是一个非常优秀的开源项目,具体请参看[作者的文档](https://github.com/phachon/mm-wiki)。部署超级简单,可以说一键部署,然后就可以用起啦了。简单来说这个平台有以下几个特点:\n- [x] 支持空间管理、空间内支持多级目录。\n- [x] 支持Markdown编辑。\n- [x] 支持附件。\n- [x] 有修改记录。\n- [ ] 不支持内容搜索,只支持笔记的题目搜索。\n- [ ] 标签只支持到空间级别,目录和笔记都没有标签。\n\n但它跟Hexo博客搭配使用,就完全满足我的需求了。其实Hexo博客中,有个仿维基的Wikitten主题,跟`MM-Wiki`项目非常像。但毕竟不是所有内容,都适合摆在公开的地方。以`MM-Wiki` 作为私用平台,增加了私隐保护。\n\n我的做法是,在维基平台中开辟一个独立的空间,用来存放博客上所有的源文件。而在Github Pages上托管的静态网站其实都是HTML文件。所有的改动,都必须在源Markdownn文件上修改,然后再推送到博客网站的。\n\n在维基平台修改、添加、删除笔记的源文件。然后复制到Hexo的项目目录,编译后推送到Github Pages站点。维基百科内置的在线版`Editor.md `编辑器,非常美观实用。基本上我都不太需要在自己的电脑上用Typora等编辑器写MD文本了。思路有了,实现起来还是有一点问题。\n\n# 难点的解决办法\n\n首先,在维基平台内,MD文件是分目录存储的。这个目录不能直接拷贝到Hexo的`_post`目录。懒得每修改一个,或者添加一个笔记,就立马拷贝到博客中去。解决笔记复制的问题。\n\n其次,笔记的物理保存目录,**必须**跟Hexo上的「分类」是一一对应的。否则,管理起来会很麻烦。在维基平台移动了笔记的保存目录后,在一一修改内容,也是很吃力的事情。\n\n## 笔记复制的解决办法\n\n说来也超级简单,一个脚本命令就够了。先用`find`命令在指定目录找出所有的MD文件,然后通过管道传给复制命令`cp`,搞定!\n```sh\nfind /root/bibliothek/markdowns/博客草稿/ -type f -name \"*.md\" -exec cp {} /home/_post/ \\;\n```\n然后`hexo d -g`编译、发布,结束!\n\n## 管理笔记的分类\n\n这个问题有一点麻烦。因为必须打开每一个文件,读取笔记的头文件描述,然后再比较跟文件的物理位置是否符合。我尝试用shell脚本解决这难题。无奈我的的shell脚本功底是在很差,搞半天未果就放弃了。用Java或者.NET Core啥的,正儿八经写一个Console程序,也不是不行。但有种杀鸡用牛刀的感觉。\n\n最后想到了用Javascript。因为编译Hexo是需要安装Node.js的,写一段JavaScript,让Node跑起来。通往罗马的道路千万条,选一条自己最熟悉的就完了。\n\n{% fold 点击查看代码 %}\n\n{% endfold %}\n\n> 上面这个脚本使用的都是我个人设置,你如果要用的话需要改成自己实际文件目录。\n\n![](https://github.com/maiernte/img/raw/master/fun/给力.jpg)","source":"_posts/IT/Web/如何系统化管理Hexo博客.md","raw":"---\ntitle: 如何系统化管理Hexo博客\ndate: 2019-07-28 21:30:00\nurlname: how-to-manage-big-hexo-blog\ntoc: true\ncontentpw: 123456\ntags: [Hexo]\ncategories: [IT, Web]\n\n---\n\n

管理?

\n\n![](https://github.com/maiernte/img/raw/master/fun/what.jpg)\n\n\n\n# 建立博客的初衷\n虽说这篇笔记的题目是「如何管理」,为了更好的回答这个问题,必须要回到最原始问题上来——我为何要建一个博客,而且是费那么大劲。而我的初衷是建立和维护一个属于自己的「知识库」。通常来说,为了达成这个目的,更好的选择是笔记APP,而不是博客。我确实也是这么做的。一开始用印象笔记,因为它死活不支持多级目录,我又转到国内的为知笔记,做了五年的VIP用户。但它五年来似乎从没改进过。随着近年来有道云异军突起,以及IOS生态圈中琳琅满目的APP,如熊掌记、Notion、谷歌的Keep、阿里的语雀。。。。。。各有各的惊艳,各有各的槽点。\n\n随着国外的Github和国内的Coding等公司,相继开放永久免费、不限流量的静态网页托管平台,如Github Pages。我走上了自建Bolg的不归路。当然不是说,搭博客这条路完全没有槽点。而是——自己造的孽,含着泪也会继续造下去。至少它满足了我以下几点「必不可少」的要求:\n\n- [x] 多级目录\n- [x] 支持Markdown文本\n- [x] 支持分类、标签、以及站内全文检索\n- [x] 没有IOS、Windows、Android等平台限制\n\n说白了,我是利用Github提供的免费平台,把Blog当笔记本来用。最后选了Hexo,简单易用、界面绚丽、插件丰富。除开自用的「知识平台」功能以外,偶尔还能发发博文装大尾巴狼,也是蛮不错的感觉。\n\n网上介绍怎么搭建Hexo以及添加绚丽功能的帖子海了去了,但我基本没有发现分享「如何管理」的。因为绝大多数这些博主,搭建Hexo只是用来玩一阵子。回头有更新更好玩的东西,就跑去玩别的了。极少数有博客,站内文章超过50篇的。所以,对他们来说,根本不存在——管理——这个议题。\n\n虽然Hexo在逻辑上支持`分类`和`标签`,但物理上它把所有的Post都放到一个单一的目录下面。而我是打算把它当作知识库,长期、密集使用的。可预见的将来,站内笔记会非常多。不但写新贴,还可能经常更改旧贴。那势必会带来一个问题:如何管理数量少日益膨胀的笔记?\n\n# 解决思路\n\n我能想到的办法很简单,也很传统。就是不但逻辑分类,而且也必须物理上分目录存放。理论上在自己的PC分目录保存就好了。但我有好几台电脑,单位一台、自己Windows一台、Mac一台,还有平板。为了让能在不同的电脑上能随时修改、添加笔记,必须放在托管在云端。\n\n## 硬件\n没有必要租用传统的VPS,太贵了,而且连10%的运算能力都用不上。用共享的Web Hosting就完全能解决需求。比如百度云,或者Azure的Web App。而我是租用 1&1 公司的Web Hosting,每个月 1€\n- 1 CPU\n- 500M 内存\n- 20G SSD\n\n就算那么低的运算能力,平时我的网站也用不到25%的运算能力。应付起啦,绰绰有余。\n\n## 软件\n我采用了`MM-Wiki` 管理平台(以下简称维基平台)。这是一个非常优秀的开源项目,具体请参看[作者的文档](https://github.com/phachon/mm-wiki)。部署超级简单,可以说一键部署,然后就可以用起啦了。简单来说这个平台有以下几个特点:\n- [x] 支持空间管理、空间内支持多级目录。\n- [x] 支持Markdown编辑。\n- [x] 支持附件。\n- [x] 有修改记录。\n- [ ] 不支持内容搜索,只支持笔记的题目搜索。\n- [ ] 标签只支持到空间级别,目录和笔记都没有标签。\n\n但它跟Hexo博客搭配使用,就完全满足我的需求了。其实Hexo博客中,有个仿维基的Wikitten主题,跟`MM-Wiki`项目非常像。但毕竟不是所有内容,都适合摆在公开的地方。以`MM-Wiki` 作为私用平台,增加了私隐保护。\n\n我的做法是,在维基平台中开辟一个独立的空间,用来存放博客上所有的源文件。而在Github Pages上托管的静态网站其实都是HTML文件。所有的改动,都必须在源Markdownn文件上修改,然后再推送到博客网站的。\n\n在维基平台修改、添加、删除笔记的源文件。然后复制到Hexo的项目目录,编译后推送到Github Pages站点。维基百科内置的在线版`Editor.md `编辑器,非常美观实用。基本上我都不太需要在自己的电脑上用Typora等编辑器写MD文本了。思路有了,实现起来还是有一点问题。\n\n# 难点的解决办法\n\n首先,在维基平台内,MD文件是分目录存储的。这个目录不能直接拷贝到Hexo的`_post`目录。懒得每修改一个,或者添加一个笔记,就立马拷贝到博客中去。解决笔记复制的问题。\n\n其次,笔记的物理保存目录,**必须**跟Hexo上的「分类」是一一对应的。否则,管理起来会很麻烦。在维基平台移动了笔记的保存目录后,在一一修改内容,也是很吃力的事情。\n\n## 笔记复制的解决办法\n\n说来也超级简单,一个脚本命令就够了。先用`find`命令在指定目录找出所有的MD文件,然后通过管道传给复制命令`cp`,搞定!\n```sh\nfind /root/bibliothek/markdowns/博客草稿/ -type f -name \"*.md\" -exec cp {} /home/_post/ \\;\n```\n然后`hexo d -g`编译、发布,结束!\n\n## 管理笔记的分类\n\n这个问题有一点麻烦。因为必须打开每一个文件,读取笔记的头文件描述,然后再比较跟文件的物理位置是否符合。我尝试用shell脚本解决这难题。无奈我的的shell脚本功底是在很差,搞半天未果就放弃了。用Java或者.NET Core啥的,正儿八经写一个Console程序,也不是不行。但有种杀鸡用牛刀的感觉。\n\n最后想到了用Javascript。因为编译Hexo是需要安装Node.js的,写一段JavaScript,让Node跑起来。通往罗马的道路千万条,选一条自己最熟悉的就完了。\n\n{% fold 点击查看代码 %}\n\n{% endfold %}\n\n> 上面这个脚本使用的都是我个人设置,你如果要用的话需要改成自己实际文件目录。\n\n![](https://github.com/maiernte/img/raw/master/fun/给力.jpg)","slug":"IT/Web/如何系统化管理Hexo博客","published":1,"updated":"2019-08-15T21:51:57.000Z","_id":"cka1y598b001y4huuppnodfz2","comments":1,"layout":"post","photos":[],"link":"","content":"

建立博客的初衷

\n

虽说这篇笔记的题目是「如何管理」,为了更好的回答这个问题,必须要回到最原始问题上来——我为何要建一个博客,而且是费那么大劲。而我的初衷是建立和维护一个属于自己的「知识库」。通常来说,为了达成这个目的,更好的选择是笔记APP,而不是博客。我确实也是这么做的。一开始用印象笔记,因为它死活不支持多级目录,我又转到国内的为知笔记,做了五年的VIP用户。但它五年来似乎从没改进过。随着近年来有道云异军突起,以及IOS生态圈中琳琅满目的APP,如熊掌记、Notion、谷歌的Keep、阿里的语雀。。。。。。各有各的惊艳,各有各的槽点。

\n

随着国外的Github和国内的Coding等公司,相继开放永久免费、不限流量的静态网页托管平台,如Github Pages。我走上了自建Bolg的不归路。当然不是说,搭博客这条路完全没有槽点。而是——自己造的孽,含着泪也会继续造下去。至少它满足了我以下几点「必不可少」的要求:

\n
    \n
  • [x] 多级目录
  • \n
  • [x] 支持Markdown文本
  • \n
  • [x] 支持分类、标签、以及站内全文检索
  • \n
  • [x] 没有IOS、Windows、Android等平台限制
  • \n
\n

说白了,我是利用Github提供的免费平台,把Blog当笔记本来用。最后选了Hexo,简单易用、界面绚丽、插件丰富。除开自用的「知识平台」功能以外,偶尔还能发发博文装大尾巴狼,也是蛮不错的感觉。

\n

网上介绍怎么搭建Hexo以及添加绚丽功能的帖子海了去了,但我基本没有发现分享「如何管理」的。因为绝大多数这些博主,搭建Hexo只是用来玩一阵子。回头有更新更好玩的东西,就跑去玩别的了。极少数有博客,站内文章超过50篇的。所以,对他们来说,根本不存在——管理——这个议题。

\n

虽然Hexo在逻辑上支持分类标签,但物理上它把所有的Post都放到一个单一的目录下面。而我是打算把它当作知识库,长期、密集使用的。可预见的将来,站内笔记会非常多。不但写新贴,还可能经常更改旧贴。那势必会带来一个问题:如何管理数量少日益膨胀的笔记?

\n

解决思路

\n

我能想到的办法很简单,也很传统。就是不但逻辑分类,而且也必须物理上分目录存放。理论上在自己的PC分目录保存就好了。但我有好几台电脑,单位一台、自己Windows一台、Mac一台,还有平板。为了让能在不同的电脑上能随时修改、添加笔记,必须放在托管在云端。

\n

硬件

\n

没有必要租用传统的VPS,太贵了,而且连10%的运算能力都用不上。用共享的Web Hosting就完全能解决需求。比如百度云,或者Azure的Web App。而我是租用 1&1 公司的Web Hosting,每个月 1€

\n
    \n
  • 1 CPU
  • \n
  • 500M 内存
  • \n
  • 20G SSD
  • \n
\n

就算那么低的运算能力,平时我的网站也用不到25%的运算能力。应付起啦,绰绰有余。

\n

软件

\n

我采用了MM-Wiki 管理平台(以下简称维基平台)。这是一个非常优秀的开源项目,具体请参看作者的文档。部署超级简单,可以说一键部署,然后就可以用起啦了。简单来说这个平台有以下几个特点:

\n
    \n
  • [x] 支持空间管理、空间内支持多级目录。
  • \n
  • [x] 支持Markdown编辑。
  • \n
  • [x] 支持附件。
  • \n
  • [x] 有修改记录。
  • \n
  • [ ] 不支持内容搜索,只支持笔记的题目搜索。
  • \n
  • [ ] 标签只支持到空间级别,目录和笔记都没有标签。
  • \n
\n

但它跟Hexo博客搭配使用,就完全满足我的需求了。其实Hexo博客中,有个仿维基的Wikitten主题,跟MM-Wiki项目非常像。但毕竟不是所有内容,都适合摆在公开的地方。以MM-Wiki 作为私用平台,增加了私隐保护。

\n

我的做法是,在维基平台中开辟一个独立的空间,用来存放博客上所有的源文件。而在Github Pages上托管的静态网站其实都是HTML文件。所有的改动,都必须在源Markdownn文件上修改,然后再推送到博客网站的。

\n

在维基平台修改、添加、删除笔记的源文件。然后复制到Hexo的项目目录,编译后推送到Github Pages站点。维基百科内置的在线版Editor.md 编辑器,非常美观实用。基本上我都不太需要在自己的电脑上用Typora等编辑器写MD文本了。思路有了,实现起来还是有一点问题。

\n

难点的解决办法

\n

首先,在维基平台内,MD文件是分目录存储的。这个目录不能直接拷贝到Hexo的_post目录。懒得每修改一个,或者添加一个笔记,就立马拷贝到博客中去。解决笔记复制的问题。

\n

其次,笔记的物理保存目录,必须跟Hexo上的「分类」是一一对应的。否则,管理起来会很麻烦。在维基平台移动了笔记的保存目录后,在一一修改内容,也是很吃力的事情。

\n

笔记复制的解决办法

\n

说来也超级简单,一个脚本命令就够了。先用find命令在指定目录找出所有的MD文件,然后通过管道传给复制命令cp,搞定!

\n
1
find  /root/bibliothek/markdowns/博客草稿/  -type f -name \"*.md\" -exec cp {} /home/_post/ \\;
\n

然后hexo d -g编译、发布,结束!

\n

管理笔记的分类

\n

这个问题有一点麻烦。因为必须打开每一个文件,读取笔记的头文件描述,然后再比较跟文件的物理位置是否符合。我尝试用shell脚本解决这难题。无奈我的的shell脚本功底是在很差,搞半天未果就放弃了。用Java或者.NET Core啥的,正儿八经写一个Console程序,也不是不行。但有种杀鸡用牛刀的感觉。

\n

最后想到了用Javascript。因为编译Hexo是需要安装Node.js的,写一段JavaScript,让Node跑起来。通往罗马的道路千万条,选一条自己最熟悉的就完了。

\n
点击查看代码
\n\n
\n
\n

上面这个脚本使用的都是我个人设置,你如果要用的话需要改成自己实际文件目录。

\n
\n

","site":{"data":{}},"excerpt":"

管理?

\n

","more":"

建立博客的初衷

\n

虽说这篇笔记的题目是「如何管理」,为了更好的回答这个问题,必须要回到最原始问题上来——我为何要建一个博客,而且是费那么大劲。而我的初衷是建立和维护一个属于自己的「知识库」。通常来说,为了达成这个目的,更好的选择是笔记APP,而不是博客。我确实也是这么做的。一开始用印象笔记,因为它死活不支持多级目录,我又转到国内的为知笔记,做了五年的VIP用户。但它五年来似乎从没改进过。随着近年来有道云异军突起,以及IOS生态圈中琳琅满目的APP,如熊掌记、Notion、谷歌的Keep、阿里的语雀。。。。。。各有各的惊艳,各有各的槽点。

\n

随着国外的Github和国内的Coding等公司,相继开放永久免费、不限流量的静态网页托管平台,如Github Pages。我走上了自建Bolg的不归路。当然不是说,搭博客这条路完全没有槽点。而是——自己造的孽,含着泪也会继续造下去。至少它满足了我以下几点「必不可少」的要求:

\n
    \n
  • [x] 多级目录
  • \n
  • [x] 支持Markdown文本
  • \n
  • [x] 支持分类、标签、以及站内全文检索
  • \n
  • [x] 没有IOS、Windows、Android等平台限制
  • \n
\n

说白了,我是利用Github提供的免费平台,把Blog当笔记本来用。最后选了Hexo,简单易用、界面绚丽、插件丰富。除开自用的「知识平台」功能以外,偶尔还能发发博文装大尾巴狼,也是蛮不错的感觉。

\n

网上介绍怎么搭建Hexo以及添加绚丽功能的帖子海了去了,但我基本没有发现分享「如何管理」的。因为绝大多数这些博主,搭建Hexo只是用来玩一阵子。回头有更新更好玩的东西,就跑去玩别的了。极少数有博客,站内文章超过50篇的。所以,对他们来说,根本不存在——管理——这个议题。

\n

虽然Hexo在逻辑上支持分类标签,但物理上它把所有的Post都放到一个单一的目录下面。而我是打算把它当作知识库,长期、密集使用的。可预见的将来,站内笔记会非常多。不但写新贴,还可能经常更改旧贴。那势必会带来一个问题:如何管理数量少日益膨胀的笔记?

\n

解决思路

\n

我能想到的办法很简单,也很传统。就是不但逻辑分类,而且也必须物理上分目录存放。理论上在自己的PC分目录保存就好了。但我有好几台电脑,单位一台、自己Windows一台、Mac一台,还有平板。为了让能在不同的电脑上能随时修改、添加笔记,必须放在托管在云端。

\n

硬件

\n

没有必要租用传统的VPS,太贵了,而且连10%的运算能力都用不上。用共享的Web Hosting就完全能解决需求。比如百度云,或者Azure的Web App。而我是租用 1&1 公司的Web Hosting,每个月 1€

\n
    \n
  • 1 CPU
  • \n
  • 500M 内存
  • \n
  • 20G SSD
  • \n
\n

就算那么低的运算能力,平时我的网站也用不到25%的运算能力。应付起啦,绰绰有余。

\n

软件

\n

我采用了MM-Wiki 管理平台(以下简称维基平台)。这是一个非常优秀的开源项目,具体请参看作者的文档。部署超级简单,可以说一键部署,然后就可以用起啦了。简单来说这个平台有以下几个特点:

\n
    \n
  • [x] 支持空间管理、空间内支持多级目录。
  • \n
  • [x] 支持Markdown编辑。
  • \n
  • [x] 支持附件。
  • \n
  • [x] 有修改记录。
  • \n
  • [ ] 不支持内容搜索,只支持笔记的题目搜索。
  • \n
  • [ ] 标签只支持到空间级别,目录和笔记都没有标签。
  • \n
\n

但它跟Hexo博客搭配使用,就完全满足我的需求了。其实Hexo博客中,有个仿维基的Wikitten主题,跟MM-Wiki项目非常像。但毕竟不是所有内容,都适合摆在公开的地方。以MM-Wiki 作为私用平台,增加了私隐保护。

\n

我的做法是,在维基平台中开辟一个独立的空间,用来存放博客上所有的源文件。而在Github Pages上托管的静态网站其实都是HTML文件。所有的改动,都必须在源Markdownn文件上修改,然后再推送到博客网站的。

\n

在维基平台修改、添加、删除笔记的源文件。然后复制到Hexo的项目目录,编译后推送到Github Pages站点。维基百科内置的在线版Editor.md 编辑器,非常美观实用。基本上我都不太需要在自己的电脑上用Typora等编辑器写MD文本了。思路有了,实现起来还是有一点问题。

\n

难点的解决办法

\n

首先,在维基平台内,MD文件是分目录存储的。这个目录不能直接拷贝到Hexo的_post目录。懒得每修改一个,或者添加一个笔记,就立马拷贝到博客中去。解决笔记复制的问题。

\n

其次,笔记的物理保存目录,必须跟Hexo上的「分类」是一一对应的。否则,管理起来会很麻烦。在维基平台移动了笔记的保存目录后,在一一修改内容,也是很吃力的事情。

\n

笔记复制的解决办法

\n

说来也超级简单,一个脚本命令就够了。先用find命令在指定目录找出所有的MD文件,然后通过管道传给复制命令cp,搞定!

\n\n

然后hexo d -g编译、发布,结束!

\n

管理笔记的分类

\n

这个问题有一点麻烦。因为必须打开每一个文件,读取笔记的头文件描述,然后再比较跟文件的物理位置是否符合。我尝试用shell脚本解决这难题。无奈我的的shell脚本功底是在很差,搞半天未果就放弃了。用Java或者.NET Core啥的,正儿八经写一个Console程序,也不是不行。但有种杀鸡用牛刀的感觉。

\n

最后想到了用Javascript。因为编译Hexo是需要安装Node.js的,写一段JavaScript,让Node跑起来。通往罗马的道路千万条,选一条自己最熟悉的就完了。

\n
点击查看代码
\n\n
\n
\n

上面这个脚本使用的都是我个人设置,你如果要用的话需要改成自己实际文件目录。

\n
\n

"},{"title":"还在用七牛?","date":"2019-08-14T21:41:28.000Z","urlname":"still-using-qiniu","toc":true,"_content":"\n\n\n自从七牛换了服务条款,每个空间就只分配测试域名, 30天到期。想省钱的用户,必须每30天倒腾一次。如果忘记了,过了期限,据说图都找不回来。不想费那个劲的用户, 得绑定自己的域名。 这样不但增加费用,还要考虑到域名备案。 十分麻烦。\n\n\n\n这是我弃用七牛的主要原因。 第二个原因就是——`慢`! 也许我人在国外的原因吧, 每次打开七牛的后台,刷好几遍都打不开对象存储的页面,只能用第三方软件进行上传下载,那样会相对好一些.\n\n\n\n第三个原因是七牛的图床不能分目录存储。 当图片越积越多的时候,管理和查找起来非常麻烦。比如我昨天用Typora的Pandoc功能将一个Word技术文档转换成MD文件,一个文件就有100来张图。放在七牛得分好几页显示了。如果再想找别的图, 那得多费劲.\n\n\n\n后来还是把心思用在了Github上。 在自己的账号下新开一个仓库, 然后在自己的本地电脑专建立一个文件夹, 用来存放MD文档或者博客中使用到的图片, 把这个专门的文件夹推送到新的仓库就完了! 相比七牛, Github还有不少优势:\n\n- **可以分多级目录存储** \n- **传输速度快** !(*可能国内慢吧, 但国内可以同样的思路, 放到 Coding 或者 CSDN 上* )\n- **免费** \n- **不限流量** \n\n\n\n还要我说啥呢? \n\n\n\n但引用Github图片, 要做一个小小的改动. 比如Github上一个图片的原始地址是:\n\n> https://github.com/maiernte/img/blob/master/books/ng-book2-71/image100.png\n\n需要把其中的 `blob` 改成 `raw`, 变成\n\n> https://github.com/maiernte/img/raw/master/books/ng-book2-71/image100.png\n\n\n\n自打有了Github这个神器, 可以跟七牛说再见! 再也不见!","source":"_posts/IT/skill/还在用七牛.md","raw":"---\ntitle: 还在用七牛?\ndate: 2019-08-14 23:41:28\nurlname: still-using-qiniu\ntoc: true\ntags: [工具]\ncategories: [IT, skill]\n\n---\n\n\n\n自从七牛换了服务条款,每个空间就只分配测试域名, 30天到期。想省钱的用户,必须每30天倒腾一次。如果忘记了,过了期限,据说图都找不回来。不想费那个劲的用户, 得绑定自己的域名。 这样不但增加费用,还要考虑到域名备案。 十分麻烦。\n\n\n\n这是我弃用七牛的主要原因。 第二个原因就是——`慢`! 也许我人在国外的原因吧, 每次打开七牛的后台,刷好几遍都打不开对象存储的页面,只能用第三方软件进行上传下载,那样会相对好一些.\n\n\n\n第三个原因是七牛的图床不能分目录存储。 当图片越积越多的时候,管理和查找起来非常麻烦。比如我昨天用Typora的Pandoc功能将一个Word技术文档转换成MD文件,一个文件就有100来张图。放在七牛得分好几页显示了。如果再想找别的图, 那得多费劲.\n\n\n\n后来还是把心思用在了Github上。 在自己的账号下新开一个仓库, 然后在自己的本地电脑专建立一个文件夹, 用来存放MD文档或者博客中使用到的图片, 把这个专门的文件夹推送到新的仓库就完了! 相比七牛, Github还有不少优势:\n\n- **可以分多级目录存储** \n- **传输速度快** !(*可能国内慢吧, 但国内可以同样的思路, 放到 Coding 或者 CSDN 上* )\n- **免费** \n- **不限流量** \n\n\n\n还要我说啥呢? \n\n\n\n但引用Github图片, 要做一个小小的改动. 比如Github上一个图片的原始地址是:\n\n> https://github.com/maiernte/img/blob/master/books/ng-book2-71/image100.png\n\n需要把其中的 `blob` 改成 `raw`, 变成\n\n> https://github.com/maiernte/img/raw/master/books/ng-book2-71/image100.png\n\n\n\n自打有了Github这个神器, 可以跟七牛说再见! 再也不见!","slug":"IT/skill/还在用七牛","published":1,"updated":"2019-08-15T06:54:53.000Z","_id":"cka1y598d00214huuioh2rw8e","comments":1,"layout":"post","photos":[],"link":"","content":"

自从七牛换了服务条款,每个空间就只分配测试域名, 30天到期。想省钱的用户,必须每30天倒腾一次。如果忘记了,过了期限,据说图都找不回来。不想费那个劲的用户, 得绑定自己的域名。 这样不但增加费用,还要考虑到域名备案。 十分麻烦。

\n\n

这是我弃用七牛的主要原因。 第二个原因就是——! 也许我人在国外的原因吧, 每次打开七牛的后台,刷好几遍都打不开对象存储的页面,只能用第三方软件进行上传下载,那样会相对好一些.

\n

第三个原因是七牛的图床不能分目录存储。 当图片越积越多的时候,管理和查找起来非常麻烦。比如我昨天用Typora的Pandoc功能将一个Word技术文档转换成MD文件,一个文件就有100来张图。放在七牛得分好几页显示了。如果再想找别的图, 那得多费劲.

\n

后来还是把心思用在了Github上。 在自己的账号下新开一个仓库, 然后在自己的本地电脑专建立一个文件夹, 用来存放MD文档或者博客中使用到的图片, 把这个专门的文件夹推送到新的仓库就完了! 相比七牛, Github还有不少优势:

\n
    \n
  • 可以分多级目录存储
  • \n
  • 传输速度快 !(可能国内慢吧, 但国内可以同样的思路, 放到 Coding 或者 CSDN 上 )
  • \n
  • 免费
  • \n
  • 不限流量
  • \n
\n

还要我说啥呢?

\n

但引用Github图片, 要做一个小小的改动. 比如Github上一个图片的原始地址是:

\n
\n

https://github.com/maiernte/img/blob/master/books/ng-book2-71/image100.png

\n
\n

需要把其中的 blob 改成 raw, 变成

\n
\n

https://github.com/maiernte/img/raw/master/books/ng-book2-71/image100.png

\n
\n

自打有了Github这个神器, 可以跟七牛说再见! 再也不见!

\n","site":{"data":{}},"excerpt":"

自从七牛换了服务条款,每个空间就只分配测试域名, 30天到期。想省钱的用户,必须每30天倒腾一次。如果忘记了,过了期限,据说图都找不回来。不想费那个劲的用户, 得绑定自己的域名。 这样不但增加费用,还要考虑到域名备案。 十分麻烦。

","more":"

这是我弃用七牛的主要原因。 第二个原因就是——! 也许我人在国外的原因吧, 每次打开七牛的后台,刷好几遍都打不开对象存储的页面,只能用第三方软件进行上传下载,那样会相对好一些.

\n

第三个原因是七牛的图床不能分目录存储。 当图片越积越多的时候,管理和查找起来非常麻烦。比如我昨天用Typora的Pandoc功能将一个Word技术文档转换成MD文件,一个文件就有100来张图。放在七牛得分好几页显示了。如果再想找别的图, 那得多费劲.

\n

后来还是把心思用在了Github上。 在自己的账号下新开一个仓库, 然后在自己的本地电脑专建立一个文件夹, 用来存放MD文档或者博客中使用到的图片, 把这个专门的文件夹推送到新的仓库就完了! 相比七牛, Github还有不少优势:

\n
    \n
  • 可以分多级目录存储
  • \n
  • 传输速度快 !(可能国内慢吧, 但国内可以同样的思路, 放到 Coding 或者 CSDN 上 )
  • \n
  • 免费
  • \n
  • 不限流量
  • \n
\n

还要我说啥呢?

\n

但引用Github图片, 要做一个小小的改动. 比如Github上一个图片的原始地址是:

\n
\n

https://github.com/maiernte/img/blob/master/books/ng-book2-71/image100.png

\n
\n

需要把其中的 blob 改成 raw, 变成

\n
\n

https://github.com/maiernte/img/raw/master/books/ng-book2-71/image100.png

\n
\n

自打有了Github这个神器, 可以跟七牛说再见! 再也不见!

"},{"title":"佛偈集合","date":"2019-07-29T07:10:50.000Z","urlname":"budahlisisch-poeim-collection","toc":true,"notshow":false,"_content":"\n
佛偈(jì)
\n\n\n![](https://raw.githubusercontent.com/maiernte/img/master/collection/tempel_3.jpg)\n\n\n\n虚云老和尚悟道偈\n\n杯子扑落地,响声明历历。\n虚空粉碎也,狂心当下息。\n\n烫着手,打碎杯,家破人亡语难开。\n春到花香处处秀,山河大地是如来。\n\n\n\n###### 布袋和尚\n\n手把青秧插满田,低头便见水中天。\n心地清净方为道,退步原来是向前。\n\n###### 赠药山高僧惟俨\n\n练得身形似鹤形,千株松下两函经。\n我来问道无馀说,云在青天水在瓶。\n\n——李翱 \n\n###### 牛头山法融禅师\n\n恰恰用心时,恰恰无心用。曲谭名相劳,直说无繁重。\n无心恰恰用,常用恰恰无。今说无心处,不与有心殊。\n\n——唐永徽年中\n\n###### 天衣义怀禅师\n\n雁过长空,影沉寒底,雁无留影之心,影无遗踪之意。\n\n> 《菜根谭》中的一句古诗:“风来疏竹,风过而竹不留声;雁渡寒潭,雁过而潭不留影。\n>\n> 另一版本:竹影扫阶尘不动,雁过寒潭水无痕。\n\n","source":"_posts/摘录/片段/佛偈集合.md","raw":"---\ntitle: 佛偈集合\ndate: 2019-07-29 09:10:50\nurlname: budahlisisch-poeim-collection\ntoc: true\ntags: [文学]\ncategories: [摘录, 片段]\nnotshow: false\n\n---\n\n
佛偈(jì)
\n\n\n![](https://raw.githubusercontent.com/maiernte/img/master/collection/tempel_3.jpg)\n\n\n\n虚云老和尚悟道偈\n\n杯子扑落地,响声明历历。\n虚空粉碎也,狂心当下息。\n\n烫着手,打碎杯,家破人亡语难开。\n春到花香处处秀,山河大地是如来。\n\n\n\n###### 布袋和尚\n\n手把青秧插满田,低头便见水中天。\n心地清净方为道,退步原来是向前。\n\n###### 赠药山高僧惟俨\n\n练得身形似鹤形,千株松下两函经。\n我来问道无馀说,云在青天水在瓶。\n\n——李翱 \n\n###### 牛头山法融禅师\n\n恰恰用心时,恰恰无心用。曲谭名相劳,直说无繁重。\n无心恰恰用,常用恰恰无。今说无心处,不与有心殊。\n\n——唐永徽年中\n\n###### 天衣义怀禅师\n\n雁过长空,影沉寒底,雁无留影之心,影无遗踪之意。\n\n> 《菜根谭》中的一句古诗:“风来疏竹,风过而竹不留声;雁渡寒潭,雁过而潭不留影。\n>\n> 另一版本:竹影扫阶尘不动,雁过寒潭水无痕。\n\n","slug":"摘录/片段/佛偈集合","published":1,"updated":"2019-08-15T21:46:14.000Z","_id":"cka1y598f00254huufdsy7udi","comments":1,"layout":"post","photos":[],"link":"","content":"
佛偈(jì)
\n

\n

虚云老和尚悟道偈

\n

杯子扑落地,响声明历历。
\n虚空粉碎也,狂心当下息。

\n

烫着手,打碎杯,家破人亡语难开。
\n春到花香处处秀,山河大地是如来。

\n\n
布袋和尚
\n

手把青秧插满田,低头便见水中天。
\n心地清净方为道,退步原来是向前。

\n
赠药山高僧惟俨
\n

练得身形似鹤形,千株松下两函经。
\n我来问道无馀说,云在青天水在瓶。

\n

——李翱

\n
牛头山法融禅师
\n

恰恰用心时,恰恰无心用。曲谭名相劳,直说无繁重。
\n无心恰恰用,常用恰恰无。今说无心处,不与有心殊。

\n

——唐永徽年中

\n
天衣义怀禅师
\n

雁过长空,影沉寒底,雁无留影之心,影无遗踪之意。

\n
\n

《菜根谭》中的一句古诗:“风来疏竹,风过而竹不留声;雁渡寒潭,雁过而潭不留影。

\n

另一版本:竹影扫阶尘不动,雁过寒潭水无痕。

\n
\n","site":{"data":{}},"excerpt":"
佛偈(jì)
\n

\n

虚云老和尚悟道偈

\n

杯子扑落地,响声明历历。
\n虚空粉碎也,狂心当下息。

\n

烫着手,打碎杯,家破人亡语难开。
\n春到花香处处秀,山河大地是如来。

","more":"
布袋和尚
\n

手把青秧插满田,低头便见水中天。
\n心地清净方为道,退步原来是向前。

\n
赠药山高僧惟俨
\n

练得身形似鹤形,千株松下两函经。
\n我来问道无馀说,云在青天水在瓶。

\n

——李翱

\n
牛头山法融禅师
\n

恰恰用心时,恰恰无心用。曲谭名相劳,直说无繁重。
\n无心恰恰用,常用恰恰无。今说无心处,不与有心殊。

\n

——唐永徽年中

\n
天衣义怀禅师
\n

雁过长空,影沉寒底,雁无留影之心,影无遗踪之意。

\n
\n

《菜根谭》中的一句古诗:“风来疏竹,风过而竹不留声;雁渡寒潭,雁过而潭不留影。

\n

另一版本:竹影扫阶尘不动,雁过寒潭水无痕。

\n
"},{"title":"搞笑段子","date":"2019-07-29T06:40:50.000Z","urlname":"funny-things-collection","toc":true,"notshow":true,"_content":"\n###### 慢慢就习惯了\n\n某人四十多岁了还碌碌无为,于是跑去找算命先生。算命先生掐指一算,然后问:“一个好消息,一个坏消息,你先听哪个?”哥们说:“那就先听坏的吧”。算命先生说:“坏消息是,你四十岁之前穷困潦倒……”那哥们眉头一挑,问:“那好消息呢?”算命先生幽幽的说到:“四十岁以后,你就习惯了。”\n\n\n\n###### 身体就像一辆车子\n\n身体就像一辆车子,还新的时候,遇到问题花点钱修理一下,就又能风驰电掣。车子越旧,修理费越高。旧到不行了,修理费比换辆新的还贵,还修个啥劲?你「身体」这家企业,当对它的投入远大于产出的时候,上帝都要考虑撤资了,你还拼命追加投资?\n\n###### 凌凌漆\n\n外景:深圳某一市场猪肉摊前。 \n某女甲:你以为你匿喺度就揾唔到你咩? 冇用架! 你啲咁出色嘅难忍(男人),无论喺边度,都好似漆黑中嘅萤火虫一样,咁鲜明,咁出众。 你忧郁嘅眼神,唏嘘嘅须根,神乎其技嘅刀法,同埋嗰杯Dry Martine,都彻底噉将你出卖咗。 不过,你虽然系咁出色,始终行有行规,无论典(点)你都要找埋寻晚嗰条过夜数,叫鸡唔使畀钱呀? \n凌凌漆:我重估我哋嘅交往系建筑喺感情之上,估唔到,原来都系一盘生意。 \n某女甲:讲感情都要畀钱架。 \n凌凌漆:明白嘅,有一早畀咗你啦。 但系近排兴食斋,冇乜人帮衬,不如噉啦,攞篘猪肉返去顶住数先啦。 嚟吖,粗粗地,唔该。 \n某女甲:你好嘢,山水有山逢。 (某女甲提猪肉转身走。) \n凌凌漆: \n有兴趣嘅不如今天再相逢啦。 \n(某女甲把猪肉投向凌凌漆) \n凌凌漆(用刀接住猪肉):悭番。 (顺势将猪肉切成两半,挂喺猪肉钩上) \n某女乙:咩话? 个衰佬唔肯畀钱? 我帮你拖马喐佢! \n某女甲:算啦,话到尾,佢始终都系一个独一无二、风度翩翩嘅猪肉佬。 \n(阿漆依着猪肉摊,品着白兰地。) \n\n###### 情人节广告\n\n14号晚报名打麻将,只报不打,报名费100元,报完名爱干嘛干嘛,爱去哪去哪,爱跟谁跟谁。本人承诺:保证任何人问你的行踪都可以证明你跟我一起打麻将了,你所有报不了的花费都可以说成是被我赢了,具体时间为2月14日17点至凌晨2点,时间地点任选。额外业务:如支付200元,还提供大牌合照以及朋友圈回复业务,做戏做全套!小本经营,童叟无欺!有意者私聊。","source":"_posts/摘录/娱乐/搞笑段子.md","raw":"---\ntitle: 搞笑段子\ndate: 2019-07-29 08:40:50\nurlname: funny-things-collection\ntoc: true\ntags: [娱乐]\ncategories: [摘录, 娱乐]\nnotshow: true\n\n---\n\n###### 慢慢就习惯了\n\n某人四十多岁了还碌碌无为,于是跑去找算命先生。算命先生掐指一算,然后问:“一个好消息,一个坏消息,你先听哪个?”哥们说:“那就先听坏的吧”。算命先生说:“坏消息是,你四十岁之前穷困潦倒……”那哥们眉头一挑,问:“那好消息呢?”算命先生幽幽的说到:“四十岁以后,你就习惯了。”\n\n\n\n###### 身体就像一辆车子\n\n身体就像一辆车子,还新的时候,遇到问题花点钱修理一下,就又能风驰电掣。车子越旧,修理费越高。旧到不行了,修理费比换辆新的还贵,还修个啥劲?你「身体」这家企业,当对它的投入远大于产出的时候,上帝都要考虑撤资了,你还拼命追加投资?\n\n###### 凌凌漆\n\n外景:深圳某一市场猪肉摊前。 \n某女甲:你以为你匿喺度就揾唔到你咩? 冇用架! 你啲咁出色嘅难忍(男人),无论喺边度,都好似漆黑中嘅萤火虫一样,咁鲜明,咁出众。 你忧郁嘅眼神,唏嘘嘅须根,神乎其技嘅刀法,同埋嗰杯Dry Martine,都彻底噉将你出卖咗。 不过,你虽然系咁出色,始终行有行规,无论典(点)你都要找埋寻晚嗰条过夜数,叫鸡唔使畀钱呀? \n凌凌漆:我重估我哋嘅交往系建筑喺感情之上,估唔到,原来都系一盘生意。 \n某女甲:讲感情都要畀钱架。 \n凌凌漆:明白嘅,有一早畀咗你啦。 但系近排兴食斋,冇乜人帮衬,不如噉啦,攞篘猪肉返去顶住数先啦。 嚟吖,粗粗地,唔该。 \n某女甲:你好嘢,山水有山逢。 (某女甲提猪肉转身走。) \n凌凌漆: \n有兴趣嘅不如今天再相逢啦。 \n(某女甲把猪肉投向凌凌漆) \n凌凌漆(用刀接住猪肉):悭番。 (顺势将猪肉切成两半,挂喺猪肉钩上) \n某女乙:咩话? 个衰佬唔肯畀钱? 我帮你拖马喐佢! \n某女甲:算啦,话到尾,佢始终都系一个独一无二、风度翩翩嘅猪肉佬。 \n(阿漆依着猪肉摊,品着白兰地。) \n\n###### 情人节广告\n\n14号晚报名打麻将,只报不打,报名费100元,报完名爱干嘛干嘛,爱去哪去哪,爱跟谁跟谁。本人承诺:保证任何人问你的行踪都可以证明你跟我一起打麻将了,你所有报不了的花费都可以说成是被我赢了,具体时间为2月14日17点至凌晨2点,时间地点任选。额外业务:如支付200元,还提供大牌合照以及朋友圈回复业务,做戏做全套!小本经营,童叟无欺!有意者私聊。","slug":"摘录/娱乐/搞笑段子","published":1,"updated":"2019-07-31T03:51:35.000Z","_id":"cka1y598g00294huuytpjchoh","comments":1,"layout":"post","photos":[],"link":"","content":"
慢慢就习惯了
\n

某人四十多岁了还碌碌无为,于是跑去找算命先生。算命先生掐指一算,然后问:“一个好消息,一个坏消息,你先听哪个?”哥们说:“那就先听坏的吧”。算命先生说:“坏消息是,你四十岁之前穷困潦倒……”那哥们眉头一挑,问:“那好消息呢?”算命先生幽幽的说到:“四十岁以后,你就习惯了。”

\n\n
身体就像一辆车子
\n

身体就像一辆车子,还新的时候,遇到问题花点钱修理一下,就又能风驰电掣。车子越旧,修理费越高。旧到不行了,修理费比换辆新的还贵,还修个啥劲?你「身体」这家企业,当对它的投入远大于产出的时候,上帝都要考虑撤资了,你还拼命追加投资?

\n
凌凌漆
\n

外景:深圳某一市场猪肉摊前。
\n某女甲:你以为你匿喺度就揾唔到你咩? 冇用架! 你啲咁出色嘅难忍(男人),无论喺边度,都好似漆黑中嘅萤火虫一样,咁鲜明,咁出众。 你忧郁嘅眼神,唏嘘嘅须根,神乎其技嘅刀法,同埋嗰杯Dry Martine,都彻底噉将你出卖咗。 不过,你虽然系咁出色,始终行有行规,无论典(点)你都要找埋寻晚嗰条过夜数,叫鸡唔使畀钱呀?
\n凌凌漆:我重估我哋嘅交往系建筑喺感情之上,估唔到,原来都系一盘生意。
\n某女甲:讲感情都要畀钱架。
\n凌凌漆:明白嘅,有一早畀咗你啦。 但系近排兴食斋,冇乜人帮衬,不如噉啦,攞篘猪肉返去顶住数先啦。 嚟吖,粗粗地,唔该。
\n某女甲:你好嘢,山水有山逢。 (某女甲提猪肉转身走。)
\n凌凌漆:
\n有兴趣嘅不如今天再相逢啦。
\n(某女甲把猪肉投向凌凌漆)
\n凌凌漆(用刀接住猪肉):悭番。 (顺势将猪肉切成两半,挂喺猪肉钩上)
\n某女乙:咩话? 个衰佬唔肯畀钱? 我帮你拖马喐佢!
\n某女甲:算啦,话到尾,佢始终都系一个独一无二、风度翩翩嘅猪肉佬。
\n(阿漆依着猪肉摊,品着白兰地。)

\n
情人节广告
\n

14号晚报名打麻将,只报不打,报名费100元,报完名爱干嘛干嘛,爱去哪去哪,爱跟谁跟谁。本人承诺:保证任何人问你的行踪都可以证明你跟我一起打麻将了,你所有报不了的花费都可以说成是被我赢了,具体时间为2月14日17点至凌晨2点,时间地点任选。额外业务:如支付200元,还提供大牌合照以及朋友圈回复业务,做戏做全套!小本经营,童叟无欺!有意者私聊。

\n","site":{"data":{}},"excerpt":"
慢慢就习惯了
\n

某人四十多岁了还碌碌无为,于是跑去找算命先生。算命先生掐指一算,然后问:“一个好消息,一个坏消息,你先听哪个?”哥们说:“那就先听坏的吧”。算命先生说:“坏消息是,你四十岁之前穷困潦倒……”那哥们眉头一挑,问:“那好消息呢?”算命先生幽幽的说到:“四十岁以后,你就习惯了。”

","more":"
身体就像一辆车子
\n

身体就像一辆车子,还新的时候,遇到问题花点钱修理一下,就又能风驰电掣。车子越旧,修理费越高。旧到不行了,修理费比换辆新的还贵,还修个啥劲?你「身体」这家企业,当对它的投入远大于产出的时候,上帝都要考虑撤资了,你还拼命追加投资?

\n
凌凌漆
\n

外景:深圳某一市场猪肉摊前。
\n某女甲:你以为你匿喺度就揾唔到你咩? 冇用架! 你啲咁出色嘅难忍(男人),无论喺边度,都好似漆黑中嘅萤火虫一样,咁鲜明,咁出众。 你忧郁嘅眼神,唏嘘嘅须根,神乎其技嘅刀法,同埋嗰杯Dry Martine,都彻底噉将你出卖咗。 不过,你虽然系咁出色,始终行有行规,无论典(点)你都要找埋寻晚嗰条过夜数,叫鸡唔使畀钱呀?
\n凌凌漆:我重估我哋嘅交往系建筑喺感情之上,估唔到,原来都系一盘生意。
\n某女甲:讲感情都要畀钱架。
\n凌凌漆:明白嘅,有一早畀咗你啦。 但系近排兴食斋,冇乜人帮衬,不如噉啦,攞篘猪肉返去顶住数先啦。 嚟吖,粗粗地,唔该。
\n某女甲:你好嘢,山水有山逢。 (某女甲提猪肉转身走。)
\n凌凌漆:
\n有兴趣嘅不如今天再相逢啦。
\n(某女甲把猪肉投向凌凌漆)
\n凌凌漆(用刀接住猪肉):悭番。 (顺势将猪肉切成两半,挂喺猪肉钩上)
\n某女乙:咩话? 个衰佬唔肯畀钱? 我帮你拖马喐佢!
\n某女甲:算啦,话到尾,佢始终都系一个独一无二、风度翩翩嘅猪肉佬。
\n(阿漆依着猪肉摊,品着白兰地。)

\n
情人节广告
\n

14号晚报名打麻将,只报不打,报名费100元,报完名爱干嘛干嘛,爱去哪去哪,爱跟谁跟谁。本人承诺:保证任何人问你的行踪都可以证明你跟我一起打麻将了,你所有报不了的花费都可以说成是被我赢了,具体时间为2月14日17点至凌晨2点,时间地点任选。额外业务:如支付200元,还提供大牌合照以及朋友圈回复业务,做戏做全套!小本经营,童叟无欺!有意者私聊。

"},{"title":"名人语录","date":"2019-07-29T06:40:50.000Z","urlname":"prominaent-slogen-collection","toc":true,"notshow":true,"_content":"\n###### 祈祷文\n\n- 上帝,请赐予我平静让我可以接受我所不能改变的,赐予我勇气让我可以改变我能够改变的,赐予我智慧以分辨这二者的不同。\n- God grand me the serenity to accept the things I cannot change, Courage to change the things I can, and wisdom to know the difference.\n\n###### 尼采\n\nHe who has a strong enough why can bear almost any how. – Friedrich Nietzsche \n\n###### 苏格拉底\n\nBeware the barrenness of a busy life. – Socrates \n\n###### 亚里士多德\n\nWe are what we repeatedly do. Excellence, then, is not an act, but a habit. – Aristotle \n\n###### 维克多 弗兰克\n\n人所拥有的任何东西都可以被剥夺,唯独人性最后的自由——也就是在任何境遇中选择一己态度和生活方式的自由——不能被剥夺。\n\n###### 马克吐温\n\n让你陷入困境的并不是这个世界;真正让你陷入困境的,是这个世界最终并非你所想象。\n\n###### 赛斯\n\n每一个心愿都预设了对于一个缺憾的承认,每一个挑战也预设了有一个要征服的阻碍。\n\n###### 叔本华\n\n痛苦和无聊是人类幸福的两个死敌。欲望不满足就痛苦,满足就无聊。人生如同钟摆在痛苦和无聊两个极点之间摆动。离开一个极点就意味着正在走向另一个极点。\n\n###### 谚语\n\nDon’t shoot the messenger.\n英文有句谚语叫“不要枪毙信使”。枪毙信使并不能改变坏消息。\n\n###### 曾国藩\n\n- 既往不恋,当下不染, 未来不迎。天涯:染,不被当下的情绪感染。要跳出情绪来观察当下。\n- 倚天照海花无数, 流水高山心自知。\n- 久利之事勿为,众争之地勿往。\n- 勿以小恶弃人大美, 勿以小怨忘人大恩。\n\n###### 宗棠\n\n人生最不幸處,是偶一失言而禍不及,偶一失謀而事倖成,偶一恣行而獲小利, 後乃視為故常,而恬不為意。則莫大之患,由此生矣。\n\n###### 俞敏洪\n\n优秀是一种习惯。","source":"_posts/摘录/片段/名人语录.md","raw":"---\ntitle: 名人语录\ndate: 2019-07-29 08:40:50\nurlname: prominaent-slogen-collection\ntoc: true\ntags: [文学]\ncategories: [摘录, 片段]\nnotshow: true\n\n---\n\n###### 祈祷文\n\n- 上帝,请赐予我平静让我可以接受我所不能改变的,赐予我勇气让我可以改变我能够改变的,赐予我智慧以分辨这二者的不同。\n- God grand me the serenity to accept the things I cannot change, Courage to change the things I can, and wisdom to know the difference.\n\n###### 尼采\n\nHe who has a strong enough why can bear almost any how. – Friedrich Nietzsche \n\n###### 苏格拉底\n\nBeware the barrenness of a busy life. – Socrates \n\n###### 亚里士多德\n\nWe are what we repeatedly do. Excellence, then, is not an act, but a habit. – Aristotle \n\n###### 维克多 弗兰克\n\n人所拥有的任何东西都可以被剥夺,唯独人性最后的自由——也就是在任何境遇中选择一己态度和生活方式的自由——不能被剥夺。\n\n###### 马克吐温\n\n让你陷入困境的并不是这个世界;真正让你陷入困境的,是这个世界最终并非你所想象。\n\n###### 赛斯\n\n每一个心愿都预设了对于一个缺憾的承认,每一个挑战也预设了有一个要征服的阻碍。\n\n###### 叔本华\n\n痛苦和无聊是人类幸福的两个死敌。欲望不满足就痛苦,满足就无聊。人生如同钟摆在痛苦和无聊两个极点之间摆动。离开一个极点就意味着正在走向另一个极点。\n\n###### 谚语\n\nDon’t shoot the messenger.\n英文有句谚语叫“不要枪毙信使”。枪毙信使并不能改变坏消息。\n\n###### 曾国藩\n\n- 既往不恋,当下不染, 未来不迎。天涯:染,不被当下的情绪感染。要跳出情绪来观察当下。\n- 倚天照海花无数, 流水高山心自知。\n- 久利之事勿为,众争之地勿往。\n- 勿以小恶弃人大美, 勿以小怨忘人大恩。\n\n###### 宗棠\n\n人生最不幸處,是偶一失言而禍不及,偶一失謀而事倖成,偶一恣行而獲小利, 後乃視為故常,而恬不為意。則莫大之患,由此生矣。\n\n###### 俞敏洪\n\n优秀是一种习惯。","slug":"摘录/片段/名人语录","published":1,"updated":"2019-07-31T03:51:35.000Z","_id":"cka1y598i002d4huu06onppzf","comments":1,"layout":"post","photos":[],"link":"","content":"
祈祷文
\n
    \n
  • 上帝,请赐予我平静让我可以接受我所不能改变的,赐予我勇气让我可以改变我能够改变的,赐予我智慧以分辨这二者的不同。
  • \n
  • God grand me the serenity to accept the things I cannot change, Courage to change the things I can, and wisdom to know the difference.
  • \n
\n
尼采
\n

He who has a strong enough why can bear almost any how. – Friedrich Nietzsche

\n
苏格拉底
\n

Beware the barrenness of a busy life. – Socrates

\n
亚里士多德
\n

We are what we repeatedly do. Excellence, then, is not an act, but a habit. – Aristotle

\n
维克多 弗兰克
\n

人所拥有的任何东西都可以被剥夺,唯独人性最后的自由——也就是在任何境遇中选择一己态度和生活方式的自由——不能被剥夺。

\n
马克吐温
\n

让你陷入困境的并不是这个世界;真正让你陷入困境的,是这个世界最终并非你所想象。

\n
赛斯
\n

每一个心愿都预设了对于一个缺憾的承认,每一个挑战也预设了有一个要征服的阻碍。

\n
叔本华
\n

痛苦和无聊是人类幸福的两个死敌。欲望不满足就痛苦,满足就无聊。人生如同钟摆在痛苦和无聊两个极点之间摆动。离开一个极点就意味着正在走向另一个极点。

\n
谚语
\n

Don’t shoot the messenger.
\n英文有句谚语叫“不要枪毙信使”。枪毙信使并不能改变坏消息。

\n
曾国藩
\n
    \n
  • 既往不恋,当下不染, 未来不迎。天涯:染,不被当下的情绪感染。要跳出情绪来观察当下。
  • \n
  • 倚天照海花无数, 流水高山心自知。
  • \n
  • 久利之事勿为,众争之地勿往。
  • \n
  • 勿以小恶弃人大美, 勿以小怨忘人大恩。
  • \n
\n
宗棠
\n

人生最不幸處,是偶一失言而禍不及,偶一失謀而事倖成,偶一恣行而獲小利, 後乃視為故常,而恬不為意。則莫大之患,由此生矣。

\n
俞敏洪
\n

优秀是一种习惯。

\n","site":{"data":{}},"excerpt":"","more":"
祈祷文
\n
    \n
  • 上帝,请赐予我平静让我可以接受我所不能改变的,赐予我勇气让我可以改变我能够改变的,赐予我智慧以分辨这二者的不同。
  • \n
  • God grand me the serenity to accept the things I cannot change, Courage to change the things I can, and wisdom to know the difference.
  • \n
\n
尼采
\n

He who has a strong enough why can bear almost any how. – Friedrich Nietzsche

\n
苏格拉底
\n

Beware the barrenness of a busy life. – Socrates

\n
亚里士多德
\n

We are what we repeatedly do. Excellence, then, is not an act, but a habit. – Aristotle

\n
维克多 弗兰克
\n

人所拥有的任何东西都可以被剥夺,唯独人性最后的自由——也就是在任何境遇中选择一己态度和生活方式的自由——不能被剥夺。

\n
马克吐温
\n

让你陷入困境的并不是这个世界;真正让你陷入困境的,是这个世界最终并非你所想象。

\n
赛斯
\n

每一个心愿都预设了对于一个缺憾的承认,每一个挑战也预设了有一个要征服的阻碍。

\n
叔本华
\n

痛苦和无聊是人类幸福的两个死敌。欲望不满足就痛苦,满足就无聊。人生如同钟摆在痛苦和无聊两个极点之间摆动。离开一个极点就意味着正在走向另一个极点。

\n
谚语
\n

Don’t shoot the messenger.
\n英文有句谚语叫“不要枪毙信使”。枪毙信使并不能改变坏消息。

\n
曾国藩
\n
    \n
  • 既往不恋,当下不染, 未来不迎。天涯:染,不被当下的情绪感染。要跳出情绪来观察当下。
  • \n
  • 倚天照海花无数, 流水高山心自知。
  • \n
  • 久利之事勿为,众争之地勿往。
  • \n
  • 勿以小恶弃人大美, 勿以小怨忘人大恩。
  • \n
\n
宗棠
\n

人生最不幸處,是偶一失言而禍不及,偶一失謀而事倖成,偶一恣行而獲小利, 後乃視為故常,而恬不為意。則莫大之患,由此生矣。

\n
俞敏洪
\n

优秀是一种习惯。

\n"},{"title":"零散句子","date":"2019-07-29T06:50:50.000Z","urlname":"funny-sloga-collection","toc":true,"notshow":true,"_content":"\n###### 幸福的路有两条\n\n中岛美雪写的歌《幸福》(任贤齐翻唱的伤心太平洋):到幸福的路有两条,一条是所有愿望都成真,另外一条是把愿望这东西扔掉。\n\n\n\n###### Matrix\n\n> Cypher: You know, I know this steak doesn't exist. I know that when I put it in my mounth, the Matrix is telling my brain that it is ..... juicy and delicious. After nine years, you know what I realize? en ...... Ignorance is bliss\n\n###### 几个顺口溜\n\n- 认认真真说假话,扎扎实实走过场。\n- 失败乃成功之母——失败生了100个孩子,其中一个叫「成功」,其它99个还叫「失败」。\n- “人类一思考,上帝就发笑。” —— “你一说要学什么东西,人们就发笑。”\n- 晚上想想千条路,早上起来走原路。(有个共同特点:不困难、不痛苦)\n- 暂时的失败要比暂时的成功要好得多。\n- 别让「半途而废」 成为你唯一坚持下来的事情。\n- 世上没有听一遍就管用的道理。\n- (你的脑袋)不要做别人思想的跑马场。\n- 路是自己走的,脚上的泡也是自己好的。\n- 忍一时越想越气,退一步越想越亏。(总是忍的人,从来都不开心。总是退让的人,却从来没有真的海阔天空)\n- 遇到烂事不纠结,遇到烂人不纠缠。\n- 每个人都想努力做,却总是做不好。\n- 曹操评袁绍:「色厉胆薄,好谋无断,干大事而惜身,见小利而忘命。」","source":"_posts/摘录/片段/零散句子.md","raw":"---\ntitle: 零散句子\ndate: 2019-07-29 08:50:50\nurlname: funny-sloga-collection\ntoc: true\ntags: [文学]\ncategories: [摘录, 片段]\nnotshow: true\n\n---\n\n###### 幸福的路有两条\n\n中岛美雪写的歌《幸福》(任贤齐翻唱的伤心太平洋):到幸福的路有两条,一条是所有愿望都成真,另外一条是把愿望这东西扔掉。\n\n\n\n###### Matrix\n\n> Cypher: You know, I know this steak doesn't exist. I know that when I put it in my mounth, the Matrix is telling my brain that it is ..... juicy and delicious. After nine years, you know what I realize? en ...... Ignorance is bliss\n\n###### 几个顺口溜\n\n- 认认真真说假话,扎扎实实走过场。\n- 失败乃成功之母——失败生了100个孩子,其中一个叫「成功」,其它99个还叫「失败」。\n- “人类一思考,上帝就发笑。” —— “你一说要学什么东西,人们就发笑。”\n- 晚上想想千条路,早上起来走原路。(有个共同特点:不困难、不痛苦)\n- 暂时的失败要比暂时的成功要好得多。\n- 别让「半途而废」 成为你唯一坚持下来的事情。\n- 世上没有听一遍就管用的道理。\n- (你的脑袋)不要做别人思想的跑马场。\n- 路是自己走的,脚上的泡也是自己好的。\n- 忍一时越想越气,退一步越想越亏。(总是忍的人,从来都不开心。总是退让的人,却从来没有真的海阔天空)\n- 遇到烂事不纠结,遇到烂人不纠缠。\n- 每个人都想努力做,却总是做不好。\n- 曹操评袁绍:「色厉胆薄,好谋无断,干大事而惜身,见小利而忘命。」","slug":"摘录/片段/零散句子","published":1,"updated":"2019-08-04T18:15:28.000Z","_id":"cka1y598k002h4huuc3fgsb7o","comments":1,"layout":"post","photos":[],"link":"","content":"
幸福的路有两条
\n

中岛美雪写的歌《幸福》(任贤齐翻唱的伤心太平洋):到幸福的路有两条,一条是所有愿望都成真,另外一条是把愿望这东西扔掉。

\n\n
Matrix
\n
\n

Cypher: You know, I know this steak doesn’t exist. I know that when I put it in my mounth, the Matrix is telling my brain that it is … juicy and delicious. After nine years, you know what I realize? en … Ignorance is bliss

\n
\n
几个顺口溜
\n
    \n
  • 认认真真说假话,扎扎实实走过场。
  • \n
  • 失败乃成功之母——失败生了100个孩子,其中一个叫「成功」,其它99个还叫「失败」。
  • \n
  • “人类一思考,上帝就发笑。” —— “你一说要学什么东西,人们就发笑。”
  • \n
  • 晚上想想千条路,早上起来走原路。(有个共同特点:不困难、不痛苦)
  • \n
  • 暂时的失败要比暂时的成功要好得多。
  • \n
  • 别让「半途而废」 成为你唯一坚持下来的事情。
  • \n
  • 世上没有听一遍就管用的道理。
  • \n
  • (你的脑袋)不要做别人思想的跑马场。
  • \n
  • 路是自己走的,脚上的泡也是自己好的。
  • \n
  • 忍一时越想越气,退一步越想越亏。(总是忍的人,从来都不开心。总是退让的人,却从来没有真的海阔天空)
  • \n
  • 遇到烂事不纠结,遇到烂人不纠缠。
  • \n
  • 每个人都想努力做,却总是做不好。
  • \n
  • 曹操评袁绍:「色厉胆薄,好谋无断,干大事而惜身,见小利而忘命。」
  • \n
\n","site":{"data":{}},"excerpt":"
幸福的路有两条
\n

中岛美雪写的歌《幸福》(任贤齐翻唱的伤心太平洋):到幸福的路有两条,一条是所有愿望都成真,另外一条是把愿望这东西扔掉。

","more":"
Matrix
\n
\n

Cypher: You know, I know this steak doesn’t exist. I know that when I put it in my mounth, the Matrix is telling my brain that it is … juicy and delicious. After nine years, you know what I realize? en … Ignorance is bliss

\n
\n
几个顺口溜
\n
    \n
  • 认认真真说假话,扎扎实实走过场。
  • \n
  • 失败乃成功之母——失败生了100个孩子,其中一个叫「成功」,其它99个还叫「失败」。
  • \n
  • “人类一思考,上帝就发笑。” —— “你一说要学什么东西,人们就发笑。”
  • \n
  • 晚上想想千条路,早上起来走原路。(有个共同特点:不困难、不痛苦)
  • \n
  • 暂时的失败要比暂时的成功要好得多。
  • \n
  • 别让「半途而废」 成为你唯一坚持下来的事情。
  • \n
  • 世上没有听一遍就管用的道理。
  • \n
  • (你的脑袋)不要做别人思想的跑马场。
  • \n
  • 路是自己走的,脚上的泡也是自己好的。
  • \n
  • 忍一时越想越气,退一步越想越亏。(总是忍的人,从来都不开心。总是退让的人,却从来没有真的海阔天空)
  • \n
  • 遇到烂事不纠结,遇到烂人不纠缠。
  • \n
  • 每个人都想努力做,却总是做不好。
  • \n
  • 曹操评袁绍:「色厉胆薄,好谋无断,干大事而惜身,见小利而忘命。」
  • \n
"},{"title":"缠中说禅","date":"2019-07-29T06:40:50.000Z","urlname":"funny-things-collection","toc":true,"notshow":true,"_content":"\n[TOC]\n\n##### 诗词\n\n###### 满江红\n\n万古长空,今犹昔,一朝风月。何处住?\n春花夏雨,秋鸿冬雪。\n百代浮华皆作土,千江吸尽无堪说。\n问世间,多少梦消磨、英雄血。\n星旋轨,天补裂,山崩柱,河倾缺。\n捣神宫鬼府,凤巢龙穴。\n怒剑穿云惊浩宇,狂涛卷日横孤筏。\n纵生死,劫火洗乾坤,齐欢悦。\n\n###### 临江仙\n\n浊水倾波三万里,愀然独坐孤峰。\n龙潜狮睡侯飙风。\n无情皆竖子,有泪亦英雄。\n长剑倚天星斗烂,古今过眼成空。\n乾坤俯仰任穷痛。\n半轮沧海上,一苇大江东。\n\n###### 卜算子\n\n本是后山人,偶做堂前客。\n醉舞经阁半卷书,坐井说天阔。\n大志戏功名,海斗量祸福。\n论到囊中羞涩时,怒指乾坤错。\n\n—— 丁元英","source":"_posts/摘录/片段/缠中说禅.md","raw":"---\ntitle: 缠中说禅\ndate: 2019-07-29 08:40:50\nurlname: funny-things-collection\ntoc: true\ntags: [文学]\ncategories: [摘录, 片段]\nnotshow: true\n\n---\n\n[TOC]\n\n##### 诗词\n\n###### 满江红\n\n万古长空,今犹昔,一朝风月。何处住?\n春花夏雨,秋鸿冬雪。\n百代浮华皆作土,千江吸尽无堪说。\n问世间,多少梦消磨、英雄血。\n星旋轨,天补裂,山崩柱,河倾缺。\n捣神宫鬼府,凤巢龙穴。\n怒剑穿云惊浩宇,狂涛卷日横孤筏。\n纵生死,劫火洗乾坤,齐欢悦。\n\n###### 临江仙\n\n浊水倾波三万里,愀然独坐孤峰。\n龙潜狮睡侯飙风。\n无情皆竖子,有泪亦英雄。\n长剑倚天星斗烂,古今过眼成空。\n乾坤俯仰任穷痛。\n半轮沧海上,一苇大江东。\n\n###### 卜算子\n\n本是后山人,偶做堂前客。\n醉舞经阁半卷书,坐井说天阔。\n大志戏功名,海斗量祸福。\n论到囊中羞涩时,怒指乾坤错。\n\n—— 丁元英","slug":"摘录/片段/缠中说禅","published":1,"updated":"2019-07-31T03:51:35.000Z","_id":"cka1y598o002l4huuoby01avt","comments":1,"layout":"post","photos":[],"link":"","content":"

[TOC]

\n
诗词
\n
满江红
\n

万古长空,今犹昔,一朝风月。何处住?
\n春花夏雨,秋鸿冬雪。
\n百代浮华皆作土,千江吸尽无堪说。
\n问世间,多少梦消磨、英雄血。
\n星旋轨,天补裂,山崩柱,河倾缺。
\n捣神宫鬼府,凤巢龙穴。
\n怒剑穿云惊浩宇,狂涛卷日横孤筏。
\n纵生死,劫火洗乾坤,齐欢悦。

\n
临江仙
\n

浊水倾波三万里,愀然独坐孤峰。
\n龙潜狮睡侯飙风。
\n无情皆竖子,有泪亦英雄。
\n长剑倚天星斗烂,古今过眼成空。
\n乾坤俯仰任穷痛。
\n半轮沧海上,一苇大江东。

\n
卜算子
\n

本是后山人,偶做堂前客。
\n醉舞经阁半卷书,坐井说天阔。
\n大志戏功名,海斗量祸福。
\n论到囊中羞涩时,怒指乾坤错。

\n

—— 丁元英

\n","site":{"data":{}},"excerpt":"","more":"

[TOC]

\n
诗词
\n
满江红
\n

万古长空,今犹昔,一朝风月。何处住?
\n春花夏雨,秋鸿冬雪。
\n百代浮华皆作土,千江吸尽无堪说。
\n问世间,多少梦消磨、英雄血。
\n星旋轨,天补裂,山崩柱,河倾缺。
\n捣神宫鬼府,凤巢龙穴。
\n怒剑穿云惊浩宇,狂涛卷日横孤筏。
\n纵生死,劫火洗乾坤,齐欢悦。

\n
临江仙
\n

浊水倾波三万里,愀然独坐孤峰。
\n龙潜狮睡侯飙风。
\n无情皆竖子,有泪亦英雄。
\n长剑倚天星斗烂,古今过眼成空。
\n乾坤俯仰任穷痛。
\n半轮沧海上,一苇大江东。

\n
卜算子
\n

本是后山人,偶做堂前客。
\n醉舞经阁半卷书,坐井说天阔。
\n大志戏功名,海斗量祸福。
\n论到囊中羞涩时,怒指乾坤错。

\n

—— 丁元英

\n"},{"title":"简短书摘","date":"2019-07-29T07:00:50.000Z","urlname":"brief-notions-collection","toc":true,"notshow":true,"_content":"\n###### 癌症\n\n“以我个人有限的接触癌症的经历总结,似乎越是传统意义上的“好人”越是容易生癌。这些人往往脾气很好,性格内向,照顾周围,万事替别人考虑,总是在乎别人眼里的自己,总是担心一些可能发生的小概率负面事件。”\n\n—— 冯唐. “无所畏【冯唐2018全新作品,一部坦露自我的真诚之作!】。” \n\n\n\n###### 暗算\n\n金风未动蝉先觉,暗算无常死不知。\n青山只会明今古,绿水何曾洗是非?\n\n###### 五个人生思维\n\n- 能把问题清楚的写下来,就是解决了问题的一半。发现问题比解决问题更重要。\n- 墨菲定律:如果事情有变坏的可能,那它就一定会发生。\n- 吉伯特法则:真正的危险是没有人告诉你有危险。「人在事中迷,就怕没人提」。\n- 福克兰定律:当你不知道如何行动时,最好的行动就是不要行动,最好的决策就是没有决策。\n- 费斯诺定律:人有两只耳朵,却只有一张嘴巴。就是说,人应该多听少讲。","source":"_posts/摘录/片段/简短书摘.md","raw":"---\ntitle: 简短书摘\ndate: 2019-07-29 09:00:50\nurlname: brief-notions-collection\ntoc: true\ntags: [文学]\ncategories: [摘录, 片段]\nnotshow: true\n\n---\n\n###### 癌症\n\n“以我个人有限的接触癌症的经历总结,似乎越是传统意义上的“好人”越是容易生癌。这些人往往脾气很好,性格内向,照顾周围,万事替别人考虑,总是在乎别人眼里的自己,总是担心一些可能发生的小概率负面事件。”\n\n—— 冯唐. “无所畏【冯唐2018全新作品,一部坦露自我的真诚之作!】。” \n\n\n\n###### 暗算\n\n金风未动蝉先觉,暗算无常死不知。\n青山只会明今古,绿水何曾洗是非?\n\n###### 五个人生思维\n\n- 能把问题清楚的写下来,就是解决了问题的一半。发现问题比解决问题更重要。\n- 墨菲定律:如果事情有变坏的可能,那它就一定会发生。\n- 吉伯特法则:真正的危险是没有人告诉你有危险。「人在事中迷,就怕没人提」。\n- 福克兰定律:当你不知道如何行动时,最好的行动就是不要行动,最好的决策就是没有决策。\n- 费斯诺定律:人有两只耳朵,却只有一张嘴巴。就是说,人应该多听少讲。","slug":"摘录/片段/简短书摘","published":1,"updated":"2019-07-31T03:51:35.000Z","_id":"cka1y598q002p4huudjt7uk0a","comments":1,"layout":"post","photos":[],"link":"","content":"
癌症
\n

“以我个人有限的接触癌症的经历总结,似乎越是传统意义上的“好人”越是容易生癌。这些人往往脾气很好,性格内向,照顾周围,万事替别人考虑,总是在乎别人眼里的自己,总是担心一些可能发生的小概率负面事件。”

\n

—— 冯唐. “无所畏【冯唐2018全新作品,一部坦露自我的真诚之作!】。”

\n\n
暗算
\n

金风未动蝉先觉,暗算无常死不知。
\n青山只会明今古,绿水何曾洗是非?

\n
五个人生思维
\n
    \n
  • 能把问题清楚的写下来,就是解决了问题的一半。发现问题比解决问题更重要。
  • \n
  • 墨菲定律:如果事情有变坏的可能,那它就一定会发生。
  • \n
  • 吉伯特法则:真正的危险是没有人告诉你有危险。「人在事中迷,就怕没人提」。
  • \n
  • 福克兰定律:当你不知道如何行动时,最好的行动就是不要行动,最好的决策就是没有决策。
  • \n
  • 费斯诺定律:人有两只耳朵,却只有一张嘴巴。就是说,人应该多听少讲。
  • \n
\n","site":{"data":{}},"excerpt":"
癌症
\n

“以我个人有限的接触癌症的经历总结,似乎越是传统意义上的“好人”越是容易生癌。这些人往往脾气很好,性格内向,照顾周围,万事替别人考虑,总是在乎别人眼里的自己,总是担心一些可能发生的小概率负面事件。”

\n

—— 冯唐. “无所畏【冯唐2018全新作品,一部坦露自我的真诚之作!】。”

","more":"
暗算
\n

金风未动蝉先觉,暗算无常死不知。
\n青山只会明今古,绿水何曾洗是非?

\n
五个人生思维
\n
    \n
  • 能把问题清楚的写下来,就是解决了问题的一半。发现问题比解决问题更重要。
  • \n
  • 墨菲定律:如果事情有变坏的可能,那它就一定会发生。
  • \n
  • 吉伯特法则:真正的危险是没有人告诉你有危险。「人在事中迷,就怕没人提」。
  • \n
  • 福克兰定律:当你不知道如何行动时,最好的行动就是不要行动,最好的决策就是没有决策。
  • \n
  • 费斯诺定律:人有两只耳朵,却只有一张嘴巴。就是说,人应该多听少讲。
  • \n
"},{"title":"有用的Shell命令","date":"2019-07-30T15:30:28.000Z","urlname":"helpfull-shell-command","toc":true,"notshow":true,"_content":"\n在线网站可以找到基本的东西:[Linux命令大全](https://man.linuxde.net/) [shell 正则表达式](https://man.linuxde.net/docs/shell_regex.html)\n\n# 文件&内容检索\n\n## 正则表达式注意的地方\n\n- 花括号之前要加转义字符 `[a-z]\\{3\\}`\n- 空格就是转义加空格`\\ `,而不是`\\s` 。如 `[a-z0-9_\\ ]\\{3,\\}`\n- 这几个符号 `_ - . #`都不需要加转义符。\n- 不要轻易加==行结束符==$,可能回车才是最后符号,所以可能找不到。\n\n\n\n## grep\n\n```sh\n# -r 递归搜索子目录\n# -l 只显示文件\n# -n 显示文件和匹配的行\n# 搜索 “markdown” 字符串并输入到文件里\n# Formating the Results...\ngrep $begrif $directory $args |awk '{ print \"[\" $1 \"](\" $1 \")\\n\" }' > suchergebnisse.md\n# 将结果转为Windows目录\nsed -i -- 's/\\/D\\//D:\\/\\//g' suchergebnisse.md\necho \"Fertig! Ergebnisse siehe Datei 'suchergebnisse.md'\"\nread\n```\n\n[更多参数请读此文](https://blog.csdn.net/u013485792/article/details/52243479) 示例脚本\n\n`grep` 正则表达式的例子\n\n```sh\n#!bin/bash\n# {#part0000_split_050.html#nav_point-99 .calibre13}\nresult=$(grep '{#part0000_split_[0-9]\\{3\\}.html[a-z0-9_\\ -.#]\\{3,\\}calibre13}' 文件名)\n\nif [ \"$result\" = \"\" ];\nthen\n\techo \"Nichts gefunden!\"\nfi\n\necho $result\nread\n```\n\ngrep或操作\n\n```sh\ngrep -E '123|abc' filename // 找出文件(filename)中包含123或者包含abc的行\negrep '123|abc' filename // 用egrep同样可以实现\nawk '/123|abc/' filename // awk 的实现方式\n```\n\ngrep与操作\n\n```sh\ngrep pattern1 files | grep pattern2 //显示既匹配 pattern1 又匹配 pattern2 的行。\n```\n\n其它常用选项\n\n```sh\ngrep -i pattern files //不区分大小写地搜索。默认情况区分大小写,\ngrep -l pattern files //只列出匹配的文件名,\ngrep -L pattern files //列出不匹配的文件名,\ngrep -w pattern files //只匹配整个单词,而不是字符串的一部分(如匹配‘magic’,而不是‘magical’),\ngrep -C number pattern files //匹配的上下文分别显示[number]行,\n```\n\n{% fold 点击显/隐代码 %}\n\n\n{% endfold %}\n\n## sed 命令\n\n[参考文献](https://man.linuxde.net/sed)\n\n### 文本替代\n\n以下文本替换通过`pandoc`导入后的文件,残留很多内部跳转链接:如\n\n```sh\n{#part0000_split_003.html#nav_point_1 .not-in-toc}\n```\n\n\n\n```bash\n#!bin/bash\necho running\n#sed 's/^#part0000_split_$/p' -f ../Linux_shell_Anleitung.md ;\nsed -i -- 's/^\\[\\]{#part0000_split_[0-9]\\{3\\}.html}$//g' ../Linux_shell_Anleitung.md \n\n#{#part0000_split_017.html#nav_point_21 .calibre8} {#part0000_split_003.html#nav_point_1 .not-in-toc}\nsed -i -- 's/{#part0000_split_[0-9]\\{3\\}.html#[a-z0-9_-]\\+ .[a-z0-9_-]\\+}//g' ../Linux_shell_Anleitung.md \n\necho fertig!\nread\n```\n\n### 整行替代\n\n[参考文献](https://www.cnblogs.com/wangqiguo/p/6718512.html)\n\n替代以 `categories:` 开头的整行(允许行开头有空格或制表符)。`c` 代表整行,以字符串 *categories: [IE]* 替代整行。\n\n```sh\n# Linux 下的写法\nsed -i -- '/^[[:blank:]]*categories:/c categories: [IE]' result.txt \n# Mac 下的写法\nsed -i '' 's/^[[:blank:]]*tags:.*/tags: [心理]/' $1 \n```\n\n错误:如果将参数 `c` 写在前面,会将整个文本每一行都替换掉。\n\n```sh\n# Linux 下的写法\nsed -i -- 'c/^[[:blank:]]*categories:/categories: [IE]/' result.txt \n```\n\n\n\n## find\n\n```sh\n# 查找所有的 md 文件\nfind /root/bibliothek/markdowns/blog_posts/ -type f -name \"*.md\" \n# 查找一天之前的文件, 一小时前时 -1h,一周 -1w\nfind . -type f -mtime -1d\n```\n\n如果要处理复杂的事情,就要用到函数\n\n```sh\n# 定义函数\nshowFileInfo(){\n echo $1\n}\n\n# 声明函数\nexport -f showFileInfo\n# 使用函数\nfind $dirPath -name \"*.md\" | xargs -n 1 -P 10 -I {} bash -c 'showFileInfo \"$@\"' _ {} \\;\n```\n\n\n\n## 查找最新文件\n\n- 将文件按从新到旧排列,取第一个。\n\n `ls -t *.cpp | head -1`\n\n- 将文件按从旧到新排列,取最后一个。\n\n `ls -rt *.cpp | tail -1`\n\n- 列出文件时间戳\n\n `ls -l simpleNode.js |awk '{print $6 \"-\" $7 \"-\" $8 }'`\n\n- 整合以上两个命令,找到最新的文件,读取时间戳 \n\n `ls -t *.* | head -1 | xargs ls -l | awk '{print $6 \"-\" $7 \"-\" $8 }'`\n\n\n\n# 字符串处理\n\n[字符串处理参考文献](https://www.jianshu.com/p/5709118af1c6) [将分隔符的字符串转为数组的几种方法](https://blog.csdn.net/Jerry_1126/article/details/83930956)\n\n配合使用,可以直接用 shell 实现文件内标签和分类的替换。\n\n## 数组转字符串\n\n使用分隔符将数组转字符串:\n\n```sh\nids=(1 2 3 4); \nlst=$( IFS='/'; echo \"${ids[*]}\" ); \necho $lst\n# 结果是:1/2/3/4\n```\n\n## 字符串转数组\n\n[懒得写,看范例](https://blog.csdn.net/Jerry_1126/article/details/83930956)\n\n## 字符串替换\n\n```sh\n# 原串 [娱乐,经济,重要] => 目标串 [娱乐, 经济, 重要]\n${tags/,/, } # 只替换了一个,结果变成 [娱乐, 经济,重要]\n${tags//,/, } # 替换了所有符合的,结果变成 [娱乐, 经济, 重要]\n# 原串 [重要] => 目标串 重要\n${tags//[\\[\\] ]/}\n```\n\n### 消除回车符、换行符、制表符\n\n```sh\n# arg是个字符串变量, 可能带有回车符\\r\n# 把它整个作为参数使用会带来很多麻烦。用以下命令将其替换掉\nnewvar=${arg//[$'\\t\\r\\n']/}\n```\n\n\n\n## 详细用法\n\n[参考文献](https://blog.csdn.net/ljianhui/article/details/43128465)\n\n1. `${var##*/}`\n该命令的作用是去掉变量var从左边算起的最后一个'/'字符及其左边的内容,返回从左边算起的最后一个'/'(不含该字符)的右边的内容。使用例子及结果如下:\n\n```sh\nvar=dir1/dir2/file.txt \n--> file.txt\n```\n\n从运行结果可以看到,使用该命令,可以提取出我们需要的文件名*file.txt*。\n\n若使用时在shell程序文件中,可以使用变量来保存这个结果,再加以利用,如file=`${var##*/}`\n\n2. `${var##*.}`\n该命令的作用是去掉变量var从左边算起的最后一个'.'字符及其左边的内容,返回从左边算起的最后一个'.'(不含该字符)的右边的内容。使用例子及结果如下:\n\n```sh\nvar=dir1/dir2/file.txt \n--> txt\n```\n\n从运行结果可以看到,使用该命令,可以提取出我们需要的文件后缀。\n\n如果文件的后缀不仅有一个,例如,file.tar.gz,命令`${var##*.}`仅能提取最后一个后缀,而我想提取tar.gz时该怎么办?那么就要用下面所说的`${var#*.}`命令了。\n\n3. `${var#*.}`\n该命令的作用是去掉变量var从左边算起的第一个'.'字符及其左边的内容,返回从左边算起第一个'.'(不含该字符)的右边部分的内容。使用例子及结果如下:\n\n```sh\nvar=dir1/dir2/file.tar.gz \n--> tar.gz\n```\n\n从运行结果可以看到,使用该命令,可以提取出文件的多个后缀。\n\n4. `${var%/*}`\n 该命令的使用是去掉变量var从右边算起的第一个'/'字符及其右边的内容,返回从右边算起的第一个'/'(不含该字符)的左边的内容。使用例子及结果如下:\n\n```sh\nvar=dir1/dir2/file.txt \n--> dir1/dir2\n```\n\n\n\n从运行的结果可以看到,使用该命令,可以提取出我们需要的文件所在的目录\n\n5. `${var%%.*}`\n该命令的使用是去掉变量var从右边算起的最后一个'.'字符及其右边的内容,返回从右边算起的最后一个'.'(不含该字符)的左边的内容。使用例子及结果如下:\n\n```sh\nvar=dir1/dir2/file.txt \n--> dir1/dir2/file\n```\n\n当我们需要建立一个与文件名相同名字(没有后缀)的目录与对应的文件相对应时,就可以使用该命令来进行操作。例如,解压文件的情况就与此类似,我们压缩文件file.zip时,会在与file.zip同级目录下建立一个名为file的目录。\n\n6. 总结\n\n 其实${}并不是专门为提取文件名或目录名的,它的使用是变量的提取和替换等等操作,它可以提取非常多的内容,并不一定是上面五个例子中的'/'或'.'。也就是说,上面的使用方法只是它使用的一个特例。\n\n\n\n看到上面的这些命令,可能会让人感到非常难以理解和记忆,其实不然,它们都是有规律的。\n\n- \\#:表示从左边算起第一个\n\n- %:表示从右边算起第一个\n\n- \\##:表示从左边算起最后一个\n\n- %%:表示从右边算起最后一个\n\n换句话来说,#总是表示左边算起,%总是表示右边算起。\n\n*:表示要删除的内容,对于#和##的情况,它位于指定的字符(例子中的'/'和'.')的左边,表于删除指定字符及其左边的内容;对于%和%%的情况,它位于指定的字符(例子中的'/'和'.')的右边,表示删除指定字符及其右边的内容。这里的'*'的位置不能互换,即不能把*号放在#或##的右边,反之亦然。\n\n例如:`${var%%x*}`表示找出从右边算起最后一个字符x,并删除字符x及其右边的字符。\n\n看到这里,就可以知道,其实该命令的用途非常广泛,上面只是指针文件名和目录名的命名特性来进行提取的一些特例而已。\n\n## basename和dirname\n\n`${}`并不是专门为提取文件名和目录名设计的命令,那么`basename`和`dirname`命令就是专门为做这一件事而已准备的了。\n\n1. `basename`\n 该命令的作用是从路径中提取出文件名,使用方法为basename NAME [SUFFIX]。\n\n 1.1 从路径中提出出文件名(带后缀),例子如下:\n\n 1.2 从上面命令的用法中可以看到,后缀(SUFFIX)是一个可选项。所以,若只想提取出文件名file,而不带有后缀,还可以在变量的后面加上后缀名,例子如下:\n\n\n2. `dirname`\n该命令的作用是从路径中提取出目录名,使用方法为 dirname NAME。使用例子如下:\n\n这样就提取出了file.txt文件所在的目录。\n\n注:该命令不仅能提取出普通文件所的目录,它能提取出任何文件所在的目录,例如目录所在的目录,如下:\n\n它提取出了目录dir2所在的目录dir1.\n\n---------------------\n\n\n\n# 查看硬盘剩余空间\n\n```sh\n# 整个硬盘空间\ndf -hl\n# 查看某个文件夹大小\ndu -h your_directory # 列出每个子文件夹大小\ndu -hcs your_directory # 汇总\n```\n\n\n\n## 查看 package 版本\n\n```sh\napt-cache show packagename\n```\n\n\n\n# Windwos 下的脚本\n\nwindows 下显示环境变量\n\n`echo %http_proxy%`\n\nwindows 下设置代理服务器\n$$\n\n$$\n\n```sh\nset http_proxy=http://username:pwd$$$@proxy-rzf:8080\nset https_proxy=http://username:pwd$$$@proxy-rzf:8080\n```\n\n","source":"_posts/IT/Tools/有用的shell命令.md","raw":"---\ntitle: 有用的Shell命令\ndate: 2019-07-30 17:30:28\nurlname: helpfull-shell-command\ntoc: true\ntags: [工具]\ncategories: [IT, Tools]\nnotshow: true\n---\n\n在线网站可以找到基本的东西:[Linux命令大全](https://man.linuxde.net/) [shell 正则表达式](https://man.linuxde.net/docs/shell_regex.html)\n\n# 文件&内容检索\n\n## 正则表达式注意的地方\n\n- 花括号之前要加转义字符 `[a-z]\\{3\\}`\n- 空格就是转义加空格`\\ `,而不是`\\s` 。如 `[a-z0-9_\\ ]\\{3,\\}`\n- 这几个符号 `_ - . #`都不需要加转义符。\n- 不要轻易加==行结束符==$,可能回车才是最后符号,所以可能找不到。\n\n\n\n## grep\n\n```sh\n# -r 递归搜索子目录\n# -l 只显示文件\n# -n 显示文件和匹配的行\n# 搜索 “markdown” 字符串并输入到文件里\n# Formating the Results...\ngrep $begrif $directory $args |awk '{ print \"[\" $1 \"](\" $1 \")\\n\" }' > suchergebnisse.md\n# 将结果转为Windows目录\nsed -i -- 's/\\/D\\//D:\\/\\//g' suchergebnisse.md\necho \"Fertig! Ergebnisse siehe Datei 'suchergebnisse.md'\"\nread\n```\n\n[更多参数请读此文](https://blog.csdn.net/u013485792/article/details/52243479) 示例脚本\n\n`grep` 正则表达式的例子\n\n```sh\n#!bin/bash\n# {#part0000_split_050.html#nav_point-99 .calibre13}\nresult=$(grep '{#part0000_split_[0-9]\\{3\\}.html[a-z0-9_\\ -.#]\\{3,\\}calibre13}' 文件名)\n\nif [ \"$result\" = \"\" ];\nthen\n\techo \"Nichts gefunden!\"\nfi\n\necho $result\nread\n```\n\ngrep或操作\n\n```sh\ngrep -E '123|abc' filename // 找出文件(filename)中包含123或者包含abc的行\negrep '123|abc' filename // 用egrep同样可以实现\nawk '/123|abc/' filename // awk 的实现方式\n```\n\ngrep与操作\n\n```sh\ngrep pattern1 files | grep pattern2 //显示既匹配 pattern1 又匹配 pattern2 的行。\n```\n\n其它常用选项\n\n```sh\ngrep -i pattern files //不区分大小写地搜索。默认情况区分大小写,\ngrep -l pattern files //只列出匹配的文件名,\ngrep -L pattern files //列出不匹配的文件名,\ngrep -w pattern files //只匹配整个单词,而不是字符串的一部分(如匹配‘magic’,而不是‘magical’),\ngrep -C number pattern files //匹配的上下文分别显示[number]行,\n```\n\n{% fold 点击显/隐代码 %}\n\n\n{% endfold %}\n\n## sed 命令\n\n[参考文献](https://man.linuxde.net/sed)\n\n### 文本替代\n\n以下文本替换通过`pandoc`导入后的文件,残留很多内部跳转链接:如\n\n```sh\n{#part0000_split_003.html#nav_point_1 .not-in-toc}\n```\n\n\n\n```bash\n#!bin/bash\necho running\n#sed 's/^#part0000_split_$/p' -f ../Linux_shell_Anleitung.md ;\nsed -i -- 's/^\\[\\]{#part0000_split_[0-9]\\{3\\}.html}$//g' ../Linux_shell_Anleitung.md \n\n#{#part0000_split_017.html#nav_point_21 .calibre8} {#part0000_split_003.html#nav_point_1 .not-in-toc}\nsed -i -- 's/{#part0000_split_[0-9]\\{3\\}.html#[a-z0-9_-]\\+ .[a-z0-9_-]\\+}//g' ../Linux_shell_Anleitung.md \n\necho fertig!\nread\n```\n\n### 整行替代\n\n[参考文献](https://www.cnblogs.com/wangqiguo/p/6718512.html)\n\n替代以 `categories:` 开头的整行(允许行开头有空格或制表符)。`c` 代表整行,以字符串 *categories: [IE]* 替代整行。\n\n```sh\n# Linux 下的写法\nsed -i -- '/^[[:blank:]]*categories:/c categories: [IE]' result.txt \n# Mac 下的写法\nsed -i '' 's/^[[:blank:]]*tags:.*/tags: [心理]/' $1 \n```\n\n错误:如果将参数 `c` 写在前面,会将整个文本每一行都替换掉。\n\n```sh\n# Linux 下的写法\nsed -i -- 'c/^[[:blank:]]*categories:/categories: [IE]/' result.txt \n```\n\n\n\n## find\n\n```sh\n# 查找所有的 md 文件\nfind /root/bibliothek/markdowns/blog_posts/ -type f -name \"*.md\" \n# 查找一天之前的文件, 一小时前时 -1h,一周 -1w\nfind . -type f -mtime -1d\n```\n\n如果要处理复杂的事情,就要用到函数\n\n```sh\n# 定义函数\nshowFileInfo(){\n echo $1\n}\n\n# 声明函数\nexport -f showFileInfo\n# 使用函数\nfind $dirPath -name \"*.md\" | xargs -n 1 -P 10 -I {} bash -c 'showFileInfo \"$@\"' _ {} \\;\n```\n\n\n\n## 查找最新文件\n\n- 将文件按从新到旧排列,取第一个。\n\n `ls -t *.cpp | head -1`\n\n- 将文件按从旧到新排列,取最后一个。\n\n `ls -rt *.cpp | tail -1`\n\n- 列出文件时间戳\n\n `ls -l simpleNode.js |awk '{print $6 \"-\" $7 \"-\" $8 }'`\n\n- 整合以上两个命令,找到最新的文件,读取时间戳 \n\n `ls -t *.* | head -1 | xargs ls -l | awk '{print $6 \"-\" $7 \"-\" $8 }'`\n\n\n\n# 字符串处理\n\n[字符串处理参考文献](https://www.jianshu.com/p/5709118af1c6) [将分隔符的字符串转为数组的几种方法](https://blog.csdn.net/Jerry_1126/article/details/83930956)\n\n配合使用,可以直接用 shell 实现文件内标签和分类的替换。\n\n## 数组转字符串\n\n使用分隔符将数组转字符串:\n\n```sh\nids=(1 2 3 4); \nlst=$( IFS='/'; echo \"${ids[*]}\" ); \necho $lst\n# 结果是:1/2/3/4\n```\n\n## 字符串转数组\n\n[懒得写,看范例](https://blog.csdn.net/Jerry_1126/article/details/83930956)\n\n## 字符串替换\n\n```sh\n# 原串 [娱乐,经济,重要] => 目标串 [娱乐, 经济, 重要]\n${tags/,/, } # 只替换了一个,结果变成 [娱乐, 经济,重要]\n${tags//,/, } # 替换了所有符合的,结果变成 [娱乐, 经济, 重要]\n# 原串 [重要] => 目标串 重要\n${tags//[\\[\\] ]/}\n```\n\n### 消除回车符、换行符、制表符\n\n```sh\n# arg是个字符串变量, 可能带有回车符\\r\n# 把它整个作为参数使用会带来很多麻烦。用以下命令将其替换掉\nnewvar=${arg//[$'\\t\\r\\n']/}\n```\n\n\n\n## 详细用法\n\n[参考文献](https://blog.csdn.net/ljianhui/article/details/43128465)\n\n1. `${var##*/}`\n该命令的作用是去掉变量var从左边算起的最后一个'/'字符及其左边的内容,返回从左边算起的最后一个'/'(不含该字符)的右边的内容。使用例子及结果如下:\n\n```sh\nvar=dir1/dir2/file.txt \n--> file.txt\n```\n\n从运行结果可以看到,使用该命令,可以提取出我们需要的文件名*file.txt*。\n\n若使用时在shell程序文件中,可以使用变量来保存这个结果,再加以利用,如file=`${var##*/}`\n\n2. `${var##*.}`\n该命令的作用是去掉变量var从左边算起的最后一个'.'字符及其左边的内容,返回从左边算起的最后一个'.'(不含该字符)的右边的内容。使用例子及结果如下:\n\n```sh\nvar=dir1/dir2/file.txt \n--> txt\n```\n\n从运行结果可以看到,使用该命令,可以提取出我们需要的文件后缀。\n\n如果文件的后缀不仅有一个,例如,file.tar.gz,命令`${var##*.}`仅能提取最后一个后缀,而我想提取tar.gz时该怎么办?那么就要用下面所说的`${var#*.}`命令了。\n\n3. `${var#*.}`\n该命令的作用是去掉变量var从左边算起的第一个'.'字符及其左边的内容,返回从左边算起第一个'.'(不含该字符)的右边部分的内容。使用例子及结果如下:\n\n```sh\nvar=dir1/dir2/file.tar.gz \n--> tar.gz\n```\n\n从运行结果可以看到,使用该命令,可以提取出文件的多个后缀。\n\n4. `${var%/*}`\n 该命令的使用是去掉变量var从右边算起的第一个'/'字符及其右边的内容,返回从右边算起的第一个'/'(不含该字符)的左边的内容。使用例子及结果如下:\n\n```sh\nvar=dir1/dir2/file.txt \n--> dir1/dir2\n```\n\n\n\n从运行的结果可以看到,使用该命令,可以提取出我们需要的文件所在的目录\n\n5. `${var%%.*}`\n该命令的使用是去掉变量var从右边算起的最后一个'.'字符及其右边的内容,返回从右边算起的最后一个'.'(不含该字符)的左边的内容。使用例子及结果如下:\n\n```sh\nvar=dir1/dir2/file.txt \n--> dir1/dir2/file\n```\n\n当我们需要建立一个与文件名相同名字(没有后缀)的目录与对应的文件相对应时,就可以使用该命令来进行操作。例如,解压文件的情况就与此类似,我们压缩文件file.zip时,会在与file.zip同级目录下建立一个名为file的目录。\n\n6. 总结\n\n 其实${}并不是专门为提取文件名或目录名的,它的使用是变量的提取和替换等等操作,它可以提取非常多的内容,并不一定是上面五个例子中的'/'或'.'。也就是说,上面的使用方法只是它使用的一个特例。\n\n\n\n看到上面的这些命令,可能会让人感到非常难以理解和记忆,其实不然,它们都是有规律的。\n\n- \\#:表示从左边算起第一个\n\n- %:表示从右边算起第一个\n\n- \\##:表示从左边算起最后一个\n\n- %%:表示从右边算起最后一个\n\n换句话来说,#总是表示左边算起,%总是表示右边算起。\n\n*:表示要删除的内容,对于#和##的情况,它位于指定的字符(例子中的'/'和'.')的左边,表于删除指定字符及其左边的内容;对于%和%%的情况,它位于指定的字符(例子中的'/'和'.')的右边,表示删除指定字符及其右边的内容。这里的'*'的位置不能互换,即不能把*号放在#或##的右边,反之亦然。\n\n例如:`${var%%x*}`表示找出从右边算起最后一个字符x,并删除字符x及其右边的字符。\n\n看到这里,就可以知道,其实该命令的用途非常广泛,上面只是指针文件名和目录名的命名特性来进行提取的一些特例而已。\n\n## basename和dirname\n\n`${}`并不是专门为提取文件名和目录名设计的命令,那么`basename`和`dirname`命令就是专门为做这一件事而已准备的了。\n\n1. `basename`\n 该命令的作用是从路径中提取出文件名,使用方法为basename NAME [SUFFIX]。\n\n 1.1 从路径中提出出文件名(带后缀),例子如下:\n\n 1.2 从上面命令的用法中可以看到,后缀(SUFFIX)是一个可选项。所以,若只想提取出文件名file,而不带有后缀,还可以在变量的后面加上后缀名,例子如下:\n\n\n2. `dirname`\n该命令的作用是从路径中提取出目录名,使用方法为 dirname NAME。使用例子如下:\n\n这样就提取出了file.txt文件所在的目录。\n\n注:该命令不仅能提取出普通文件所的目录,它能提取出任何文件所在的目录,例如目录所在的目录,如下:\n\n它提取出了目录dir2所在的目录dir1.\n\n---------------------\n\n\n\n# 查看硬盘剩余空间\n\n```sh\n# 整个硬盘空间\ndf -hl\n# 查看某个文件夹大小\ndu -h your_directory # 列出每个子文件夹大小\ndu -hcs your_directory # 汇总\n```\n\n\n\n## 查看 package 版本\n\n```sh\napt-cache show packagename\n```\n\n\n\n# Windwos 下的脚本\n\nwindows 下显示环境变量\n\n`echo %http_proxy%`\n\nwindows 下设置代理服务器\n$$\n\n$$\n\n```sh\nset http_proxy=http://username:pwd$$$@proxy-rzf:8080\nset https_proxy=http://username:pwd$$$@proxy-rzf:8080\n```\n\n","slug":"IT/Tools/有用的shell命令","published":1,"updated":"2019-08-14T13:12:36.000Z","_id":"cka1y599o004i4huuvxxo90p7","comments":1,"layout":"post","photos":[],"link":"","content":"

在线网站可以找到基本的东西:Linux命令大全 shell 正则表达式

\n

文件&内容检索

\n

正则表达式注意的地方

\n
    \n
  • 花括号之前要加转义字符 [a-z]\\{3\\}
  • \n
  • 空格就是转义加空格\\ ,而不是\\s 。如 [a-z0-9_\\ ]\\{3,\\}
  • \n
  • 这几个符号 _ - . #都不需要加转义符。
  • \n
  • 不要轻易加==行结束符==$,可能回车才是最后符号,所以可能找不到。
  • \n
\n\n

grep

\n
1
2
3
4
5
6
7
8
9
10
# -r 递归搜索子目录
# -l 只显示文件
# -n 显示文件和匹配的行
# 搜索 “markdown” 字符串并输入到文件里
# Formating the Results...
grep $begrif $directory $args |awk '{ print \"[\" $1 \"](\" $1 \")\\n\" }' > suchergebnisse.md
# 将结果转为Windows目录
sed -i -- 's/\\/D\\//D:\\/\\//g' suchergebnisse.md
echo \"Fertig! Ergebnisse siehe Datei 'suchergebnisse.md'\"
read
\n

更多参数请读此文 示例脚本

\n

grep 正则表达式的例子

\n
1
2
3
4
5
6
7
8
9
10
11
#!bin/bash
# {#part0000_split_050.html#nav_point-99 .calibre13}
result=$(grep '{#part0000_split_[0-9]\\{3\\}.html[a-z0-9_\\ -.#]\\{3,\\}calibre13}' 文件名)

if [ \"$result\" = \"\" ];
then
\techo \"Nichts gefunden!\"
fi

echo $result
read
\n

grep或操作

\n
1
2
3
grep -E '123|abc' filename  // 找出文件(filename)中包含123或者包含abc的行
egrep '123|abc' filename // 用egrep同样可以实现
awk '/123|abc/' filename // awk 的实现方式
\n

grep与操作

\n
1
grep pattern1 files | grep pattern2 //显示既匹配 pattern1 又匹配 pattern2 的行。
\n

其它常用选项

\n
1
2
3
4
5
grep -i pattern files   //不区分大小写地搜索。默认情况区分大小写,
grep -l pattern files //只列出匹配的文件名,
grep -L pattern files //列出不匹配的文件名,
grep -w pattern files //只匹配整个单词,而不是字符串的一部分(如匹配‘magic’,而不是‘magical’),
grep -C number pattern files //匹配的上下文分别显示[number]行,
\n
点击显/隐代码
\n\n
\n

sed 命令

\n

参考文献

\n

文本替代

\n

以下文本替换通过pandoc导入后的文件,残留很多内部跳转链接:如

\n
1
{#part0000_split_003.html#nav_point_1 .not-in-toc}
\n
1
2
3
4
5
6
7
8
9
10
#!bin/bash
echo running
#sed 's/^#part0000_split_$/p' -f ../Linux_shell_Anleitung.md ;
sed -i -- 's/^\\[\\]{#part0000_split_[0-9]\\{3\\}.html}$//g' ../Linux_shell_Anleitung.md

#{#part0000_split_017.html#nav_point_21 .calibre8} {#part0000_split_003.html#nav_point_1 .not-in-toc}
sed -i -- 's/{#part0000_split_[0-9]\\{3\\}.html#[a-z0-9_-]\\+ .[a-z0-9_-]\\+}//g' ../Linux_shell_Anleitung.md

echo fertig!
read
\n

整行替代

\n

参考文献

\n

替代以 categories: 开头的整行(允许行开头有空格或制表符)。c 代表整行,以字符串 categories: [IE] 替代整行。

\n
1
2
3
4
# Linux 下的写法
sed -i -- '/^[[:blank:]]*categories:/c categories: [IE]' result.txt
# Mac 下的写法
sed -i '' 's/^[[:blank:]]*tags:.*/tags: [心理]/' $1
\n

错误:如果将参数 c 写在前面,会将整个文本每一行都替换掉。

\n
1
2
# Linux 下的写法
sed -i -- 'c/^[[:blank:]]*categories:/categories: [IE]/' result.txt
\n

find

\n
1
2
3
4
# 查找所有的 md 文件
find /root/bibliothek/markdowns/blog_posts/ -type f -name \"*.md\"
# 查找一天之前的文件, 一小时前时 -1h,一周 -1w
find . -type f -mtime -1d
\n

如果要处理复杂的事情,就要用到函数

\n
1
2
3
4
5
6
7
8
9
# 定义函数
showFileInfo(){
echo $1
}

# 声明函数
export -f showFileInfo
# 使用函数
find $dirPath -name \"*.md\" | xargs -n 1 -P 10 -I {} bash -c 'showFileInfo \"$@\"' _ {} \\;
\n

查找最新文件

\n
    \n
  • \n

    将文件按从新到旧排列,取第一个。

    \n

    ls -t *.cpp | head -1

    \n
  • \n
  • \n

    将文件按从旧到新排列,取最后一个。

    \n

    ls -rt *.cpp | tail -1

    \n
  • \n
  • \n

    列出文件时间戳

    \n

    ls -l simpleNode.js |awk '{print $6 "-" $7 "-" $8 }'

    \n
  • \n
  • \n

    整合以上两个命令,找到最新的文件,读取时间戳

    \n

    ls -t *.* | head -1 | xargs ls -l | awk '{print $6 "-" $7 "-" $8 }'

    \n
  • \n
\n

字符串处理

\n

字符串处理参考文献 将分隔符的字符串转为数组的几种方法

\n

配合使用,可以直接用 shell 实现文件内标签和分类的替换。

\n

数组转字符串

\n

使用分隔符将数组转字符串:

\n
1
2
3
4
ids=(1 2 3 4); 
lst=$( IFS='/'; echo \"${ids[*]}\" );
echo $lst
# 结果是:1/2/3/4
\n

字符串转数组

\n

懒得写,看范例

\n

字符串替换

\n
1
2
3
4
5
# 原串 [娱乐,经济,重要] => 目标串 [娱乐, 经济, 重要]
${tags/,/, } # 只替换了一个,结果变成 [娱乐, 经济,重要]
${tags//,/, } # 替换了所有符合的,结果变成 [娱乐, 经济, 重要]
# 原串 [重要] => 目标串 重要
${tags//[\\[\\] ]/}
\n

消除回车符、换行符、制表符

\n
1
2
3
# arg是个字符串变量, 可能带有回车符\\r
# 把它整个作为参数使用会带来很多麻烦。用以下命令将其替换掉
newvar=${arg//[$'\\t\\r\\n']/}
\n

详细用法

\n

参考文献

\n
    \n
  1. ${var##*/}
    \n该命令的作用是去掉变量var从左边算起的最后一个’/‘字符及其左边的内容,返回从左边算起的最后一个’/’(不含该字符)的右边的内容。使用例子及结果如下:
  2. \n
\n
1
2
var=dir1/dir2/file.txt 
--> file.txt
\n

从运行结果可以看到,使用该命令,可以提取出我们需要的文件名file.txt

\n

若使用时在shell程序文件中,可以使用变量来保存这个结果,再加以利用,如file=${var##*/}

\n
    \n
  1. ${var##*.}
    \n该命令的作用是去掉变量var从左边算起的最后一个’.‘字符及其左边的内容,返回从左边算起的最后一个’.’(不含该字符)的右边的内容。使用例子及结果如下:
  2. \n
\n
1
2
var=dir1/dir2/file.txt 
--> txt
\n

从运行结果可以看到,使用该命令,可以提取出我们需要的文件后缀。

\n

如果文件的后缀不仅有一个,例如,file.tar.gz,命令${var##*.}仅能提取最后一个后缀,而我想提取tar.gz时该怎么办?那么就要用下面所说的${var#*.}命令了。

\n
    \n
  1. ${var#*.}
    \n该命令的作用是去掉变量var从左边算起的第一个’.‘字符及其左边的内容,返回从左边算起第一个’.’(不含该字符)的右边部分的内容。使用例子及结果如下:
  2. \n
\n
1
2
var=dir1/dir2/file.tar.gz 
--> tar.gz
\n

从运行结果可以看到,使用该命令,可以提取出文件的多个后缀。

\n
    \n
  1. ${var%/*}
    \n该命令的使用是去掉变量var从右边算起的第一个’/‘字符及其右边的内容,返回从右边算起的第一个’/’(不含该字符)的左边的内容。使用例子及结果如下:
  2. \n
\n
1
2
var=dir1/dir2/file.txt 
--> dir1/dir2
\n

从运行的结果可以看到,使用该命令,可以提取出我们需要的文件所在的目录

\n
    \n
  1. ${var%%.*}
    \n该命令的使用是去掉变量var从右边算起的最后一个’.‘字符及其右边的内容,返回从右边算起的最后一个’.’(不含该字符)的左边的内容。使用例子及结果如下:
  2. \n
\n
1
2
var=dir1/dir2/file.txt 
--> dir1/dir2/file
\n

当我们需要建立一个与文件名相同名字(没有后缀)的目录与对应的文件相对应时,就可以使用该命令来进行操作。例如,解压文件的情况就与此类似,我们压缩文件file.zip时,会在与file.zip同级目录下建立一个名为file的目录。

\n
    \n
  1. 总结
  2. \n
\n

其实${}并不是专门为提取文件名或目录名的,它的使用是变量的提取和替换等等操作,它可以提取非常多的内容,并不一定是上面五个例子中的’/‘或’.’。也就是说,上面的使用方法只是它使用的一个特例。

\n

看到上面的这些命令,可能会让人感到非常难以理解和记忆,其实不然,它们都是有规律的。

\n
    \n
  • \n

    #:表示从左边算起第一个

    \n
  • \n
  • \n

    %:表示从右边算起第一个

    \n
  • \n
  • \n

    ##:表示从左边算起最后一个

    \n
  • \n
  • \n

    %%:表示从右边算起最后一个

    \n
  • \n
\n

换句话来说,#总是表示左边算起,%总是表示右边算起。

\n

*:表示要删除的内容,对于#和##的情况,它位于指定的字符(例子中的’/‘和’.’)的左边,表于删除指定字符及其左边的内容;对于%和%%的情况,它位于指定的字符(例子中的’/‘和’.’)的右边,表示删除指定字符及其右边的内容。这里的’'的位置不能互换,即不能把号放在#或##的右边,反之亦然。

\n

例如:${var%%x*}表示找出从右边算起最后一个字符x,并删除字符x及其右边的字符。

\n

看到这里,就可以知道,其实该命令的用途非常广泛,上面只是指针文件名和目录名的命名特性来进行提取的一些特例而已。

\n

basename和dirname

\n

${}并不是专门为提取文件名和目录名设计的命令,那么basenamedirname命令就是专门为做这一件事而已准备的了。

\n
    \n
  1. basename
    \n该命令的作用是从路径中提取出文件名,使用方法为basename NAME [SUFFIX]。
  2. \n
\n

1.1 从路径中提出出文件名(带后缀),例子如下:

\n

1.2 从上面命令的用法中可以看到,后缀(SUFFIX)是一个可选项。所以,若只想提取出文件名file,而不带有后缀,还可以在变量的后面加上后缀名,例子如下:

\n
    \n
  1. dirname
    \n该命令的作用是从路径中提取出目录名,使用方法为 dirname NAME。使用例子如下:
  2. \n
\n

这样就提取出了file.txt文件所在的目录。

\n

注:该命令不仅能提取出普通文件所的目录,它能提取出任何文件所在的目录,例如目录所在的目录,如下:

\n

它提取出了目录dir2所在的目录dir1.

\n
\n

查看硬盘剩余空间

\n
1
2
3
4
5
# 整个硬盘空间
df -hl
# 查看某个文件夹大小
du -h your_directory # 列出每个子文件夹大小
du -hcs your_directory # 汇总
\n

查看 package 版本

\n
1
apt-cache show packagename
\n

Windwos 下的脚本

\n

windows 下显示环境变量

\n

echo %http_proxy%

\n

windows 下设置代理服务器
\n$$

\n

$$

\n
1
2
set http_proxy=http://username:pwd$$$@proxy-rzf:8080
set https_proxy=http://username:pwd$$$@proxy-rzf:8080
\n","site":{"data":{}},"excerpt":"

在线网站可以找到基本的东西:Linux命令大全 shell 正则表达式

\n

文件&内容检索

\n

正则表达式注意的地方

\n
    \n
  • 花括号之前要加转义字符 [a-z]\\{3\\}
  • \n
  • 空格就是转义加空格\\ ,而不是\\s 。如 [a-z0-9_\\ ]\\{3,\\}
  • \n
  • 这几个符号 _ - . #都不需要加转义符。
  • \n
  • 不要轻易加==行结束符==$,可能回车才是最后符号,所以可能找不到。
  • \n
","more":"

grep

\n\n

更多参数请读此文 示例脚本

\n

grep 正则表达式的例子

\n\n

grep或操作

\n\n

grep与操作

\n\n

其它常用选项

\n\n
点击显/隐代码
\n\n
\n

sed 命令

\n

参考文献

\n

文本替代

\n

以下文本替换通过pandoc导入后的文件,残留很多内部跳转链接:如

\n\n\n

整行替代

\n

参考文献

\n

替代以 categories: 开头的整行(允许行开头有空格或制表符)。c 代表整行,以字符串 categories: [IE] 替代整行。

\n\n

错误:如果将参数 c 写在前面,会将整个文本每一行都替换掉。

\n\n

find

\n\n

如果要处理复杂的事情,就要用到函数

\n\n

查找最新文件

\n
    \n
  • \n

    将文件按从新到旧排列,取第一个。

    \n

    ls -t *.cpp | head -1

    \n
  • \n
  • \n

    将文件按从旧到新排列,取最后一个。

    \n

    ls -rt *.cpp | tail -1

    \n
  • \n
  • \n

    列出文件时间戳

    \n

    ls -l simpleNode.js |awk '{print $6 "-" $7 "-" $8 }'

    \n
  • \n
  • \n

    整合以上两个命令,找到最新的文件,读取时间戳

    \n

    ls -t *.* | head -1 | xargs ls -l | awk '{print $6 "-" $7 "-" $8 }'

    \n
  • \n
\n

字符串处理

\n

字符串处理参考文献 将分隔符的字符串转为数组的几种方法

\n

配合使用,可以直接用 shell 实现文件内标签和分类的替换。

\n

数组转字符串

\n

使用分隔符将数组转字符串:

\n\n

字符串转数组

\n

懒得写,看范例

\n

字符串替换

\n\n

消除回车符、换行符、制表符

\n\n

详细用法

\n

参考文献

\n
    \n
  1. ${var##*/}
    \n该命令的作用是去掉变量var从左边算起的最后一个’/‘字符及其左边的内容,返回从左边算起的最后一个’/’(不含该字符)的右边的内容。使用例子及结果如下:
  2. \n
\n\n

从运行结果可以看到,使用该命令,可以提取出我们需要的文件名file.txt

\n

若使用时在shell程序文件中,可以使用变量来保存这个结果,再加以利用,如file=${var##*/}

\n
    \n
  1. ${var##*.}
    \n该命令的作用是去掉变量var从左边算起的最后一个’.‘字符及其左边的内容,返回从左边算起的最后一个’.’(不含该字符)的右边的内容。使用例子及结果如下:
  2. \n
\n\n

从运行结果可以看到,使用该命令,可以提取出我们需要的文件后缀。

\n

如果文件的后缀不仅有一个,例如,file.tar.gz,命令${var##*.}仅能提取最后一个后缀,而我想提取tar.gz时该怎么办?那么就要用下面所说的${var#*.}命令了。

\n
    \n
  1. ${var#*.}
    \n该命令的作用是去掉变量var从左边算起的第一个’.‘字符及其左边的内容,返回从左边算起第一个’.’(不含该字符)的右边部分的内容。使用例子及结果如下:
  2. \n
\n\n

从运行结果可以看到,使用该命令,可以提取出文件的多个后缀。

\n
    \n
  1. ${var%/*}
    \n该命令的使用是去掉变量var从右边算起的第一个’/‘字符及其右边的内容,返回从右边算起的第一个’/’(不含该字符)的左边的内容。使用例子及结果如下:
  2. \n
\n\n

从运行的结果可以看到,使用该命令,可以提取出我们需要的文件所在的目录

\n
    \n
  1. ${var%%.*}
    \n该命令的使用是去掉变量var从右边算起的最后一个’.‘字符及其右边的内容,返回从右边算起的最后一个’.’(不含该字符)的左边的内容。使用例子及结果如下:
  2. \n
\n\n

当我们需要建立一个与文件名相同名字(没有后缀)的目录与对应的文件相对应时,就可以使用该命令来进行操作。例如,解压文件的情况就与此类似,我们压缩文件file.zip时,会在与file.zip同级目录下建立一个名为file的目录。

\n
    \n
  1. 总结
  2. \n
\n

其实${}并不是专门为提取文件名或目录名的,它的使用是变量的提取和替换等等操作,它可以提取非常多的内容,并不一定是上面五个例子中的’/‘或’.’。也就是说,上面的使用方法只是它使用的一个特例。

\n

看到上面的这些命令,可能会让人感到非常难以理解和记忆,其实不然,它们都是有规律的。

\n
    \n
  • \n

    #:表示从左边算起第一个

    \n
  • \n
  • \n

    %:表示从右边算起第一个

    \n
  • \n
  • \n

    ##:表示从左边算起最后一个

    \n
  • \n
  • \n

    %%:表示从右边算起最后一个

    \n
  • \n
\n

换句话来说,#总是表示左边算起,%总是表示右边算起。

\n

*:表示要删除的内容,对于#和##的情况,它位于指定的字符(例子中的’/‘和’.’)的左边,表于删除指定字符及其左边的内容;对于%和%%的情况,它位于指定的字符(例子中的’/‘和’.’)的右边,表示删除指定字符及其右边的内容。这里的’'的位置不能互换,即不能把号放在#或##的右边,反之亦然。

\n

例如:${var%%x*}表示找出从右边算起最后一个字符x,并删除字符x及其右边的字符。

\n

看到这里,就可以知道,其实该命令的用途非常广泛,上面只是指针文件名和目录名的命名特性来进行提取的一些特例而已。

\n

basename和dirname

\n

${}并不是专门为提取文件名和目录名设计的命令,那么basenamedirname命令就是专门为做这一件事而已准备的了。

\n
    \n
  1. basename
    \n该命令的作用是从路径中提取出文件名,使用方法为basename NAME [SUFFIX]。
  2. \n
\n

1.1 从路径中提出出文件名(带后缀),例子如下:

\n

1.2 从上面命令的用法中可以看到,后缀(SUFFIX)是一个可选项。所以,若只想提取出文件名file,而不带有后缀,还可以在变量的后面加上后缀名,例子如下:

\n
    \n
  1. dirname
    \n该命令的作用是从路径中提取出目录名,使用方法为 dirname NAME。使用例子如下:
  2. \n
\n

这样就提取出了file.txt文件所在的目录。

\n

注:该命令不仅能提取出普通文件所的目录,它能提取出任何文件所在的目录,例如目录所在的目录,如下:

\n

它提取出了目录dir2所在的目录dir1.

\n
\n

查看硬盘剩余空间

\n\n

查看 package 版本

\n\n

Windwos 下的脚本

\n

windows 下显示环境变量

\n

echo %http_proxy%

\n

windows 下设置代理服务器
\n$$

\n

$$

\n"},{"title":"用TypeScript编写JS函数库","date":"2019-08-16T20:15:28.000Z","urlname":"TypeScript-build-JS-Package","toc":true,"_content":"\n本文具体介绍如何用TypeScript编写JavaScript库文件,以及制作npm工具包。主要参考下面两篇文章。我也省却一步步解释,只罗列相关的代码和我遇到的坑。想知道代码含义的请参阅原帖\n\n- [TypeScript第一步](http://imzc.me/dev/2016/11/22/getting-start-with-typescript/)\n- [如何使用Gulp构建TypeScript](https://www.gowhich.com/blog/869)\n- [从Javascript迁移到Typescript](https://zhongsp.gitbooks.io/typescript-handbook/doc/handbook/tutorials/Migrating%20from%20JavaScript.html) *只看相关的那一章就可以*\n\n\n\n\n# 安装 TypeScript\n\n终端执行 `npm install typescript -g` \n\n```sh\n$ tsc --version\nVersion 3.5.3\n```\n\n# 创建工程\n\n1. 初始化项目\n\n```sh\nmkdir typescript_demo && cd typescript_demo\nnpm init -y # 初始化项目,会生成 package.json 文件\n```\n\n2. 安装Gulp, 并在项目根目录下新建 `gulpfile.js` 文件\n\n```sh\nnpm install gulp-cli gulp typescript gulp-typescript --save-dev\n```\n\n3. 在命令行中执行 `tsc --init` 可以在当前目录中快速创建一个 tsconfig.json 文件。\n\n4. 安装 Browserify :目的是把所有**ts**文件打包成一个单一的**js**文件。\n\n```sh\nnpm install browserify tsify vinyl-source-stream --save-dev\n```\n\n5. Watchify、Babel和Uglify :目的是让编译器保持运行,无需每次修改手动编译。\n\nnpm install watchify gulp-util --save-dev\n\n```sh\nnpm install watchify gulp-util --save-dev\n```\n\n6. 安装 Uglify : 将输出文件 bundle.js 压缩\n\n```sh\nnpm install gulp-uglify vinyl-buffer gulp-sourcemaps --save-dev\n```\n\n7. Babel :允许按新标准**ES6**编写代码,而最终会编译**es05**标准,兼容低版本浏览器。\n\n```sh\nnpm install babelify babel-core babel-preset-env vinyl-buffer gulp-sourcemaps --save-dev\n```\n\n:bangbang: 安装中出现了错误, 显示babelify 版本太低. 将命令改为 `npm install babelify@8` 就能顺利进行下去了.\n\n\n\n\n8. 编写主文件 `src/main.ts` (*名字随便起*),在 `package.json` 中改为 $ \"main\": \"./dist/main.js\", $。创建两文件夹 `src` 和 `dist`,分别放置原文件和编译后的文件。为演示调用,再新建一个 `src/greet.ts` 文件\n\n ```typescript\n # src/greet.ts\n declare function require(path: string): any;\n \n export function sayHello(name: string) {\n console.log(ln)\n return `Hallo von ${name}`;\n }\n ```\n\n ```typescript\n # src/main.ts\n import { sayHello } from \"./greet\";\n \n function showHello(idName: string, name: string) {\n const elt = document.getElementById(idName);\n elt.innerText = sayHello(name);\n }\n \n showHello(\"greeting\", \"TypeScript\");\n ```\n\n9. 新建 `src/index.html` \n\n```html\n\n\n \n \n Hello World!\n \n \n

Loading ...

\n \n \n\n```\n\n10. 修改 `gulpfile.js` \n\n```javascript\nconst gulp = require(\"gulp\");\nconst browserify = require(\"browserify\");\nconst source = require('vinyl-source-stream');\nconst tsify = require(\"tsify\");\nconst watchify = require(\"watchify\");\nconst gutil = require(\"gulp-util\");\nconst uglify = require('gulp-uglify');\nconst sourcemaps = require('gulp-sourcemaps');\nconst buffer = require('vinyl-buffer');\nconst paths = {\n pages: ['src/*.html']\n};\n\nconst watchedBrowserify = watchify(browserify({\n basedir: '.',\n debug: true,\n entries: ['src/main.ts'],\n cache: {},\n packageCache: {}\n}).plugin(tsify));\n\ngulp.task(\"copy-html\", function () {\n return gulp.src(paths.pages)\n .pipe(gulp.dest(\"dist\"));\n})\n\nfunction browserifyBundle() {\n return watchedBrowserify\n .transform('babelify', {\n presets: ['env'],\n extensions: ['.ts']\n })\n .bundle()\n .pipe(source('bundle.js'))\n .pipe(buffer())\n .pipe(sourcemaps.init({\n loadMaps: true\n }))\n .pipe(uglify())\n .pipe(sourcemaps.write('./'))\n .pipe(gulp.dest(\"dist\"));\n}\n\ngulp.task(\"browserify\", function () {\n return browserifyBundle();\n})\n\ngulp.task(\"default\", gulp.series('copy-html', 'browserify'));\nwatchedBrowserify.on(\"update\", browserifyBundle);\nwatchedBrowserify.on(\"log\", gutil.log);\n```\n11. 修改 tsconfig.json\n\n ```json\n {\n \"files\": [\n \"src/*.ts\"\n ],\n \"compilerOptions\": {\n \"noImplicitAny\": true,\n \"target\": \"es2015\"\n }\n }\n ```\n\n12. 编译并在浏览器打开 `dist/index.html`\n\n```sh\n# 通过gulp编译代码\nnpx gulp\n```\n\n> 显示器中会显示 “Hello from TypeScript” 字样。\n\n\n\n我们看到 main.ts 调用了 greet.ts 的函数, 并生成一个 bundle.js 文件, 在 index.html 中被加载使用. \n\n\n\n# 调用JavaScript文件\n\n为了使用以前已经存在的JavaScript库文件, 在 src 下新建一个文件夹 libs 用来存放第三方JavaScript. \n\n> projectRoot\n> ├── src/\n> │ ├── libs/\n> │ │ ├── lunar.js\n> │ ├── main.ts\n> │ └── greet.ts\n> │ \n> ├── dist/\n> └── tsconfig.json\n\n```javascript\n# src/libs/lunar.js\n\nLunar = {\n Name: \"Dick\",\n sayHallo:function(){\n return 'i am Lunar';\n }\n} \n\nfunction Ab () {\n this.a = 1\n }\n \nAb.prototype.seta = function (num) {\n this.a = num\n }\n \nAb.prototype.geta = function (num) {\n return this.a\n }\n \nexports.Ab = Ab\nexports.Lunar = Lunar;\n\n```\n\n修改 `greet.ts` 文件, 调用 `src/libs/lunar.js` 中的函数和对象\n\n```typescript\ndeclare function require(path: string): any;\n\nvar ln = require(\"./libs/lunar\");\n\nexport function sayHello(name: string) {\n \tln.Ab = 10\n console.log(ln.Ab)\n return `Hallo von ${name}, ${ln.Lunar.Name}`;\n}\n```\n\nTypeScript使用`tsconfig.json`文件管理工程配置,例如想包含哪些文件和进行哪些检查。\n\n```json\n{\n \"compilerOptions\": {\n \t\t\"noImplicitAny\": true, \n //\"outDir\": \"./dist\", //不需要. gulpfile.js 已经处理过了\n \"allowJs\": true,\n \"target\": \"es2015\",\n \"esModuleInterop\": true /* Enables emit interoperability between CommonJS and ES Modules via creation of namespace objects for all imports. Implies 'allowSyntheticDefaultImports'. */\n },\n \"files\": [\n \"src/*.ts\"\n ],\n \"include\": [\n \"./src/**/*.js\"\n ]\n}\n```\n\n\n\n我们看到网页显示 *Hallo von TypeScript, Dick*, 打开chrome的开发者工具, 看到console 中写出 `10`. \n\n\n\n# Unit-Test\n\n[参考:Unit testing node applications with Typescript -- using nocha and chai](https://journal.artfuldev.com/unit-testing-node-applications-with-typescript-using-mocha-and-chai-384ef05f32b2)\n\n1. 安装测试包文件\n\n```sh\nnpm install chai mocha ts-node @types/chai @types/mocha --save-dev\n```\n\n2. 新建一个test目录专门存放测试文件,并新建一个测试文件 `test/ganzhi.spec.ts`\n\n```typescript\nimport { expect } from 'chai';\nimport 'mocha';\n\ndescribe('干支 function', () => {\n\n it('should return hello world', () => {\n const result = 'Hello world!';\n expect(result).to.equal('Hello world!');\n });\n \n });\n```\n\n3. 在 `package.json` 文件中配置测试参数和路径\n\n```json\n{\n \"scripts\": {\n \"test\": \"mocha -r ts-node/register test/**/*.spec.ts\"\n }\n}\n```\n\n4. 运行测试\n\n> $ npm run test\n>\n> \\> huahets@1.0.0 test /Users/mai/Projects/huahets\n>\n> \\> mocha -r ts-node/register test/**/*.spec.ts\n>\n> 干支 function\n>\n> ​ ✓ should return hello world\n>\n> 1 passing (19ms)\n\n\n\n## 错误处理\n\n假设有以下函数调用中`LandMaps.FindCity`会给出一个异常。\n\n```typescript\nvar result = LandMaps.FindCity(\"xx省\", \"xx市\");\nexpect(LandMaps.FindCity.bind(LandMaps, \"err\", \"\")).throw(\"Error Message\") # 或者\nexpect(LandMaps.FindCity.bind(LandMaps, \"err\", \"\")).throw(new Error(\"Error Message\"))\n```\n\n\n\n# 打包\n\n[用 TypeScript 编写函数库](https://www.xuejiayuan.net/blog/27db473912f642d8a5fa0e32af3bb600)\n\n[require.js 官方文档](https://requirejs.org/docs/start.html)\n\n通过上述方式生成的 bundle.js 文件不能被浏览器直接使用。参考上面两个网页提供的方式,可以生成给浏览器用的单一js文件。\n\n1. 新建一个入口文件,将所有接口都连接起来,并统一导出\n\n ```typescript\n # yixue.ts\n import {TYDate, TYLunar} from \"./tylunar\";\n import {GanZhi} from \"./ganzhi\";\n import {ShenSha} from \"./shensha\";\n import {WuXing, FetchWuXing} from \"./wuxing\";\n import {Gua} from './gua'\n import {LandMaps} from \"./landmaps\"\n \n exports.GanZhi = GanZhi\n exports.TYDate = TYDate\n exports.Gua = Gua\n ```\n2. 设置`tsconfig.json`让编译后的文件导出到`dist/cmjs`目录\n\n```json\n{\n \"compilerOptions\": {\n \"target\": \"es5\",\n \"module\": \"commonjs\",\n \"moduleResolution\": \"node\",\n \"outDir\": \"dist/cmjs\",\n \"rootDir\": \"./src\",\n \"declaration\": true,\n \"sourceMap\": true,\n \"lib\": [\"dom\", \"es6\"]\n }\n}\n```\n\n3. 通过命令 tsc 编译\n\n```sh\ntsc -P tsconfig.json\n```\n\n也可以在 package.json 中设定,然后运行 `npm run build:cmjs` 编译。编译后的 yixue.js 文件就是统一入口。\n\n4. yi xue.js 实际就是个目录,我需要将其打包成一个单一文件。 安装 browserify , \n\n```sh\nbrowserify dist/cmjs/base/yixue.js --standalone huahejs -o dist/web/yixue.js\n```\n\n5. 下载 [require.js](https://requirejs.org/docs/start.html), 并放到项目目录中。以下方式将 yixue.js 中的 `class GanZhi` 设为当前网页的一个全局函数。其它函数就可以调用。 \n\n```html\n\n\n \n \n 易学包\n \n \n

易学包测试

\n \n\n
\n
gua
\n \n\n```\n\n6. 在 Node.js 中调用更简单\n\n1. ```javascript\n const {Gua, GanZhi, TYDate} = require(\"./web/yixue\")\n ```\n\n\n\n\n\n\n\n\n需要更详细代码请下载项目:\n\n[演示项目地址](https://gitee.com/maiernte/typescript-build-js-package)","source":"_posts/IT/skill/用Typescript编写JS函数库.md","raw":"---\ntitle: 用TypeScript编写JS函数库\ndate: 2019-08-16 22:15:28\nurlname: TypeScript-build-JS-Package\ntoc: true\ntags: [工具]\ncategories: [IT, skill]\n---\n\n本文具体介绍如何用TypeScript编写JavaScript库文件,以及制作npm工具包。主要参考下面两篇文章。我也省却一步步解释,只罗列相关的代码和我遇到的坑。想知道代码含义的请参阅原帖\n\n- [TypeScript第一步](http://imzc.me/dev/2016/11/22/getting-start-with-typescript/)\n- [如何使用Gulp构建TypeScript](https://www.gowhich.com/blog/869)\n- [从Javascript迁移到Typescript](https://zhongsp.gitbooks.io/typescript-handbook/doc/handbook/tutorials/Migrating%20from%20JavaScript.html) *只看相关的那一章就可以*\n\n\n\n\n# 安装 TypeScript\n\n终端执行 `npm install typescript -g` \n\n```sh\n$ tsc --version\nVersion 3.5.3\n```\n\n# 创建工程\n\n1. 初始化项目\n\n```sh\nmkdir typescript_demo && cd typescript_demo\nnpm init -y # 初始化项目,会生成 package.json 文件\n```\n\n2. 安装Gulp, 并在项目根目录下新建 `gulpfile.js` 文件\n\n```sh\nnpm install gulp-cli gulp typescript gulp-typescript --save-dev\n```\n\n3. 在命令行中执行 `tsc --init` 可以在当前目录中快速创建一个 tsconfig.json 文件。\n\n4. 安装 Browserify :目的是把所有**ts**文件打包成一个单一的**js**文件。\n\n```sh\nnpm install browserify tsify vinyl-source-stream --save-dev\n```\n\n5. Watchify、Babel和Uglify :目的是让编译器保持运行,无需每次修改手动编译。\n\nnpm install watchify gulp-util --save-dev\n\n```sh\nnpm install watchify gulp-util --save-dev\n```\n\n6. 安装 Uglify : 将输出文件 bundle.js 压缩\n\n```sh\nnpm install gulp-uglify vinyl-buffer gulp-sourcemaps --save-dev\n```\n\n7. Babel :允许按新标准**ES6**编写代码,而最终会编译**es05**标准,兼容低版本浏览器。\n\n```sh\nnpm install babelify babel-core babel-preset-env vinyl-buffer gulp-sourcemaps --save-dev\n```\n\n:bangbang: 安装中出现了错误, 显示babelify 版本太低. 将命令改为 `npm install babelify@8` 就能顺利进行下去了.\n\n\n\n\n8. 编写主文件 `src/main.ts` (*名字随便起*),在 `package.json` 中改为 $ \"main\": \"./dist/main.js\", $。创建两文件夹 `src` 和 `dist`,分别放置原文件和编译后的文件。为演示调用,再新建一个 `src/greet.ts` 文件\n\n ```typescript\n # src/greet.ts\n declare function require(path: string): any;\n \n export function sayHello(name: string) {\n console.log(ln)\n return `Hallo von ${name}`;\n }\n ```\n\n ```typescript\n # src/main.ts\n import { sayHello } from \"./greet\";\n \n function showHello(idName: string, name: string) {\n const elt = document.getElementById(idName);\n elt.innerText = sayHello(name);\n }\n \n showHello(\"greeting\", \"TypeScript\");\n ```\n\n9. 新建 `src/index.html` \n\n```html\n\n\n \n \n Hello World!\n \n \n

Loading ...

\n \n \n\n```\n\n10. 修改 `gulpfile.js` \n\n```javascript\nconst gulp = require(\"gulp\");\nconst browserify = require(\"browserify\");\nconst source = require('vinyl-source-stream');\nconst tsify = require(\"tsify\");\nconst watchify = require(\"watchify\");\nconst gutil = require(\"gulp-util\");\nconst uglify = require('gulp-uglify');\nconst sourcemaps = require('gulp-sourcemaps');\nconst buffer = require('vinyl-buffer');\nconst paths = {\n pages: ['src/*.html']\n};\n\nconst watchedBrowserify = watchify(browserify({\n basedir: '.',\n debug: true,\n entries: ['src/main.ts'],\n cache: {},\n packageCache: {}\n}).plugin(tsify));\n\ngulp.task(\"copy-html\", function () {\n return gulp.src(paths.pages)\n .pipe(gulp.dest(\"dist\"));\n})\n\nfunction browserifyBundle() {\n return watchedBrowserify\n .transform('babelify', {\n presets: ['env'],\n extensions: ['.ts']\n })\n .bundle()\n .pipe(source('bundle.js'))\n .pipe(buffer())\n .pipe(sourcemaps.init({\n loadMaps: true\n }))\n .pipe(uglify())\n .pipe(sourcemaps.write('./'))\n .pipe(gulp.dest(\"dist\"));\n}\n\ngulp.task(\"browserify\", function () {\n return browserifyBundle();\n})\n\ngulp.task(\"default\", gulp.series('copy-html', 'browserify'));\nwatchedBrowserify.on(\"update\", browserifyBundle);\nwatchedBrowserify.on(\"log\", gutil.log);\n```\n11. 修改 tsconfig.json\n\n ```json\n {\n \"files\": [\n \"src/*.ts\"\n ],\n \"compilerOptions\": {\n \"noImplicitAny\": true,\n \"target\": \"es2015\"\n }\n }\n ```\n\n12. 编译并在浏览器打开 `dist/index.html`\n\n```sh\n# 通过gulp编译代码\nnpx gulp\n```\n\n> 显示器中会显示 “Hello from TypeScript” 字样。\n\n\n\n我们看到 main.ts 调用了 greet.ts 的函数, 并生成一个 bundle.js 文件, 在 index.html 中被加载使用. \n\n\n\n# 调用JavaScript文件\n\n为了使用以前已经存在的JavaScript库文件, 在 src 下新建一个文件夹 libs 用来存放第三方JavaScript. \n\n> projectRoot\n> ├── src/\n> │ ├── libs/\n> │ │ ├── lunar.js\n> │ ├── main.ts\n> │ └── greet.ts\n> │ \n> ├── dist/\n> └── tsconfig.json\n\n```javascript\n# src/libs/lunar.js\n\nLunar = {\n Name: \"Dick\",\n sayHallo:function(){\n return 'i am Lunar';\n }\n} \n\nfunction Ab () {\n this.a = 1\n }\n \nAb.prototype.seta = function (num) {\n this.a = num\n }\n \nAb.prototype.geta = function (num) {\n return this.a\n }\n \nexports.Ab = Ab\nexports.Lunar = Lunar;\n\n```\n\n修改 `greet.ts` 文件, 调用 `src/libs/lunar.js` 中的函数和对象\n\n```typescript\ndeclare function require(path: string): any;\n\nvar ln = require(\"./libs/lunar\");\n\nexport function sayHello(name: string) {\n \tln.Ab = 10\n console.log(ln.Ab)\n return `Hallo von ${name}, ${ln.Lunar.Name}`;\n}\n```\n\nTypeScript使用`tsconfig.json`文件管理工程配置,例如想包含哪些文件和进行哪些检查。\n\n```json\n{\n \"compilerOptions\": {\n \t\t\"noImplicitAny\": true, \n //\"outDir\": \"./dist\", //不需要. gulpfile.js 已经处理过了\n \"allowJs\": true,\n \"target\": \"es2015\",\n \"esModuleInterop\": true /* Enables emit interoperability between CommonJS and ES Modules via creation of namespace objects for all imports. Implies 'allowSyntheticDefaultImports'. */\n },\n \"files\": [\n \"src/*.ts\"\n ],\n \"include\": [\n \"./src/**/*.js\"\n ]\n}\n```\n\n\n\n我们看到网页显示 *Hallo von TypeScript, Dick*, 打开chrome的开发者工具, 看到console 中写出 `10`. \n\n\n\n# Unit-Test\n\n[参考:Unit testing node applications with Typescript -- using nocha and chai](https://journal.artfuldev.com/unit-testing-node-applications-with-typescript-using-mocha-and-chai-384ef05f32b2)\n\n1. 安装测试包文件\n\n```sh\nnpm install chai mocha ts-node @types/chai @types/mocha --save-dev\n```\n\n2. 新建一个test目录专门存放测试文件,并新建一个测试文件 `test/ganzhi.spec.ts`\n\n```typescript\nimport { expect } from 'chai';\nimport 'mocha';\n\ndescribe('干支 function', () => {\n\n it('should return hello world', () => {\n const result = 'Hello world!';\n expect(result).to.equal('Hello world!');\n });\n \n });\n```\n\n3. 在 `package.json` 文件中配置测试参数和路径\n\n```json\n{\n \"scripts\": {\n \"test\": \"mocha -r ts-node/register test/**/*.spec.ts\"\n }\n}\n```\n\n4. 运行测试\n\n> $ npm run test\n>\n> \\> huahets@1.0.0 test /Users/mai/Projects/huahets\n>\n> \\> mocha -r ts-node/register test/**/*.spec.ts\n>\n> 干支 function\n>\n> ​ ✓ should return hello world\n>\n> 1 passing (19ms)\n\n\n\n## 错误处理\n\n假设有以下函数调用中`LandMaps.FindCity`会给出一个异常。\n\n```typescript\nvar result = LandMaps.FindCity(\"xx省\", \"xx市\");\nexpect(LandMaps.FindCity.bind(LandMaps, \"err\", \"\")).throw(\"Error Message\") # 或者\nexpect(LandMaps.FindCity.bind(LandMaps, \"err\", \"\")).throw(new Error(\"Error Message\"))\n```\n\n\n\n# 打包\n\n[用 TypeScript 编写函数库](https://www.xuejiayuan.net/blog/27db473912f642d8a5fa0e32af3bb600)\n\n[require.js 官方文档](https://requirejs.org/docs/start.html)\n\n通过上述方式生成的 bundle.js 文件不能被浏览器直接使用。参考上面两个网页提供的方式,可以生成给浏览器用的单一js文件。\n\n1. 新建一个入口文件,将所有接口都连接起来,并统一导出\n\n ```typescript\n # yixue.ts\n import {TYDate, TYLunar} from \"./tylunar\";\n import {GanZhi} from \"./ganzhi\";\n import {ShenSha} from \"./shensha\";\n import {WuXing, FetchWuXing} from \"./wuxing\";\n import {Gua} from './gua'\n import {LandMaps} from \"./landmaps\"\n \n exports.GanZhi = GanZhi\n exports.TYDate = TYDate\n exports.Gua = Gua\n ```\n2. 设置`tsconfig.json`让编译后的文件导出到`dist/cmjs`目录\n\n```json\n{\n \"compilerOptions\": {\n \"target\": \"es5\",\n \"module\": \"commonjs\",\n \"moduleResolution\": \"node\",\n \"outDir\": \"dist/cmjs\",\n \"rootDir\": \"./src\",\n \"declaration\": true,\n \"sourceMap\": true,\n \"lib\": [\"dom\", \"es6\"]\n }\n}\n```\n\n3. 通过命令 tsc 编译\n\n```sh\ntsc -P tsconfig.json\n```\n\n也可以在 package.json 中设定,然后运行 `npm run build:cmjs` 编译。编译后的 yixue.js 文件就是统一入口。\n\n4. yi xue.js 实际就是个目录,我需要将其打包成一个单一文件。 安装 browserify , \n\n```sh\nbrowserify dist/cmjs/base/yixue.js --standalone huahejs -o dist/web/yixue.js\n```\n\n5. 下载 [require.js](https://requirejs.org/docs/start.html), 并放到项目目录中。以下方式将 yixue.js 中的 `class GanZhi` 设为当前网页的一个全局函数。其它函数就可以调用。 \n\n```html\n\n\n \n \n 易学包\n \n \n

易学包测试

\n \n\n
\n
gua
\n \n\n```\n\n6. 在 Node.js 中调用更简单\n\n1. ```javascript\n const {Gua, GanZhi, TYDate} = require(\"./web/yixue\")\n ```\n\n\n\n\n\n\n\n\n需要更详细代码请下载项目:\n\n[演示项目地址](https://gitee.com/maiernte/typescript-build-js-package)","slug":"IT/skill/用Typescript编写JS函数库","published":1,"updated":"2019-08-24T11:30:40.000Z","_id":"cka1y599p004j4huucopvbcs0","comments":1,"layout":"post","photos":[],"link":"","content":"

本文具体介绍如何用TypeScript编写JavaScript库文件,以及制作npm工具包。主要参考下面两篇文章。我也省却一步步解释,只罗列相关的代码和我遇到的坑。想知道代码含义的请参阅原帖

\n\n\n

安装 TypeScript

\n

终端执行 npm install typescript -g

\n
1
2
$ tsc --version
Version 3.5.3
\n

创建工程

\n
    \n
  1. 初始化项目
  2. \n
\n
1
2
mkdir typescript_demo && cd typescript_demo
npm init -y # 初始化项目,会生成 package.json 文件
\n
    \n
  1. 安装Gulp, 并在项目根目录下新建 gulpfile.js 文件
  2. \n
\n
1
npm install gulp-cli gulp typescript gulp-typescript --save-dev
\n
    \n
  1. \n

    在命令行中执行 tsc --init 可以在当前目录中快速创建一个 tsconfig.json 文件。

    \n
  2. \n
  3. \n

    安装 Browserify :目的是把所有ts文件打包成一个单一的js文件。

    \n
  4. \n
\n
1
npm install browserify tsify vinyl-source-stream --save-dev
\n
    \n
  1. Watchify、Babel和Uglify :目的是让编译器保持运行,无需每次修改手动编译。
  2. \n
\n

npm install watchify gulp-util --save-dev

\n
1
npm install watchify gulp-util --save-dev
\n
    \n
  1. 安装 Uglify : 将输出文件 bundle.js 压缩
  2. \n
\n
1
npm install gulp-uglify vinyl-buffer gulp-sourcemaps --save-dev
\n
    \n
  1. Babel :允许按新标准ES6编写代码,而最终会编译es05标准,兼容低版本浏览器。
  2. \n
\n
1
npm install babelify babel-core babel-preset-env vinyl-buffer gulp-sourcemaps --save-dev
\n

:bangbang: 安装中出现了错误, 显示babelify 版本太低. 将命令改为 npm install babelify@8 就能顺利进行下去了.

\n
    \n
  1. \n

    编写主文件 src/main.ts (名字随便起),在 package.json 中改为 $ “main”: “./dist/main.js”, $。创建两文件夹 srcdist,分别放置原文件和编译后的文件。为演示调用,再新建一个 src/greet.ts 文件

    \n
    1
    2
    3
    4
    5
    6
    7
    # src/greet.ts
    declare function require(path: string): any;

    export function sayHello(name: string) {
    console.log(ln)
    return `Hallo von ${name}`;
    }
    \n
    1
    2
    3
    4
    5
    6
    7
    8
    9
    # src/main.ts
    import { sayHello } from \"./greet\";

    function showHello(idName: string, name: string) {
    const elt = document.getElementById(idName);
    elt.innerText = sayHello(name);
    }

    showHello(\"greeting\", \"TypeScript\");
    \n
  2. \n
  3. \n

    新建 src/index.html

    \n
  4. \n
\n
1
2
3
4
5
6
7
8
9
10
11
<!DOCTYPE html>
<html>
<head>
<meta charset=\"UTF-8\" />
<title>Hello World!</title>
</head>
<body>
<p id=\"greeting\">Loading ...</p>
<script src=\"bundle.js\"></script>
</body>
</html>
\n
    \n
  1. 修改 gulpfile.js
  2. \n
\n
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
const gulp = require(\"gulp\");
const browserify = require(\"browserify\");
const source = require('vinyl-source-stream');
const tsify = require(\"tsify\");
const watchify = require(\"watchify\");
const gutil = require(\"gulp-util\");
const uglify = require('gulp-uglify');
const sourcemaps = require('gulp-sourcemaps');
const buffer = require('vinyl-buffer');
const paths = {
pages: ['src/*.html']
};

const watchedBrowserify = watchify(browserify({
basedir: '.',
debug: true,
entries: ['src/main.ts'],
cache: {},
packageCache: {}
}).plugin(tsify));

gulp.task(\"copy-html\", function () {
return gulp.src(paths.pages)
.pipe(gulp.dest(\"dist\"));
})

function browserifyBundle() {
return watchedBrowserify
.transform('babelify', {
presets: ['env'],
extensions: ['.ts']
})
.bundle()
.pipe(source('bundle.js'))
.pipe(buffer())
.pipe(sourcemaps.init({
loadMaps: true
}))
.pipe(uglify())
.pipe(sourcemaps.write('./'))
.pipe(gulp.dest(\"dist\"));
}

gulp.task(\"browserify\", function () {
return browserifyBundle();
})

gulp.task(\"default\", gulp.series('copy-html', 'browserify'));
watchedBrowserify.on(\"update\", browserifyBundle);
watchedBrowserify.on(\"log\", gutil.log);
\n
    \n
  1. \n

    修改 tsconfig.json

    \n
    1
    2
    3
    4
    5
    6
    7
    8
    9
    {
    \"files\": [
    \"src/*.ts\"
    ],
    \"compilerOptions\": {
    \"noImplicitAny\": true,
    \"target\": \"es2015\"
    }
    }
    \n
  2. \n
  3. \n

    编译并在浏览器打开 dist/index.html

    \n
  4. \n
\n
1
2
# 通过gulp编译代码
npx gulp
\n
\n

显示器中会显示 “Hello from TypeScript” 字样。

\n
\n

我们看到 main.ts 调用了 greet.ts 的函数, 并生成一个 bundle.js 文件, 在 index.html 中被加载使用.

\n

调用JavaScript文件

\n

为了使用以前已经存在的JavaScript库文件, 在 src 下新建一个文件夹 libs 用来存放第三方JavaScript.

\n
\n

projectRoot
\n├── src/
\n│ ├── libs/
\n│ │ ├── lunar.js
\n│ ├── main.ts
\n│ └── greet.ts
\n│
\n├── dist/
\n└── tsconfig.json

\n
\n
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
# src/libs/lunar.js

Lunar = {
Name: \"Dick\",
sayHallo:function(){
return 'i am Lunar';
}
}

function Ab () {
this.a = 1
}

Ab.prototype.seta = function (num) {
this.a = num
}

Ab.prototype.geta = function (num) {
return this.a
}

exports.Ab = Ab
exports.Lunar = Lunar;
\n

修改 greet.ts 文件, 调用 src/libs/lunar.js 中的函数和对象

\n
1
2
3
4
5
6
7
8
9
declare function require(path: string): any;

var ln = require(\"./libs/lunar\");

export function sayHello(name: string) {
\tln.Ab = 10
console.log(ln.Ab)
return `Hallo von ${name}, ${ln.Lunar.Name}`;
}
\n

TypeScript使用tsconfig.json文件管理工程配置,例如想包含哪些文件和进行哪些检查。

\n
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
{
\"compilerOptions\": {
\t\t\"noImplicitAny\": true,
//\"outDir\": \"./dist\", //不需要. gulpfile.js 已经处理过了
\"allowJs\": true,
\"target\": \"es2015\",
\"esModuleInterop\": true /* Enables emit interoperability between CommonJS and ES Modules via creation of namespace objects for all imports. Implies 'allowSyntheticDefaultImports'. */
},
\"files\": [
\"src/*.ts\"
],
\"include\": [
\"./src/**/*.js\"
]
}
\n

我们看到网页显示 Hallo von TypeScript, Dick, 打开chrome的开发者工具, 看到console 中写出 10.

\n

Unit-Test

\n

参考:Unit testing node applications with Typescript – using nocha and chai

\n
    \n
  1. 安装测试包文件
  2. \n
\n
1
npm install chai mocha ts-node @types/chai @types/mocha --save-dev
\n
    \n
  1. 新建一个test目录专门存放测试文件,并新建一个测试文件 test/ganzhi.spec.ts
  2. \n
\n
1
2
3
4
5
6
7
8
9
10
11
import { expect } from 'chai';
import 'mocha';

describe('干支 function', () => {

it('should return hello world', () => {
const result = 'Hello world!';
expect(result).to.equal('Hello world!');
});

});
\n
    \n
  1. package.json 文件中配置测试参数和路径
  2. \n
\n
1
2
3
4
5
{
\"scripts\": {
\"test\": \"mocha -r ts-node/register test/**/*.spec.ts\"
}
}
\n
    \n
  1. 运行测试
  2. \n
\n
\n

$ npm run test

\n

> huahets@1.0.0 test /Users/mai/Projects/huahets

\n

> mocha -r ts-node/register test/**/*.spec.ts

\n

干支 function

\n

​ ✓ should return hello world

\n

1 passing (19ms)

\n
\n

错误处理

\n

假设有以下函数调用中LandMaps.FindCity会给出一个异常。

\n
1
2
3
var result = LandMaps.FindCity(\"xx省\", \"xx市\");
expect(LandMaps.FindCity.bind(LandMaps, \"err\", \"\")).throw(\"Error Message\") # 或者
expect(LandMaps.FindCity.bind(LandMaps, \"err\", \"\")).throw(new Error(\"Error Message\"))
\n

打包

\n

用 TypeScript 编写函数库

\n

require.js 官方文档

\n

通过上述方式生成的 bundle.js 文件不能被浏览器直接使用。参考上面两个网页提供的方式,可以生成给浏览器用的单一js文件。

\n
    \n
  1. 新建一个入口文件,将所有接口都连接起来,并统一导出
  2. \n
\n
1
2
3
4
5
6
7
8
9
10
11
# yixue.ts
import {TYDate, TYLunar} from \"./tylunar\";
import {GanZhi} from \"./ganzhi\";
import {ShenSha} from \"./shensha\";
import {WuXing, FetchWuXing} from \"./wuxing\";
import {Gua} from './gua'
import {LandMaps} from \"./landmaps\"

exports.GanZhi = GanZhi
exports.TYDate = TYDate
exports.Gua = Gua
\n
    \n
  1. 设置tsconfig.json让编译后的文件导出到dist/cmjs目录
  2. \n
\n
1
2
3
4
5
6
7
8
9
10
11
12
{
\"compilerOptions\": {
\"target\": \"es5\",
\"module\": \"commonjs\",
\"moduleResolution\": \"node\",
\"outDir\": \"dist/cmjs\",
\"rootDir\": \"./src\",
\"declaration\": true,
\"sourceMap\": true,
\"lib\": [\"dom\", \"es6\"]
}
}
\n
    \n
  1. 通过命令 tsc 编译
  2. \n
\n
1
tsc -P tsconfig.json
\n

也可以在 package.json 中设定,然后运行 npm run build:cmjs 编译。编译后的 yixue.js 文件就是统一入口。

\n
    \n
  1. yi xue.js 实际就是个目录,我需要将其打包成一个单一文件。 安装 browserify ,
  2. \n
\n
1
browserify dist/cmjs/base/yixue.js --standalone huahejs -o dist/web/yixue.js
\n
    \n
  1. 下载 require.js, 并放到项目目录中。以下方式将 yixue.js 中的 class GanZhi 设为当前网页的一个全局函数。其它函数就可以调用。
  2. \n
\n
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
<!DOCTYPE html>
<html>
<head>
<meta charset=\"UTF-8\" />
<title>易学包</title>
<script type=\"text/javascript\"
src=\"libs/require.js\"></script>
<body >
<p id=\"greeting\">易学包测试</p>
<script>
var newGanZhi

requirejs([\"web/yixue\"], function(yixue) {
console.log(yixue)
newGanZhi = function(arg){
return new yixue.GanZhi(arg)
}

init()
});

function init(){
console.log(\"init will be called\")
var ele = document.getElementById(\"gz1\")
var gz = newGanZhi(1)
ele.innerText = gz.Name
}
</script>

<div id=\"gz1\"></div>
<div name=\"gua\">gua</div>
</body>
</html>
\n
    \n
  1. \n

    在 Node.js 中调用更简单

    \n
  2. \n
  3. \n
    1
    const {Gua, GanZhi, TYDate} = require(\"./web/yixue\")
    \n
  4. \n
\n

需要更详细代码请下载项目:

\n

演示项目地址

\n","site":{"data":{}},"excerpt":"

本文具体介绍如何用TypeScript编写JavaScript库文件,以及制作npm工具包。主要参考下面两篇文章。我也省却一步步解释,只罗列相关的代码和我遇到的坑。想知道代码含义的请参阅原帖

\n","more":"

安装 TypeScript

\n

终端执行 npm install typescript -g

\n\n

创建工程

\n
    \n
  1. 初始化项目
  2. \n
\n\n
    \n
  1. 安装Gulp, 并在项目根目录下新建 gulpfile.js 文件
  2. \n
\n\n
    \n
  1. \n

    在命令行中执行 tsc --init 可以在当前目录中快速创建一个 tsconfig.json 文件。

    \n
  2. \n
  3. \n

    安装 Browserify :目的是把所有ts文件打包成一个单一的js文件。

    \n
  4. \n
\n\n
    \n
  1. Watchify、Babel和Uglify :目的是让编译器保持运行,无需每次修改手动编译。
  2. \n
\n

npm install watchify gulp-util --save-dev

\n\n
    \n
  1. 安装 Uglify : 将输出文件 bundle.js 压缩
  2. \n
\n\n
    \n
  1. Babel :允许按新标准ES6编写代码,而最终会编译es05标准,兼容低版本浏览器。
  2. \n
\n\n

:bangbang: 安装中出现了错误, 显示babelify 版本太低. 将命令改为 npm install babelify@8 就能顺利进行下去了.

\n
    \n
  1. \n

    编写主文件 src/main.ts (名字随便起),在 package.json 中改为 $ “main”: “./dist/main.js”, $。创建两文件夹 srcdist,分别放置原文件和编译后的文件。为演示调用,再新建一个 src/greet.ts 文件

    \n\n\n
  2. \n
  3. \n

    新建 src/index.html

    \n
  4. \n
\n\n
    \n
  1. 修改 gulpfile.js
  2. \n
\n\n
    \n
  1. \n

    修改 tsconfig.json

    \n\n
  2. \n
  3. \n

    编译并在浏览器打开 dist/index.html

    \n
  4. \n
\n\n
\n

显示器中会显示 “Hello from TypeScript” 字样。

\n
\n

我们看到 main.ts 调用了 greet.ts 的函数, 并生成一个 bundle.js 文件, 在 index.html 中被加载使用.

\n

调用JavaScript文件

\n

为了使用以前已经存在的JavaScript库文件, 在 src 下新建一个文件夹 libs 用来存放第三方JavaScript.

\n
\n

projectRoot
\n├── src/
\n│ ├── libs/
\n│ │ ├── lunar.js
\n│ ├── main.ts
\n│ └── greet.ts
\n│
\n├── dist/
\n└── tsconfig.json

\n
\n\n

修改 greet.ts 文件, 调用 src/libs/lunar.js 中的函数和对象

\n\n

TypeScript使用tsconfig.json文件管理工程配置,例如想包含哪些文件和进行哪些检查。

\n\n

我们看到网页显示 Hallo von TypeScript, Dick, 打开chrome的开发者工具, 看到console 中写出 10.

\n

Unit-Test

\n

参考:Unit testing node applications with Typescript – using nocha and chai

\n
    \n
  1. 安装测试包文件
  2. \n
\n\n
    \n
  1. 新建一个test目录专门存放测试文件,并新建一个测试文件 test/ganzhi.spec.ts
  2. \n
\n\n
    \n
  1. package.json 文件中配置测试参数和路径
  2. \n
\n\n
    \n
  1. 运行测试
  2. \n
\n
\n

$ npm run test

\n

> huahets@1.0.0 test /Users/mai/Projects/huahets

\n

> mocha -r ts-node/register test/**/*.spec.ts

\n

干支 function

\n

​ ✓ should return hello world

\n

1 passing (19ms)

\n
\n

错误处理

\n

假设有以下函数调用中LandMaps.FindCity会给出一个异常。

\n\n

打包

\n

用 TypeScript 编写函数库

\n

require.js 官方文档

\n

通过上述方式生成的 bundle.js 文件不能被浏览器直接使用。参考上面两个网页提供的方式,可以生成给浏览器用的单一js文件。

\n
    \n
  1. 新建一个入口文件,将所有接口都连接起来,并统一导出
  2. \n
\n \n
    \n
  1. 设置tsconfig.json让编译后的文件导出到dist/cmjs目录
  2. \n
\n\n
    \n
  1. 通过命令 tsc 编译
  2. \n
\n\n

也可以在 package.json 中设定,然后运行 npm run build:cmjs 编译。编译后的 yixue.js 文件就是统一入口。

\n
    \n
  1. yi xue.js 实际就是个目录,我需要将其打包成一个单一文件。 安装 browserify ,
  2. \n
\n\n
    \n
  1. 下载 require.js, 并放到项目目录中。以下方式将 yixue.js 中的 class GanZhi 设为当前网页的一个全局函数。其它函数就可以调用。
  2. \n
\n\n
    \n
  1. \n

    在 Node.js 中调用更简单

    \n
  2. \n
  3. \n\n
  4. \n
\n

需要更详细代码请下载项目:

\n

演示项目地址

"},{"title":"MathJax用于易学领域","date":"2019-08-30T08:15:28.000Z","urlname":"mathjax-yixue-usage","toc":true,"mathjax":true,"_content":"\n关于利用 `MathJax` 和 `Katex` 数学公式解释器,实现易学上排六爻盘和八字盘个功能。今天实现了易学上的核心功能。有望将来能添加更多的函数,以便利各位同门以及广大易友。\n\n\n\n### 效果与演示\n\n\n无法观看油管的朋友请移步B站:[使用MathJax渲染六爻和八字盘](https://www.bilibili.com/video/av66317810/)\n\n\n\n\n### 安装和使用\n\n首先,你需要一个支持 Markdown (简称MD) 语言格式的文本编辑器。如果不知道什么是MD的话,请参阅以下介绍:\n\n- [Markdown介绍及使用教程](https://www.jianshu.com/p/7771794c88a1)\n\n- [Markdown - 简单的世界](https://wizardforcel.gitbooks.io/markdown-simple-world/index.html)\n\n- [认识与入门 Markdown](https://sspai.com/post/25137)\n\n\n\nMarkdown 语言**简约而优美**,可以自由转换成pdf、word、Html 等等各种其它格式的文本。可以推送到博客、微信公众号等等。虽然算卦是一个传统的行业,我们仍然不宜**固步自封**。MD语言支持MathJax和Katex书写Latex数学公式,可以写出非常漂亮的数学、物理、化学方面的公式。正式的科技刊物都要求用Latex格式。\n\n\n\n这个易学解决方案是对 MathJax 进行扩展,加入指定的易学公式,让 MathJax 解释器去完成公式渲染。它并不是一个独立的程序。需要构建在已有的MD文本编辑器之上。我使用一个文件夹存放所有的关于易学方面的MD文件,并将这个文件夹同步到 [坚果云](https://www.jianguoyun.com/#/),这样就可以实现多台电脑和移动端之间的同步,而不太需要一个独立的易学软件。甚至可以将MD文件导出为HTML文件,放到我的HEXO博客上(您正在阅读的这篇博文即是例子)。\n\n\n\n理论上所有支持Markdown语言和MathJax的文本编辑器,都可以改装。改装过程需要两段代码和一个库文件。\n\n#### 文本编辑器\n\n##### Typora \n\nTypora 是我个人最钟爱的MD编辑器,因此这里着重介绍。如果你喜欢用别的MD编辑器,比如iAWrte等,理论上可以用同样的方式改装。(无法百分百保证) 有需要的朋友可以私下联系我。\n\n最新的安装教程请参考[华鹤易学平台文档](https://maiernte.gitee.io/huahedocument/chapter6/libinstall.html)\n\n##### VSCode\n\n同样请移步[华鹤易学平台文档](https://maiernte.gitee.io/huahedocument/chapter6/libinstall.html)。那里有详细描述。\n\n\n\n#### Hexo博客\n\n🔔 注意:首先要检查自己的 Hexo 博客使用的渲染器是否默认开启了Katex或者MathJax数学插件。如果有的话需要卸载或者禁用数学插件,如果不能禁用,就必须更换Markdown渲染器。\n\n> 因为系统使用的数学插件会在网页生成之前就改动数学表达,这样无法使用我提供给的函数库。我提供给博客的方案是在浏览网页的时候,即时渲染易学公式。\n\n比如我之前用了 \"hexo-renderer-markdown-it-plus\" 渲染器就是强制使用 Katex 数学渲染的。\n\n```shell\nnpm un hexo-renderer-markdown-it-plus --save // 卸载\nnpm i hexo-renderer-markdown-it --save // 更换\n```\n\n然后将下列代码添加到文件模版就可以了。使用 swig 模版的是在 `/layout/_custom/header.swig` 或者 `/layout/index.swig` 。而使用 ejs 模版的是文件 `/layout/layout.ejs`\n\n```html\n\n\n\n\n\n\n\n\n\n\n```\n\n> 注意搜索 _config.yml 文件,\"math\", \"katex\", \"mathjax\" 等字样,发现有的话把他们禁用。\n\n\n\n#### Gitbook\n\n最新的安装教程请参考[华鹤易学平台文档](https://maiernte.gitee.io/huahedocument/chapter6/libinstall.html)\n\n\n\n### API 参数\n\n使用易学函数库非常简单,在经过改装的Markdown编辑器中,输入易学公式,并用两个 `$` 符号将公式前后围起来即可。MD语言一般默认两个 `$` 符号之间的文本是数学公式,它会调用MathJax对公式进行渲染。否则,它会认为这是普通文本,而不会做任何动作。\n\n#### 易学通用\n\n**命令:纳音** `\\nayin{干支名称}`\n\n【干支名称】 :就是甲子、己卯等六十甲子。\n\n例子1:`\\nayin{戊午}` --> $\\nayin{戊午}$\n\n**命令:干支日历** `\\timegz{时间参数}{年月日}`\n\n【时间参数】 :例如 2020-02-21。\n\n【年月日】 :省略时默认为`111`,即显示年月日。`0`表示不显示,`1`表示显示。\n\n例子1:`\\timegz{2020-02-21}` --> $\\timegz{2020-02-21}$\n\n例子2:`\\timegz{2020-02-21}{011}` --> $\\timegz{2020-02-21}{011}$\n\n\n#### 六爻\n\n**命令:爻符** `\\yao{爻名}`\n\n【爻名】:laoyin, laoyang,shaoyin,shaoyang, x, o, =, -, 交,重,阴,阳,0,1,2,3\n\n例子2:`\\yao{x}` --> $\\yao{x}$\n\n例子3:`\\yao{shaoyin}` --> $\\yao{shaoyin}$\n\n例子4:`\\yao{重}` --> $\\yao{重}$\n\n\n\n **命令:六爻排盘** `\\paigua{时令}{卦辞}{标识}`\n\n其中 【时令】、【卦辞】这两个参数是必须的,**【标识】**参数可以省略。\n\n【时令】允许的格式为:“1980-1-3 08:15”、“2019年3月4日”、“申月戊寅日”\n\n【卦辞】允许的格式为:“解之师”、“离为火”、“--==x-”、“0121100”、“阴阳阴交阴阳”\n\n【标识】由三部分组成:ID号、简排、字符大小。格式为:`guadi/s/5`\n\n- 「ID号」:随便一串字符,空白则默认为“gua1”。:x:不允许只有数字,因为会与参数「字符大小」混淆。如果一个文本出现多个六爻卦,则每个卦都需要指定一个ID号。否则下面的命令[卦爻细节](#guayao)不知道具体指向哪一个卦本。\n- 「简排」:只允许`s` 和 `l`两个英文字符的其中一个。`s` 表示只显示短名,如“妻财”显示为“财”,“青龙”显示为“龙”。`l` 则显示完整名称。留白则按照用户全局设定来显示。(参阅[用户设定](#code2))\n- 「字符大小」:允许 0 - 9 档。数字越大文字越大。默认大小为`5`或者用户的[全局设定](#code2)。\n\n例子5: `$\\paigua{1978年7月1日}{101201}{gua1}$` 效果\n$$\\paigua{1978年7月1日}{101201}{gua1}$$\n\n:pencil2: 如果文章很长,需要在指定位置重新显示一遍卦本,则可以使用重排命令。即让【时令】和【卦辞】两个参数留白,只给出【ID号】。如 `\\paigua{}{}{gua1}` 。留白的参数,仍然需要用大括号括起来,否则解释器会出错。\n\n\n\n **命令:卦爻细节** `\\guayao{标识}{位置}`\n\n使用前提:当前文本中已经排出至少一支六爻卦。\n\n【标识】:与排盘命令的「标识」参数等同。由ID号、简排、字符大小三个部分组成。其中「ID号」标识已经存在的六爻盘。\n\n【位置】:格式为 “ben1”、“fu3”、“bian5” 等,分别表示「本卦初爻」、「伏卦3爻」、「变卦5爻」\n\n\n\n例子6:`\\guayao{gua1}{ben4}` --> $\\guayao{gua1}{ben4}$\n\n> 例子6 中给出的「ID号」为例子5中指定的ID号 “gua1”,并要求显示本卦4爻的具体信息。\n\n\n\n#### 八字\n\n **命令:八字排盘** `\\paibazi{时间}{性别}{标识}[细节]`\n\n【时间】和【性别】参数必填,【标识】和【细节】参数可选。(如果要第二次显示已有的八字盘,则【时间】和【性别】参数可留白,只给定【标识】参数中的「ID号」)\n\n【时间】:允许格式 “1980-1-3 08:15”、“2019年3月4日 6时3分” \n\n【性别】:允许格式 “m”、“f”、“男”、“女”、“乾”、“坤”、\n\n【标识】:与排盘命令的「标识」参数等同。由ID号、简排、字符大小三个部分组成。\n\n【细节】:允许“藏干”、“长生”、“纳音”这三个中的一个或者多个,也可以留白。格式为 `藏干/纳音/长生`\n\n例子7:`\\paibazi{1990年5月1日 6:45}{男}{小明/s/5}`\n\n$\\paibazi{1990年5月1日 6:45}{男}{小明/5}$\n\n例子8:重排例子7的八字盘 `\\paibazi{}{}{小明/s/5}[纳音/藏干/长生]` ,并要求显示藏干和纳音等信息。\n\n$\\paibazi{}{}{小明/s/5}[纳音/藏干/长生]$\n\n\n\n **命令:八字细节** `\\bazi{标识}{类别}[细节]`\n\n使用前提:当前文本中已经排出至少一个八字盘。\n\n【标识】:与排盘命令的「标识」参数等同。由ID号、简排、字符大小三个部分组成。其中「ID号」标识已经存在的八字命盘。\n\n【类别】:支持 “神煞”、“大运”、“流年”、“小运” 四个选项。\n\n【细节】:具体含义视【类别】而定。\n\n- 类别为「神煞」时:「细节」为 1~ 9 的数字,表示每行列数。\n- 类别为「大运」时:` 1-9 纳音/藏干/长生/神煞` 前面的数字表示第几步大运,限定 1 到 10\n- 类别为「流年」和「小运」时: `2015 - 2019 纳音/藏干/长生/神煞` 前面的数字表示年份,注意不要超过命盘的生命周期,否则会出错。「纳音/藏干/长生/神煞」可以留白,也可只显示一两项。\n\n\n\n例子9: `\\bazi{小明}{神煞}[6]` 显示小明命盘的神煞,每行6列。\n\n$\\bazi{小明}{神煞}[6]$\n\n\n\n例子10: `\\bazi{小明}{大运}[2-3 ]` 显示小明的第二到第三步大运\n\n$\\bazi{小明}{大运}[2-3]$\n\n\n\n例子11: `\\bazi{小明}{流年}[2017-2019 纳音/藏干/长生/神煞]` 显示小明的2017到2019年的流年信息。\n\n$\\bazi{小明}{流年}[2017-2019 纳音/藏干/长生/神煞]$\n\n\n\n### 未来与展望\n\n我知道这篇文章介绍的工具,并非所有人都能使用。所以在不久的将来,还是要制作一个独立易学软件,以便易友在PC端和移动端都能按照传统的方式使用。但由于时间和精力原因,我无法保证完成时间。\n\n\n\n不断完善易学函数,提供更丰富的应用细节。在用户更为广泛的MD编辑器中实现此方式。比如有道云笔记、为知笔记、印象笔记等。并争取介绍移动端(Android & iOS)实现此方式。也希望在Gitbook中实现。\n\n\n\n希望能将师父的六爻和八字讲义,『增删卜易』等著作制作成Gitbook,将精彩的卦例和名人八字建成易学数据库。这样就可以通过我的易学函数直接获取, 比如 `\\paibazi{蒋介石}`。\n\n\n\n### 附录: \n\n#### 命令列表\n\n[纳音](#nayin)\n\n[爻符](#yao)\n\n[排卦](#paigua)\n\n[卦爻细节](#guayao)\n\n[排八字](#paibazi)\n\n[八字细节](#bazi)\n\n#### 发布\n\n脚本文件的[原始路径](https://github.com/maiernte/img/raw/master/libs/bundle.js)是`https://github.com/maiernte/img/raw/master/libs/bundle.js`。因为涉及到跨域问题,要通过 [Gitkack](https://raw.githack.com/) 重链接,把上述路径输入到 Githack 的地址框,会得到「应用地址」和「开发地址」。\n\n[应用地址](https://rawcdn.githack.com/maiernte/img/bb3c42dc26b0866a142bb905d1753ac483e0a474/libs/bundle.js):\n\n`https://rawcdn.githack.com/maiernte/img/11a1bb572a6875dbf434a7fc457ea2fdd329f7db/libs/bundle.js`\n\n[开发地址](https://raw.githack.com/maiernte/img/master/libs/bundle.js):\n\n`https://raw.githack.com/maiernte/img/master/libs/bundle.js`\n\n#### 查看当前易学函数库版本\n\n在 chrome 浏览其中打开此博文,Mac 系统中按 `⌘+⌥+I` ,Windows 系统 `Ctr+⇧+I`,或者 Chrome 菜单栏调出 “开发者工具”,选择 Console 页面,即可显示当前易学库版本和时间。","source":"_posts/IT/skill/MathJax用于易学领域.md","raw":"---\ntitle: MathJax用于易学领域\ndate: 2019-08-30 10:15:28\nurlname: mathjax-yixue-usage\ntoc: true\ntags: [工具]\ncategories: [IT, skill]\nmathjax: true\n---\n\n关于利用 `MathJax` 和 `Katex` 数学公式解释器,实现易学上排六爻盘和八字盘个功能。今天实现了易学上的核心功能。有望将来能添加更多的函数,以便利各位同门以及广大易友。\n\n\n\n### 效果与演示\n\n\n无法观看油管的朋友请移步B站:[使用MathJax渲染六爻和八字盘](https://www.bilibili.com/video/av66317810/)\n\n\n\n\n### 安装和使用\n\n首先,你需要一个支持 Markdown (简称MD) 语言格式的文本编辑器。如果不知道什么是MD的话,请参阅以下介绍:\n\n- [Markdown介绍及使用教程](https://www.jianshu.com/p/7771794c88a1)\n\n- [Markdown - 简单的世界](https://wizardforcel.gitbooks.io/markdown-simple-world/index.html)\n\n- [认识与入门 Markdown](https://sspai.com/post/25137)\n\n\n\nMarkdown 语言**简约而优美**,可以自由转换成pdf、word、Html 等等各种其它格式的文本。可以推送到博客、微信公众号等等。虽然算卦是一个传统的行业,我们仍然不宜**固步自封**。MD语言支持MathJax和Katex书写Latex数学公式,可以写出非常漂亮的数学、物理、化学方面的公式。正式的科技刊物都要求用Latex格式。\n\n\n\n这个易学解决方案是对 MathJax 进行扩展,加入指定的易学公式,让 MathJax 解释器去完成公式渲染。它并不是一个独立的程序。需要构建在已有的MD文本编辑器之上。我使用一个文件夹存放所有的关于易学方面的MD文件,并将这个文件夹同步到 [坚果云](https://www.jianguoyun.com/#/),这样就可以实现多台电脑和移动端之间的同步,而不太需要一个独立的易学软件。甚至可以将MD文件导出为HTML文件,放到我的HEXO博客上(您正在阅读的这篇博文即是例子)。\n\n\n\n理论上所有支持Markdown语言和MathJax的文本编辑器,都可以改装。改装过程需要两段代码和一个库文件。\n\n#### 文本编辑器\n\n##### Typora \n\nTypora 是我个人最钟爱的MD编辑器,因此这里着重介绍。如果你喜欢用别的MD编辑器,比如iAWrte等,理论上可以用同样的方式改装。(无法百分百保证) 有需要的朋友可以私下联系我。\n\n最新的安装教程请参考[华鹤易学平台文档](https://maiernte.gitee.io/huahedocument/chapter6/libinstall.html)\n\n##### VSCode\n\n同样请移步[华鹤易学平台文档](https://maiernte.gitee.io/huahedocument/chapter6/libinstall.html)。那里有详细描述。\n\n\n\n#### Hexo博客\n\n🔔 注意:首先要检查自己的 Hexo 博客使用的渲染器是否默认开启了Katex或者MathJax数学插件。如果有的话需要卸载或者禁用数学插件,如果不能禁用,就必须更换Markdown渲染器。\n\n> 因为系统使用的数学插件会在网页生成之前就改动数学表达,这样无法使用我提供给的函数库。我提供给博客的方案是在浏览网页的时候,即时渲染易学公式。\n\n比如我之前用了 \"hexo-renderer-markdown-it-plus\" 渲染器就是强制使用 Katex 数学渲染的。\n\n```shell\nnpm un hexo-renderer-markdown-it-plus --save // 卸载\nnpm i hexo-renderer-markdown-it --save // 更换\n```\n\n然后将下列代码添加到文件模版就可以了。使用 swig 模版的是在 `/layout/_custom/header.swig` 或者 `/layout/index.swig` 。而使用 ejs 模版的是文件 `/layout/layout.ejs`\n\n```html\n\n\n\n\n\n\n\n\n\n\n```\n\n> 注意搜索 _config.yml 文件,\"math\", \"katex\", \"mathjax\" 等字样,发现有的话把他们禁用。\n\n\n\n#### Gitbook\n\n最新的安装教程请参考[华鹤易学平台文档](https://maiernte.gitee.io/huahedocument/chapter6/libinstall.html)\n\n\n\n### API 参数\n\n使用易学函数库非常简单,在经过改装的Markdown编辑器中,输入易学公式,并用两个 `$` 符号将公式前后围起来即可。MD语言一般默认两个 `$` 符号之间的文本是数学公式,它会调用MathJax对公式进行渲染。否则,它会认为这是普通文本,而不会做任何动作。\n\n#### 易学通用\n\n**命令:纳音** `\\nayin{干支名称}`\n\n【干支名称】 :就是甲子、己卯等六十甲子。\n\n例子1:`\\nayin{戊午}` --> $\\nayin{戊午}$\n\n**命令:干支日历** `\\timegz{时间参数}{年月日}`\n\n【时间参数】 :例如 2020-02-21。\n\n【年月日】 :省略时默认为`111`,即显示年月日。`0`表示不显示,`1`表示显示。\n\n例子1:`\\timegz{2020-02-21}` --> $\\timegz{2020-02-21}$\n\n例子2:`\\timegz{2020-02-21}{011}` --> $\\timegz{2020-02-21}{011}$\n\n\n#### 六爻\n\n**命令:爻符** `\\yao{爻名}`\n\n【爻名】:laoyin, laoyang,shaoyin,shaoyang, x, o, =, -, 交,重,阴,阳,0,1,2,3\n\n例子2:`\\yao{x}` --> $\\yao{x}$\n\n例子3:`\\yao{shaoyin}` --> $\\yao{shaoyin}$\n\n例子4:`\\yao{重}` --> $\\yao{重}$\n\n\n\n **命令:六爻排盘** `\\paigua{时令}{卦辞}{标识}`\n\n其中 【时令】、【卦辞】这两个参数是必须的,**【标识】**参数可以省略。\n\n【时令】允许的格式为:“1980-1-3 08:15”、“2019年3月4日”、“申月戊寅日”\n\n【卦辞】允许的格式为:“解之师”、“离为火”、“--==x-”、“0121100”、“阴阳阴交阴阳”\n\n【标识】由三部分组成:ID号、简排、字符大小。格式为:`guadi/s/5`\n\n- 「ID号」:随便一串字符,空白则默认为“gua1”。:x:不允许只有数字,因为会与参数「字符大小」混淆。如果一个文本出现多个六爻卦,则每个卦都需要指定一个ID号。否则下面的命令[卦爻细节](#guayao)不知道具体指向哪一个卦本。\n- 「简排」:只允许`s` 和 `l`两个英文字符的其中一个。`s` 表示只显示短名,如“妻财”显示为“财”,“青龙”显示为“龙”。`l` 则显示完整名称。留白则按照用户全局设定来显示。(参阅[用户设定](#code2))\n- 「字符大小」:允许 0 - 9 档。数字越大文字越大。默认大小为`5`或者用户的[全局设定](#code2)。\n\n例子5: `$\\paigua{1978年7月1日}{101201}{gua1}$` 效果\n$$\\paigua{1978年7月1日}{101201}{gua1}$$\n\n:pencil2: 如果文章很长,需要在指定位置重新显示一遍卦本,则可以使用重排命令。即让【时令】和【卦辞】两个参数留白,只给出【ID号】。如 `\\paigua{}{}{gua1}` 。留白的参数,仍然需要用大括号括起来,否则解释器会出错。\n\n\n\n **命令:卦爻细节** `\\guayao{标识}{位置}`\n\n使用前提:当前文本中已经排出至少一支六爻卦。\n\n【标识】:与排盘命令的「标识」参数等同。由ID号、简排、字符大小三个部分组成。其中「ID号」标识已经存在的六爻盘。\n\n【位置】:格式为 “ben1”、“fu3”、“bian5” 等,分别表示「本卦初爻」、「伏卦3爻」、「变卦5爻」\n\n\n\n例子6:`\\guayao{gua1}{ben4}` --> $\\guayao{gua1}{ben4}$\n\n> 例子6 中给出的「ID号」为例子5中指定的ID号 “gua1”,并要求显示本卦4爻的具体信息。\n\n\n\n#### 八字\n\n **命令:八字排盘** `\\paibazi{时间}{性别}{标识}[细节]`\n\n【时间】和【性别】参数必填,【标识】和【细节】参数可选。(如果要第二次显示已有的八字盘,则【时间】和【性别】参数可留白,只给定【标识】参数中的「ID号」)\n\n【时间】:允许格式 “1980-1-3 08:15”、“2019年3月4日 6时3分” \n\n【性别】:允许格式 “m”、“f”、“男”、“女”、“乾”、“坤”、\n\n【标识】:与排盘命令的「标识」参数等同。由ID号、简排、字符大小三个部分组成。\n\n【细节】:允许“藏干”、“长生”、“纳音”这三个中的一个或者多个,也可以留白。格式为 `藏干/纳音/长生`\n\n例子7:`\\paibazi{1990年5月1日 6:45}{男}{小明/s/5}`\n\n$\\paibazi{1990年5月1日 6:45}{男}{小明/5}$\n\n例子8:重排例子7的八字盘 `\\paibazi{}{}{小明/s/5}[纳音/藏干/长生]` ,并要求显示藏干和纳音等信息。\n\n$\\paibazi{}{}{小明/s/5}[纳音/藏干/长生]$\n\n\n\n **命令:八字细节** `\\bazi{标识}{类别}[细节]`\n\n使用前提:当前文本中已经排出至少一个八字盘。\n\n【标识】:与排盘命令的「标识」参数等同。由ID号、简排、字符大小三个部分组成。其中「ID号」标识已经存在的八字命盘。\n\n【类别】:支持 “神煞”、“大运”、“流年”、“小运” 四个选项。\n\n【细节】:具体含义视【类别】而定。\n\n- 类别为「神煞」时:「细节」为 1~ 9 的数字,表示每行列数。\n- 类别为「大运」时:` 1-9 纳音/藏干/长生/神煞` 前面的数字表示第几步大运,限定 1 到 10\n- 类别为「流年」和「小运」时: `2015 - 2019 纳音/藏干/长生/神煞` 前面的数字表示年份,注意不要超过命盘的生命周期,否则会出错。「纳音/藏干/长生/神煞」可以留白,也可只显示一两项。\n\n\n\n例子9: `\\bazi{小明}{神煞}[6]` 显示小明命盘的神煞,每行6列。\n\n$\\bazi{小明}{神煞}[6]$\n\n\n\n例子10: `\\bazi{小明}{大运}[2-3 ]` 显示小明的第二到第三步大运\n\n$\\bazi{小明}{大运}[2-3]$\n\n\n\n例子11: `\\bazi{小明}{流年}[2017-2019 纳音/藏干/长生/神煞]` 显示小明的2017到2019年的流年信息。\n\n$\\bazi{小明}{流年}[2017-2019 纳音/藏干/长生/神煞]$\n\n\n\n### 未来与展望\n\n我知道这篇文章介绍的工具,并非所有人都能使用。所以在不久的将来,还是要制作一个独立易学软件,以便易友在PC端和移动端都能按照传统的方式使用。但由于时间和精力原因,我无法保证完成时间。\n\n\n\n不断完善易学函数,提供更丰富的应用细节。在用户更为广泛的MD编辑器中实现此方式。比如有道云笔记、为知笔记、印象笔记等。并争取介绍移动端(Android & iOS)实现此方式。也希望在Gitbook中实现。\n\n\n\n希望能将师父的六爻和八字讲义,『增删卜易』等著作制作成Gitbook,将精彩的卦例和名人八字建成易学数据库。这样就可以通过我的易学函数直接获取, 比如 `\\paibazi{蒋介石}`。\n\n\n\n### 附录: \n\n#### 命令列表\n\n[纳音](#nayin)\n\n[爻符](#yao)\n\n[排卦](#paigua)\n\n[卦爻细节](#guayao)\n\n[排八字](#paibazi)\n\n[八字细节](#bazi)\n\n#### 发布\n\n脚本文件的[原始路径](https://github.com/maiernte/img/raw/master/libs/bundle.js)是`https://github.com/maiernte/img/raw/master/libs/bundle.js`。因为涉及到跨域问题,要通过 [Gitkack](https://raw.githack.com/) 重链接,把上述路径输入到 Githack 的地址框,会得到「应用地址」和「开发地址」。\n\n[应用地址](https://rawcdn.githack.com/maiernte/img/bb3c42dc26b0866a142bb905d1753ac483e0a474/libs/bundle.js):\n\n`https://rawcdn.githack.com/maiernte/img/11a1bb572a6875dbf434a7fc457ea2fdd329f7db/libs/bundle.js`\n\n[开发地址](https://raw.githack.com/maiernte/img/master/libs/bundle.js):\n\n`https://raw.githack.com/maiernte/img/master/libs/bundle.js`\n\n#### 查看当前易学函数库版本\n\n在 chrome 浏览其中打开此博文,Mac 系统中按 `⌘+⌥+I` ,Windows 系统 `Ctr+⇧+I`,或者 Chrome 菜单栏调出 “开发者工具”,选择 Console 页面,即可显示当前易学库版本和时间。","slug":"IT/skill/MathJax用于易学领域","published":1,"updated":"2020-05-08T09:38:08.489Z","_id":"cka1y599q004l4huuz9r1vgbn","comments":1,"layout":"post","photos":[],"link":"","content":"

关于利用 MathJaxKatex 数学公式解释器,实现易学上排六爻盘和八字盘个功能。今天实现了易学上的核心功能。有望将来能添加更多的函数,以便利各位同门以及广大易友。

\n\n

效果与演示

\n\n无法观看油管的朋友请移步B站:[使用MathJax渲染六爻和八字盘](https://www.bilibili.com/video/av66317810/)\n

安装和使用

\n

首先,你需要一个支持 Markdown (简称MD) 语言格式的文本编辑器。如果不知道什么是MD的话,请参阅以下介绍:

\n\n

Markdown 语言简约而优美,可以自由转换成pdf、word、Html 等等各种其它格式的文本。可以推送到博客、微信公众号等等。虽然算卦是一个传统的行业,我们仍然不宜固步自封。MD语言支持MathJax和Katex书写Latex数学公式,可以写出非常漂亮的数学、物理、化学方面的公式。正式的科技刊物都要求用Latex格式。

\n

这个易学解决方案是对 MathJax 进行扩展,加入指定的易学公式,让 MathJax 解释器去完成公式渲染。它并不是一个独立的程序。需要构建在已有的MD文本编辑器之上。我使用一个文件夹存放所有的关于易学方面的MD文件,并将这个文件夹同步到 坚果云,这样就可以实现多台电脑和移动端之间的同步,而不太需要一个独立的易学软件。甚至可以将MD文件导出为HTML文件,放到我的HEXO博客上(您正在阅读的这篇博文即是例子)。

\n

理论上所有支持Markdown语言和MathJax的文本编辑器,都可以改装。改装过程需要两段代码和一个库文件。

\n

文本编辑器

\n
Typora
\n

Typora 是我个人最钟爱的MD编辑器,因此这里着重介绍。如果你喜欢用别的MD编辑器,比如iAWrte等,理论上可以用同样的方式改装。(无法百分百保证) 有需要的朋友可以私下联系我。

\n

最新的安装教程请参考华鹤易学平台文档

\n
VSCode
\n

同样请移步华鹤易学平台文档。那里有详细描述。

\n

Hexo博客

\n

🔔 注意:首先要检查自己的 Hexo 博客使用的渲染器是否默认开启了Katex或者MathJax数学插件。如果有的话需要卸载或者禁用数学插件,如果不能禁用,就必须更换Markdown渲染器。

\n
\n

因为系统使用的数学插件会在网页生成之前就改动数学表达,这样无法使用我提供给的函数库。我提供给博客的方案是在浏览网页的时候,即时渲染易学公式。

\n
\n

比如我之前用了 “hexo-renderer-markdown-it-plus” 渲染器就是强制使用 Katex 数学渲染的。

\n
1
2
npm un hexo-renderer-markdown-it-plus --save // 卸载
npm i hexo-renderer-markdown-it --save // 更换
\n

然后将下列代码添加到文件模版就可以了。使用 swig 模版的是在 <your thems>/layout/_custom/header.swig 或者 <your thems>/layout/index.swig 。而使用 ejs 模版的是文件 <your thems>/layout/layout.ejs

\n
1
2
3
4
5
6
7
8
9
<!--前三行最好添加到 <header></header> 头区块中-->

<link rel=\"stylesheet\" href=\"https://cdn.jsdelivr.net/npm/katex@0.11.0/dist/katex.min.css\" >
<script defer src=\"https://cdn.jsdelivr.net/npm/katex@0.11.0/dist/katex.min.js\" ></script>
<script defer src=\"https://cdn.jsdelivr.net/npm/katex@0.11.0/dist/contrib/auto-render.min.js\"></script>


<script src=\"https://raw.githack.com/maiernte/img/master/libs/katexYixue.js\"></script>
<script src=\"https://raw.githack.com/maiernte/img/master/libs/bundle.js\"></script>
\n
\n

注意搜索 _config.yml 文件,“math”, “katex”, “mathjax” 等字样,发现有的话把他们禁用。

\n
\n

Gitbook

\n

最新的安装教程请参考华鹤易学平台文档

\n

API 参数

\n

使用易学函数库非常简单,在经过改装的Markdown编辑器中,输入易学公式,并用两个 $ 符号将公式前后围起来即可。MD语言一般默认两个 $ 符号之间的文本是数学公式,它会调用MathJax对公式进行渲染。否则,它会认为这是普通文本,而不会做任何动作。

\n

易学通用

\n

命令:纳音 \\nayin{干支名称}

\n

【干支名称】 :就是甲子、己卯等六十甲子。

\n

例子1:\\nayin{戊午} --> $\\nayin{戊午}$

\n

命令:干支日历 \\timegz{时间参数}{年月日}

\n

【时间参数】 :例如 2020-02-21。

\n

【年月日】 :省略时默认为111,即显示年月日。0表示不显示,1表示显示。

\n

例子1:\\timegz{2020-02-21} --> $\\timegz{2020-02-21}$

\n

例子2:\\timegz{2020-02-21}{011} --> $\\timegz{2020-02-21}{011}$

\n

六爻

\n

命令:爻符 \\yao{爻名}

\n

【爻名】:laoyin, laoyang,shaoyin,shaoyang, x, o, =, -, 交,重,阴,阳,0,1,2,3

\n

例子2:\\yao{x} --> $\\yao{x}$

\n

例子3:\\yao{shaoyin} --> $\\yao{shaoyin}$

\n

例子4:\\yao{重} --> $\\yao{重}$

\n

命令:六爻排盘 \\paigua{时令}{卦辞}{标识}

\n

其中 【时令】、【卦辞】这两个参数是必须的,**【标识】**参数可以省略。

\n

【时令】允许的格式为:“1980-1-3 08:15”、“2019年3月4日”、“申月戊寅日”

\n

【卦辞】允许的格式为:“解之师”、“离为火”、“–==x-”、“0121100”、“阴阳阴交阴阳”

\n

【标识】由三部分组成:ID号、简排、字符大小。格式为:guadi/s/5

\n
    \n
  • 「ID号」:随便一串字符,空白则默认为“gua1”。:x:不允许只有数字,因为会与参数「字符大小」混淆。如果一个文本出现多个六爻卦,则每个卦都需要指定一个ID号。否则下面的命令卦爻细节不知道具体指向哪一个卦本。
  • \n
  • 「简排」:只允许sl两个英文字符的其中一个。s 表示只显示短名,如“妻财”显示为“财”,“青龙”显示为“龙”。l 则显示完整名称。留白则按照用户全局设定来显示。(参阅用户设定
  • \n
  • 「字符大小」:允许 0 - 9 档。数字越大文字越大。默认大小为5或者用户的全局设定
  • \n
\n

例子5: $\\paigua{1978年7月1日}{101201}{gua1}$ 效果
\n$$\\paigua{1978年7月1日}{101201}{gua1}$$

\n

:pencil2: 如果文章很长,需要在指定位置重新显示一遍卦本,则可以使用重排命令。即让【时令】和【卦辞】两个参数留白,只给出【ID号】。如 \\paigua{}{}{gua1} 。留白的参数,仍然需要用大括号括起来,否则解释器会出错。

\n

命令:卦爻细节 \\guayao{标识}{位置}

\n

使用前提:当前文本中已经排出至少一支六爻卦。

\n

【标识】:与排盘命令的「标识」参数等同。由ID号、简排、字符大小三个部分组成。其中「ID号」标识已经存在的六爻盘。

\n

【位置】:格式为 “ben1”、“fu3”、“bian5” 等,分别表示「本卦初爻」、「伏卦3爻」、「变卦5爻」

\n

例子6:\\guayao{gua1}{ben4} --> $\\guayao{gua1}{ben4}$

\n
\n

例子6 中给出的「ID号」为例子5中指定的ID号 “gua1”,并要求显示本卦4爻的具体信息。

\n
\n

八字

\n

命令:八字排盘 \\paibazi{时间}{性别}{标识}[细节]

\n

【时间】和【性别】参数必填,【标识】和【细节】参数可选。(如果要第二次显示已有的八字盘,则【时间】和【性别】参数可留白,只给定【标识】参数中的「ID号」)

\n

【时间】:允许格式 “1980-1-3 08:15”、“2019年3月4日 6时3分”

\n

【性别】:允许格式 “m”、“f”、“男”、“女”、“乾”、“坤”、

\n

【标识】:与排盘命令的「标识」参数等同。由ID号、简排、字符大小三个部分组成。

\n

【细节】:允许“藏干”、“长生”、“纳音”这三个中的一个或者多个,也可以留白。格式为 藏干/纳音/长生

\n

例子7:\\paibazi{1990年5月1日 6:45}{男}{小明/s/5}

\n

$\\paibazi{1990年5月1日 6:45}{男}{小明/5}$

\n

例子8:重排例子7的八字盘 \\paibazi{}{}{小明/s/5}[纳音/藏干/长生] ,并要求显示藏干和纳音等信息。

\n

$\\paibazi{}{}{小明/s/5}[纳音/藏干/长生]$

\n

命令:八字细节 \\bazi{标识}{类别}[细节]

\n

使用前提:当前文本中已经排出至少一个八字盘。

\n

【标识】:与排盘命令的「标识」参数等同。由ID号、简排、字符大小三个部分组成。其中「ID号」标识已经存在的八字命盘。

\n

【类别】:支持 “神煞”、“大运”、“流年”、“小运” 四个选项。

\n

【细节】:具体含义视【类别】而定。

\n
    \n
  • 类别为「神煞」时:「细节」为 1~ 9 的数字,表示每行列数。
  • \n
  • 类别为「大运」时: 1-9 纳音/藏干/长生/神煞 前面的数字表示第几步大运,限定 1 到 10
  • \n
  • 类别为「流年」和「小运」时: 2015 - 2019 纳音/藏干/长生/神煞 前面的数字表示年份,注意不要超过命盘的生命周期,否则会出错。「纳音/藏干/长生/神煞」可以留白,也可只显示一两项。
  • \n
\n

例子9: \\bazi{小明}{神煞}[6] 显示小明命盘的神煞,每行6列。

\n

$\\bazi{小明}{神煞}[6]$

\n

例子10: \\bazi{小明}{大运}[2-3 ] 显示小明的第二到第三步大运

\n

$\\bazi{小明}{大运}[2-3]$

\n

例子11: \\bazi{小明}{流年}[2017-2019 纳音/藏干/长生/神煞] 显示小明的2017到2019年的流年信息。

\n

$\\bazi{小明}{流年}[2017-2019 纳音/藏干/长生/神煞]$

\n

未来与展望

\n

我知道这篇文章介绍的工具,并非所有人都能使用。所以在不久的将来,还是要制作一个独立易学软件,以便易友在PC端和移动端都能按照传统的方式使用。但由于时间和精力原因,我无法保证完成时间。

\n

不断完善易学函数,提供更丰富的应用细节。在用户更为广泛的MD编辑器中实现此方式。比如有道云笔记、为知笔记、印象笔记等。并争取介绍移动端(Android & iOS)实现此方式。也希望在Gitbook中实现。

\n

希望能将师父的六爻和八字讲义,『增删卜易』等著作制作成Gitbook,将精彩的卦例和名人八字建成易学数据库。这样就可以通过我的易学函数直接获取, 比如 \\paibazi{蒋介石}

\n

附录:

\n

命令列表

\n

纳音

\n

爻符

\n

排卦

\n

卦爻细节

\n

排八字

\n

八字细节

\n

发布

\n

脚本文件的原始路径https://github.com/maiernte/img/raw/master/libs/bundle.js。因为涉及到跨域问题,要通过 Gitkack 重链接,把上述路径输入到 Githack 的地址框,会得到「应用地址」和「开发地址」。

\n

应用地址

\n

https://rawcdn.githack.com/maiernte/img/11a1bb572a6875dbf434a7fc457ea2fdd329f7db/libs/bundle.js

\n

开发地址

\n

https://raw.githack.com/maiernte/img/master/libs/bundle.js

\n

查看当前易学函数库版本

\n

在 chrome 浏览其中打开此博文,Mac 系统中按 ⌘+⌥+I ,Windows 系统 Ctr+⇧+I,或者 Chrome 菜单栏调出 “开发者工具”,选择 Console 页面,即可显示当前易学库版本和时间。

\n","site":{"data":{}},"excerpt":"

关于利用 MathJaxKatex 数学公式解释器,实现易学上排六爻盘和八字盘个功能。今天实现了易学上的核心功能。有望将来能添加更多的函数,以便利各位同门以及广大易友。

","more":"

效果与演示

\n\n无法观看油管的朋友请移步B站:[使用MathJax渲染六爻和八字盘](https://www.bilibili.com/video/av66317810/)\n

安装和使用

\n

首先,你需要一个支持 Markdown (简称MD) 语言格式的文本编辑器。如果不知道什么是MD的话,请参阅以下介绍:

\n\n

Markdown 语言简约而优美,可以自由转换成pdf、word、Html 等等各种其它格式的文本。可以推送到博客、微信公众号等等。虽然算卦是一个传统的行业,我们仍然不宜固步自封。MD语言支持MathJax和Katex书写Latex数学公式,可以写出非常漂亮的数学、物理、化学方面的公式。正式的科技刊物都要求用Latex格式。

\n

这个易学解决方案是对 MathJax 进行扩展,加入指定的易学公式,让 MathJax 解释器去完成公式渲染。它并不是一个独立的程序。需要构建在已有的MD文本编辑器之上。我使用一个文件夹存放所有的关于易学方面的MD文件,并将这个文件夹同步到 坚果云,这样就可以实现多台电脑和移动端之间的同步,而不太需要一个独立的易学软件。甚至可以将MD文件导出为HTML文件,放到我的HEXO博客上(您正在阅读的这篇博文即是例子)。

\n

理论上所有支持Markdown语言和MathJax的文本编辑器,都可以改装。改装过程需要两段代码和一个库文件。

\n

文本编辑器

\n
Typora
\n

Typora 是我个人最钟爱的MD编辑器,因此这里着重介绍。如果你喜欢用别的MD编辑器,比如iAWrte等,理论上可以用同样的方式改装。(无法百分百保证) 有需要的朋友可以私下联系我。

\n

最新的安装教程请参考华鹤易学平台文档

\n
VSCode
\n

同样请移步华鹤易学平台文档。那里有详细描述。

\n

Hexo博客

\n

🔔 注意:首先要检查自己的 Hexo 博客使用的渲染器是否默认开启了Katex或者MathJax数学插件。如果有的话需要卸载或者禁用数学插件,如果不能禁用,就必须更换Markdown渲染器。

\n
\n

因为系统使用的数学插件会在网页生成之前就改动数学表达,这样无法使用我提供给的函数库。我提供给博客的方案是在浏览网页的时候,即时渲染易学公式。

\n
\n

比如我之前用了 “hexo-renderer-markdown-it-plus” 渲染器就是强制使用 Katex 数学渲染的。

\n\n

然后将下列代码添加到文件模版就可以了。使用 swig 模版的是在 <your thems>/layout/_custom/header.swig 或者 <your thems>/layout/index.swig 。而使用 ejs 模版的是文件 <your thems>/layout/layout.ejs

\n\n
\n

注意搜索 _config.yml 文件,“math”, “katex”, “mathjax” 等字样,发现有的话把他们禁用。

\n
\n

Gitbook

\n

最新的安装教程请参考华鹤易学平台文档

\n

API 参数

\n

使用易学函数库非常简单,在经过改装的Markdown编辑器中,输入易学公式,并用两个 $ 符号将公式前后围起来即可。MD语言一般默认两个 $ 符号之间的文本是数学公式,它会调用MathJax对公式进行渲染。否则,它会认为这是普通文本,而不会做任何动作。

\n

易学通用

\n

命令:纳音 \\nayin{干支名称}

\n

【干支名称】 :就是甲子、己卯等六十甲子。

\n

例子1:\\nayin{戊午} --> $\\nayin{戊午}$

\n

命令:干支日历 \\timegz{时间参数}{年月日}

\n

【时间参数】 :例如 2020-02-21。

\n

【年月日】 :省略时默认为111,即显示年月日。0表示不显示,1表示显示。

\n

例子1:\\timegz{2020-02-21} --> $\\timegz{2020-02-21}$

\n

例子2:\\timegz{2020-02-21}{011} --> $\\timegz{2020-02-21}{011}$

\n

六爻

\n

命令:爻符 \\yao{爻名}

\n

【爻名】:laoyin, laoyang,shaoyin,shaoyang, x, o, =, -, 交,重,阴,阳,0,1,2,3

\n

例子2:\\yao{x} --> $\\yao{x}$

\n

例子3:\\yao{shaoyin} --> $\\yao{shaoyin}$

\n

例子4:\\yao{重} --> $\\yao{重}$

\n

命令:六爻排盘 \\paigua{时令}{卦辞}{标识}

\n

其中 【时令】、【卦辞】这两个参数是必须的,**【标识】**参数可以省略。

\n

【时令】允许的格式为:“1980-1-3 08:15”、“2019年3月4日”、“申月戊寅日”

\n

【卦辞】允许的格式为:“解之师”、“离为火”、“–==x-”、“0121100”、“阴阳阴交阴阳”

\n

【标识】由三部分组成:ID号、简排、字符大小。格式为:guadi/s/5

\n
    \n
  • 「ID号」:随便一串字符,空白则默认为“gua1”。:x:不允许只有数字,因为会与参数「字符大小」混淆。如果一个文本出现多个六爻卦,则每个卦都需要指定一个ID号。否则下面的命令卦爻细节不知道具体指向哪一个卦本。
  • \n
  • 「简排」:只允许sl两个英文字符的其中一个。s 表示只显示短名,如“妻财”显示为“财”,“青龙”显示为“龙”。l 则显示完整名称。留白则按照用户全局设定来显示。(参阅用户设定
  • \n
  • 「字符大小」:允许 0 - 9 档。数字越大文字越大。默认大小为5或者用户的全局设定
  • \n
\n

例子5: $\\paigua{1978年7月1日}{101201}{gua1}$ 效果
\n$$\\paigua{1978年7月1日}{101201}{gua1}$$

\n

:pencil2: 如果文章很长,需要在指定位置重新显示一遍卦本,则可以使用重排命令。即让【时令】和【卦辞】两个参数留白,只给出【ID号】。如 \\paigua{}{}{gua1} 。留白的参数,仍然需要用大括号括起来,否则解释器会出错。

\n

命令:卦爻细节 \\guayao{标识}{位置}

\n

使用前提:当前文本中已经排出至少一支六爻卦。

\n

【标识】:与排盘命令的「标识」参数等同。由ID号、简排、字符大小三个部分组成。其中「ID号」标识已经存在的六爻盘。

\n

【位置】:格式为 “ben1”、“fu3”、“bian5” 等,分别表示「本卦初爻」、「伏卦3爻」、「变卦5爻」

\n

例子6:\\guayao{gua1}{ben4} --> $\\guayao{gua1}{ben4}$

\n
\n

例子6 中给出的「ID号」为例子5中指定的ID号 “gua1”,并要求显示本卦4爻的具体信息。

\n
\n

八字

\n

命令:八字排盘 \\paibazi{时间}{性别}{标识}[细节]

\n

【时间】和【性别】参数必填,【标识】和【细节】参数可选。(如果要第二次显示已有的八字盘,则【时间】和【性别】参数可留白,只给定【标识】参数中的「ID号」)

\n

【时间】:允许格式 “1980-1-3 08:15”、“2019年3月4日 6时3分”

\n

【性别】:允许格式 “m”、“f”、“男”、“女”、“乾”、“坤”、

\n

【标识】:与排盘命令的「标识」参数等同。由ID号、简排、字符大小三个部分组成。

\n

【细节】:允许“藏干”、“长生”、“纳音”这三个中的一个或者多个,也可以留白。格式为 藏干/纳音/长生

\n

例子7:\\paibazi{1990年5月1日 6:45}{男}{小明/s/5}

\n

$\\paibazi{1990年5月1日 6:45}{男}{小明/5}$

\n

例子8:重排例子7的八字盘 \\paibazi{}{}{小明/s/5}[纳音/藏干/长生] ,并要求显示藏干和纳音等信息。

\n

$\\paibazi{}{}{小明/s/5}[纳音/藏干/长生]$

\n

命令:八字细节 \\bazi{标识}{类别}[细节]

\n

使用前提:当前文本中已经排出至少一个八字盘。

\n

【标识】:与排盘命令的「标识」参数等同。由ID号、简排、字符大小三个部分组成。其中「ID号」标识已经存在的八字命盘。

\n

【类别】:支持 “神煞”、“大运”、“流年”、“小运” 四个选项。

\n

【细节】:具体含义视【类别】而定。

\n
    \n
  • 类别为「神煞」时:「细节」为 1~ 9 的数字,表示每行列数。
  • \n
  • 类别为「大运」时: 1-9 纳音/藏干/长生/神煞 前面的数字表示第几步大运,限定 1 到 10
  • \n
  • 类别为「流年」和「小运」时: 2015 - 2019 纳音/藏干/长生/神煞 前面的数字表示年份,注意不要超过命盘的生命周期,否则会出错。「纳音/藏干/长生/神煞」可以留白,也可只显示一两项。
  • \n
\n

例子9: \\bazi{小明}{神煞}[6] 显示小明命盘的神煞,每行6列。

\n

$\\bazi{小明}{神煞}[6]$

\n

例子10: \\bazi{小明}{大运}[2-3 ] 显示小明的第二到第三步大运

\n

$\\bazi{小明}{大运}[2-3]$

\n

例子11: \\bazi{小明}{流年}[2017-2019 纳音/藏干/长生/神煞] 显示小明的2017到2019年的流年信息。

\n

$\\bazi{小明}{流年}[2017-2019 纳音/藏干/长生/神煞]$

\n

未来与展望

\n

我知道这篇文章介绍的工具,并非所有人都能使用。所以在不久的将来,还是要制作一个独立易学软件,以便易友在PC端和移动端都能按照传统的方式使用。但由于时间和精力原因,我无法保证完成时间。

\n

不断完善易学函数,提供更丰富的应用细节。在用户更为广泛的MD编辑器中实现此方式。比如有道云笔记、为知笔记、印象笔记等。并争取介绍移动端(Android & iOS)实现此方式。也希望在Gitbook中实现。

\n

希望能将师父的六爻和八字讲义,『增删卜易』等著作制作成Gitbook,将精彩的卦例和名人八字建成易学数据库。这样就可以通过我的易学函数直接获取, 比如 \\paibazi{蒋介石}

\n

附录:

\n

命令列表

\n

纳音

\n

爻符

\n

排卦

\n

卦爻细节

\n

排八字

\n

八字细节

\n

发布

\n

脚本文件的原始路径https://github.com/maiernte/img/raw/master/libs/bundle.js。因为涉及到跨域问题,要通过 Gitkack 重链接,把上述路径输入到 Githack 的地址框,会得到「应用地址」和「开发地址」。

\n

应用地址

\n

https://rawcdn.githack.com/maiernte/img/11a1bb572a6875dbf434a7fc457ea2fdd329f7db/libs/bundle.js

\n

开发地址

\n

https://raw.githack.com/maiernte/img/master/libs/bundle.js

\n

查看当前易学函数库版本

\n

在 chrome 浏览其中打开此博文,Mac 系统中按 ⌘+⌥+I ,Windows 系统 Ctr+⇧+I,或者 Chrome 菜单栏调出 “开发者工具”,选择 Console 页面,即可显示当前易学库版本和时间。

"},{"title":"搭建Hexo博客的流水账","date":"2019-07-25T03:49:15.000Z","urlname":"how-build-my-hexo-blog","toc":true,"notshow":false,"_content":"\n\n\n建网过程中的一些流水账。以备将来查询。\n\n\n\n# 建立网站\n\n## Github配置\n\n输入命令 `ssh-keygen -t rsa -b 4096 -C \"myname@gmail.com\"`。\n\n\n\n密码 `T1`。(下列展开后复制)\n\n> 将文件 ~/.ssh/id_rsa.pub 中的内容复制到 Github 的SSH-Key 内就可以了。(备份文件已上传百度网盘)\n\n3. 在Github上新建SSH-Key名称为`gmail`\n\n[具体步骤参阅此文章](https://gavinlee1.github.io/2017/02/25/十步之内轻松搞定-Hexo-GitHub搭建个人博客/)\n\n```\nssh-keygen -t rsa -b 4096 -C \"username@gmail.com\"\n[Enter]\n[password T..1]\n\neval \"$(ssh-agent -s)\"\nssh-add -K ~/.ssh/id_rsa\n\ncd ~\ncd .ssh\nls\nvim id_rsa.pub\n(然后复制钥匙串)\n```\n4. 测试公匙\n\n```\n$ ssh -T git@github.com\n\nHi username! You've successfully authenticated, but GitHub does not provide shell access.\n```\n\n## 安装Hexo\n\n参考资料[^1] [^7]。\n1. 安装node.js 因为以前已经安装过,所以跳过。\n2. 安装 Hexo `$ npm install hexo-cli -g` \n3. 创建网站\n```command\nmkdir mywiki\ncd mywiki\nhexo init\nnpm install\n```\n4. 生成静态页面 `hexo g` or `hexo generate`\n5. 启动本地网站服务 `hexo s` or `hexo server`\n> 网站一般会运行在 http://localhost:4000/\n> Press Ctrl+C to stop.\n\n6. 用pow做服务本地运行\n\n**Install**\n\n```\n$ curl get.pow.cx | sh\n```\n\n**Setup**\n\nSymlink the folder into `~/.pow`\n\n```\n$ cd ~/.pow\n$ ln -s /path/to/test\n```\n\n## 发布到Github\n\n终于搭建好站点部署环境啦,那么要怎么样将我们本地生成预览好的页面发布到github上呢?很简单,Follow!\n\n首先,打开blog目录下的`_config.yml`,找到deploy段,配置成这样\n\n> deploy:\n> type: git\n> repository: git@github.com:yourname/yourname.github.io.git\n> branch: master\n\n注意将代码里面的yourname换成你账号的username。\n\n设置git身份信息\n\n> git config --global user.name \"你的用户名\"\n> git config --global user.email \"你的邮箱\" \n\n执行以下指令进行部署\n\n`hexo d -g `\n\n如果提示没找到git,请先执行以下指令\n\n`cnpm install hexo-deployer-git --save` \n\n再次部署后,浏览器打开 [https://yourname.github.io](https://yourname.github.io/) 就可以看到刚才本地预览页面。\n\n## 网站基本配置\n\n### Next 主题\n\n主题配置文件说明\n\n{% fold 点击显/隐内容 %}\n\n```ini\n# Hexo 站点配置文件\n## Docs: https://hexo.io/docs/configuration.html\n## Source: https://github.com/hexojs/hexo/\n\n# 网站配置\ntitle: Hexo # 网站标题\nsubtitle: # 网站副标题\ndescription: # 网站描述\nauthor: John Doe # 你的昵称\nlanguage: # 网站使用的语言(英文:en, 简体中文:zh-Hans,繁体中文:zh-tw)\ntimezone: # 网站时区,用于生成页面时填充相关时间,默认使用电脑时区,一般不用改\n\n# URL\n## 如果你的站点要放入子目录, 请将url设置为'http://yoursite.com/child' 并将根目录设置为'/child/'\nurl: http://yoursite.com # 站点网址\nroot: / # 网站根目录\npermalink: :year/:month/:day/:title/ #文单的永久链接格式\npermalink_defaults: # 永久链接中各部分的默认值\n\n# 目录\nsource_dir: source # 资源文件夹,这个文件夹用来存放博客内容\npublic_dir: public # 公共文件夹,这个文件夹用来存放生成的站点静态文件\ntag_dir: tags # 标签文件夹\narchive_dir: archives # 归档文件夹\ncategory_dir: categories # 分类文件夹\ncode_dir: downloads/code # Include code文件夹\ni18n_dir: :lang # 国际化文件夹,存放各种语言定义\nskip_render: # 跳过指定文件的渲染\n\n# 写作\nnew_post_name: :title.md # 新文章的文件名称\ndefault_layout: post # 预设布局\ntitlecase: false # 把标题转换为 title case\nexternal_link: true # 在新标签中打开链接\nfilename_case: 0 # 把文件名称转换为 (1) 小写或 (2) 大写\nrender_drafts: false # 显示草稿\npost_asset_folder: false # 启动 Asset 文件夹\nrelative_link: false # 把链接改为与根目录的相对位址\nfuture: true # 显示未来的文章\nhighlight: # 代码块的设置\n enable: true\n line_number: true\n auto_detect: false\n tab_replace:\n\n# 分类 & 标签\ndefault_category: uncategorized # 默认分类\ncategory_map: # 分类别名\ntag_map: # 标签别名\n\n# 日期 / 时间格式\n## Hexo 使用 Moment.js 来解析和显示时间\n## http://momentjs.com/docs/#/displaying/format/\ndate_format: YYYY-MM-DD # 日期格式\ntime_format: HH:mm:ss # 时间格式\n\n# 分页\n## 每页显示的文章量 (0 = 关闭分页功能)\nper_page: 10\npagination_dir: page\n\n# 扩展\n## Plugins: https://hexo.io/plugins/\n## Themes: https://hexo.io/themes/\ntheme: landscape # 主题\n\n# 部署\n## Docs: https://hexo.io/docs/deployment.html\ndeploy:\n type:\n```\n\n{% endfold %}\n\n### Wikitten主题\n\n具体配置参考[开发者说明](https://github.com/zthxxx/hexo-theme-Wikitten/blob/master/README_zh-CN.md),更详细的描述参阅[hexo-theme-icarus](https://github.com/ppoffice/hexo-theme-icarus/wiki)。为了与主题Next不冲突,作以下修改。\n\n1. 自行修改 `tags`, `about`,`categories` 等`index.md`,而不能从主题复制,覆盖站点原有设置。\n2. `languages\\zh-CN.yml` 重命名为 `zh-Hans.yml`\n3. `_config.yml` 菜单作以下更改\n\n```ini\nmenu:\n 首页: /\n 归档: /archives/\n 分类: /categories/\n 标签: /tags/\n 关于: /about/\n```\n\n4. `thumbnail: true` 使得每个post在快速列表里,显示图标。但就是每个帖子都要设定,很麻烦。\n5. post 中的 toc 要设置为 true,如果需要显示目录的话。\n\n### 同时部署两个项目\n\n第一个项目使用 Github 上面默认的 Github Pages,即 `username.github.io` 。在站点配置文件中如下:\n\n```\nurl: http://username.github.io\nroot: /\n...\n...\ndeploy:\n type: git\n repository: git@github.com:username/username.github.io.git\n branch: master\n\n```\n\n\n第二个站点开通一个 普通的repository,添加名为`gh-pages` 的Branch,并将gh-pages` 设为默认Branch。我将第二个仓库命名为 wiki ,那第二个站点就运行在 `https://username.github.io/wiki`次级目录下面。\n\n站点配置文件更改如下:\n\n```\nurl: http://username.github.io/wiki\nroot: /wiki/\n...\n...\ndeploy:\n type: git\n repository: git@github.com:username/wiki.git\n branch: gh-pages\n```\n\n同样用 `hexo d -g` 部署命令发布,两个站点就都运行起来了。\n\n为了使得两个项目使用同一个笔记资源,将站点中的 source 文件夹移到项目意外,将配置文件里的 `source_dir: source` 改为 `source_dir: ../source`(这里使用了相对目录)。\n\n[参考文章][multipages] (细节已经失效,但思路值得参考)\n\n### 站内搜索\n\n1. 安装插件\n\n```shell\nnpm install hexo-generator-search --save\nnpm install hexo-generator-searchdb --save\n```\n\n2. 配置hexo站点主配置文件``_config.yml``, 添加\n\n```ini\nsearch:\n path: search.xml\n field: post\n format: html\n limit: 10000\n```\n\n3. 修改next主题配置文件`_config.yml`,启用 `local_search`\n\n```ini\nlocal_search:\n\tenable: true\n\ttrigger: auto\n\ttop_n_per_article: 1\n```\n\n4. 生成`search.xml`文件以及发布\n\n```shell\nhexo g\nhexo d -g # 本地运行 hexo s\n```\n\n### 去除主题字样\n\n关于添加头像、标签、分类、「关于」等具体的修改,跟着参考资料[^2]里面的步骤做就好了。最后说说如何去掉底部强力驱动及主题字样。\n\n1. 找到 `\\themes\\next\\layout_partials\\`下面的`footer.swig`文件,打开:\n\n```html\n
\n {{ __('footer.powered', 'Hexo') }}\n
\n
\n {{ __('footer.theme') }} -\n \n NexT.{{ theme.scheme }}\n \n
\n```\n\n第一条是“由Hexo驱动” 的Hexo链接,把xml段删除,只留两个单引号''。\n\n第二条是“主题-Next.XX”,将xml段都删掉,不留引号。\n\n```html\n
\n {{ __('footer.powered', '') }}\n
\n
\n {{ __('footer.theme') }}\n
\n```\n\n2. 找到这个地方`\\themes\\next\\languages\\ `下面的语言文件`zh-Hans.yml`(以中文为例):\n\n```ini\nfooter:\n powered: \"由 %s 强力驱动\"\n theme: 主题\n```\n\n将上面的文字改成自己想要的即可。\n\n## 添加评论功能\n\n#### Gitment\n\n**此项目已经终止!**改为Disqus,以及其它评论服务。\n\n1. 安装功能模块。在项目的根目录:\n\n```shell\nnpm i --save gitment\n```\n\n2. 在Github申请应用。`settings -> Developer Settings -> OAuth Apps`\n\n```ini\nApplication name:随便写\nHomepage URL:这个也可以随意写,就写你的博客地址就行\nApplication description:描述,也可以随意写\nAuthorization callback URL:这个必须写你的博客地址\n```\n\n申请好之后点注册,然后就可以看到两个东西`ClientID`和`Client Secret`,后面会用到。\n\n3. 配置Gitment,打开`themes/next/_config.yml`:\n\n```javascript\n# Gitment\n# Introduction: https://imsun.net/posts/gitment-introduction/\ngitment:\n enable: true\n mint: true # RECOMMEND, A mint on Gitment, to support count, language and proxy_gateway\n count: true # Show comments count in post meta area\n lazy: false # Comments lazy loading with a button\n cleanly: false # Hide 'Powered by ...' on footer, and more\n language: # Force language, or auto switch by theme\n github_user: {you github user id}\n github_repo: 随便写一个你的公开的git仓库就行,到时候评论会作为那个项目的issue\n client_id: {刚才申请的ClientID}\n client_secret: {刚才申请的Client Secret}\n proxy_gateway: # Address of api proxy, See: https://github.com/aimingoo/intersect\n redirect_protocol: # Protocol of redirect_uri with force_redirect_protocol when mint enabled\n```\n\n注意到这里基本上已经OK了,再看你的博客应该可以显示评论了.不过每篇博客都需要你手动初始化评论功能(如果你的历史博客很多那就一篇一篇去点吧,不过貌似有人写了批量处理脚本,没试过哈).\n\n而由于 github 中 `Issues` 的 `label` 长度限制为最大 `50` 个字符,当 文章标题长度过长时,该label就会生成失败,而导致初始化错误,弹出 `Validation Failed` 的提示。\n\n通过网上的搜索,发现可以使用文章创建时的时间来代替文章标题,作为这个唯一的label标签。\n\n找到giment的配置:`/themes/next/layout/_third-party/comments/gitment.swig` 文件, 并找到如下部分:\n\n```javascript\nvar gitment = new {{CommentsClass}}({\n id: window.location.pathname,\n owner: '{{ theme.gitment.github_user }}',\n repo: '{{ theme.gitment.github_repo }}',\n ...\n```\n\n将`id`后面的路径值修改为 'itfanr\\_blog\\_\\{{ date(page.date, \"YYYYMMDDhhmmss\") \\}}' 就可以了。\n\n#### Disqus\n\n目前只开通[Disqus](https://disqus.com/)的评论。\n\n1. 开通Disqus账号,并添加一个点 应用。具体步骤参看[Hexo搭建博客系列:(六)Hexo添加Disqus评论](https://www.jianshu.com/p/d68de067ea74)。\n2. 在`主题配置文件`(_config.yml)文件中找到以下代码,添加你Disqus设置的Website Name在shortname。\n\n```json\n# Disqus\ndisqus:\n enable: true\n shortname: tian-ya-de-zhi-fu\n count: true\n```\n\n更详细请参阅网上。\n\n\n\n## 新文章命名规则\n\n发表新文章后系统崩溃。\n\n在根目录的配置文件中找到类似的:\n\n```\n# Writing\nnew_post_name: 新文章.md # File name of new posts\ndefault_layout: post\n...\n```\n\n将其改为由时间和题目组成:\n\n```\n# Writing\nnew_post_name: year-:month-:day-:title.md # File name of new posts\ndefault_layout: post\n...\n```\n\n\n\n# 进阶设置\n\n## 显示\n\n### 首页文章显示预览\n\n默认设定下。首页的文章每一篇都显示全文,不方便浏览。需要到主题的配置文件里将`auto_excerpt` 的 `enable` 改为 `true`。而`length` 字节表示文章预览的长度。\n\n```\n# Automatically Excerpt. Not recommand.\nauto_excerpt:\n\tenable: true\n\tlength: 300\n```\n\n### 永久链接\n\n新文章的名字采用了中文([见上](#id_new_post_name)),中文出现在地址栏上不美观。也不利于SEO,以及增加了博文URL的层数。解决办法是给每篇文章制定链接地址。\n\n1. 修改网站的配置文件中永久地址的设定:\n\n```ini\npermalink: :urlname.html\n```\n\n2. 给每篇文章指定 `urlname`\n\n```ini\ntitle: 《少有人走的路》笔记\ndate: 2019-07-21 00:14:37\nurlname: road-less-traveled-summary\ntags:\n - 心理学\ncategories: 读书笔记\n```\n\n编译后新的地址为 `http://mywiki.test/road-less-traveled-summary.html`。看起来就清爽多了。\n\n### 图片链接\n\n1. 开通[资源文件夹](https://hexo.io/zh-cn/docs/asset-folders),创建新文章的时候会自动建立一个与文章同名的文件夹。可以将图片或者其它资源文件放到里面(*打算将思维导图放到这里*)。因为自定义了[文件名的方式](#id_new_post_name),所以根据官方描述无效。\n2. 安装第三方插件`hexo-asset-image`\n\n```bash\nnpm install hexo-asset-image --save\n```\n\n在文章中图片的链,可以省略路径,直接引用图片名:\n\n```markdown\n![mypicture](mypicture.jpg)\n```\n\n3. 修改插件代码\n\n我在使用永久链接的时候在每篇文章的实际地址都加上了`.html`。文章的地址显示如下\n\n```http\nhttp://mywebsite.com/my-articel-url.html\n```\n\n而插件生成的图片地址如下:\n\n```\nhttp://mywebsite.com/my-articel-url.htm/mypicture.jpg\n```\n\n多出了 `.htm` 这几个字符,而实际图片的地址应该是:\n\n```http\nhttp://mywebsite.com/my-articel-url/mypicture.jpg\n```\n\n找到 `node_modules/hexo-asset-imge` 目录下的 `index.js` 文件,将以下代码中的 `1` 改成 `5`,就可以正常显示图片了。\n\n```javascript\nvar endPos = link.length - 1\n```\n\n考虑到将来项目膨胀,应该将图片放到图床,比如七牛。\n\n### 站内链接\n\n导航到站内别的文章使用以下方式就可以。\n\n链接方式 `[文章名](urlname.html)`\n\n\n\n### 设定代码区的高度\n\nHexo自身的式样暂时还没找到。其实也不太需要。如果代码不长直接显示全部就好了。太长的话不如放到$Gits$,通过限制gist的高度实现。**Net**主题修改 `next/themes/next/source/css/_custom/custom.styl` ,Wikitten主题则在文件 `wikitten/themes/Wikitten/source/css/_partial/article.styl` 中修改。\n\n```CSS\n.gist \n.gist-file\n.gist-data {\n max-height: 450px;\n}\n```\n\n\n\n### 添加注脚支持\n\n[插件项目](https://github.com/LouisBarranqueiro/hexo-footnotes)\n\n1. 安装插件 `npm install hexo-footnotes --save`\n2. **项目配置文件** 添加\n\n```ini\n# 注意第二行的前面没有 \"-\" 符号,官方说明有. 但是会导致无法编译.\nplugins:\n hexo-footnotes\n```\n\n\n\n### 更换Markdown渲染\n\n[Markdown-it-plus](https://github.com/CHENXCHEN/hexo-renderer-markdown-it-plus)\n\n如果更换了这个渲染,就无需上面那个注脚插件, 因为已经支持了. 首先卸载掉旧的渲染, 然后安装新的.\n\n```sh\nnpm un hexo-renderer-marked --save\nnpm i hexo-renderer-markdown-it-plus --save\n# 查看是否已经安装\nnpm ls hexo-renderer-markdown-it-plus\n```\n\n然后在项目配置文件, 添加下面文字. 更深入的设置, 参看 markdown-it-plus 项目的说明文档.\n\n```ini\nmarkdown_it_plus:\n highlight: true\n html: true\n xhtmlOut: true\n breaks: true\n langPrefix:\n linkify: true\n typographer:\n quotes: “”‘’\n plugins:\n```\n\n\n\n## 辅助功能\n\n### 本地运行服务\n\n在Mac中可以用本地服务[Pow](http://pow.cx)运行网站,不用每次更改重启服务器`hexo s`。\n\n1. 安装Pow\n\n```bash\n$ curl get.pow.cx | sh\n```\n\n2. 建立项目链接,`myapp` 是项目的名字。比如真实路径`~/Project/mywiki`\n\n```bash\n$ cd ~/.pow\n$ ln -s /path/to/myapp\n```\n\n3. 执行完以上步骤后在浏览器打开链接 ``http://myapp.test/`` 就能看到网站。更改内容后要执行==生成== 命令才能看到更新`hexo generate` or `hexo g` 。\n4. 不想运行,直接把项目文件夹删除就可以。\n\n### 绑定个人域名\n\n1. 在万网买一个顶级域名,开通后添加两个域名解释\n\n```ini\n#记录名 主机记录 记录值\nCNAME www username.github.io\nCNAME @ username.github.io\n```\n\n2. 在项目的根目录添加一个名为 `CNAME` 的文件,然后填入万网注册的域名, 这里是 `goldentianya.pub` 。第一次我是手动添加的。添加后进入 repository 的 setting, 往下混动到 Custom domain ,可以看到系统已经自动把用户域名加进去了。\n3. 将来不希望用这个域名,域名重定向后,在浏览器输入 username.github.io 后 Chrome 会一直转向 goldentianya.pub 。需要打开`开发者工具`,选中 `disable cache` ,再刷新一遍地址就好了。\n4. `next` 项目要将 `CNAME` 文件复制到 `/themes/next/source` 目录下个,编译的时候会拷贝到 `public` 目录。`wikitten` 项目不需要,域名定向以后能找到 `goldentianya/wiki` 站点,十分神奇。\n\n### 隐藏文章\n\n#### 全隐藏\n\n根据插件`hext-sage-posts` 作者的博文[^9]中描述,安装插件\n\n```bash\nnpm install hexo-sage-posts --save\n```\n\n并将初创时的`Hello-world.md` 文章的Metadata中加入`sage: true`,文章就从网站上消失了。但在别的文章下面导航栏中,通过“下一篇”或者“上一篇”还是能被找到。被隐藏的文章其地址仍旧没有改变,只是不不出现在首页导航,和分类中而已。\n\n#### 从首页隐藏\n\n为了不让太琐碎的文章充斥首页,但又可以在分类中找到。可以采用这种方式。\n\n1. 在文章的Metadata部分添加关键字 `notshow: true`。\n2. 找到 `Hexo\\themes\\next\\layout\\index.swig` 文件中以下部分:\n\n```html\n{% block content %}\n
\n {% for post in page.posts %}\n {{ post_template.render(post, true) }} \n {% endfor %}\n
\n\n {% include '_partials/pagination.swig' %}\n{% endblock %}\n```\n\n将以上代码第四行修改为\n\n```html\n{% if post.notshow != true %}\n\t{{ post_template.render(post, true) }}\n{% endif %}\n```\n\n\n\n#### 文章加密\n\n1. 安装插件 `hexo-blog-encrypt`\n\n```\nnpm install --save hexo-blog-encrypt\n```\n\n并在**站点配置**文件中启用该插件:\n\n```json\nencrypt:\n enable: true\n```\n\n2. 然后在文章的头部添加上对应的字段\n\n```ini\n---\ntitle: 文章加密\ndate: 2019-01-04T22:20:13.000Z\ncategory: 教程\ntags:\n - 博客\n - Hexo\nkeywords: 博客文章密码\npassword: TloveY\nabstract: 此文章含有敏感内容。\nmessage: 输入密码,查看文章\n---\n```\n\n- password: 是该博客加密使用的密码\n\n- abstract: 是该博客的摘要,会显示在博客的列表页\n\n- message: 这个是博客查看时,密码输入框上面的描述性文字\n\n\n\n### Hexo Admin\n\n安装后台管理插件 `hexo-damin`\n\n```bash\nnpm install --save hexo-admin\nhexo server -d\nopen http://localhost:4000/admin/\n```\n\n初次运行后,设置管理账户。\n\n```\nadmin:\n username: maiernte\n password_hash: $2a$10$QeeWfDwIxbJ94h8EDfplDe9aLB0uaNrjMeVGhaYnfF0BBDosDze0S\n secret: NamoAmitabha!\n```\n\n### 访问量统计\n\n[介绍文章](https://bjtu-hxs.github.io/2018/06/12/leancloud-config/) (*有图*)\n\n[原文(有代码)](https://notes.doublemine.me/2015-10-21-%E4%B8%BANexT%E4%B8%BB%E9%A2%98%E6%B7%BB%E5%8A%A0%E6%96%87%E7%AB%A0%E9%98%85%E8%AF%BB%E9%87%8F%E7%BB%9F%E8%AE%A1%E5%8A%9F%E8%83%BD.html#%E9%85%8D%E7%BD%AELeanCloud)\n\n1. 第一步, 到Lean Cloud增添一个应用,并创建类似Counter 的类。设置成 $ 所有人可读可写 $\n2. 在安全中心添加 **Web 安全域名**, 添加Blog域名,防止有人Hack我们的数据库。\n\n3. 按上面的文章修改 Hexo 以及主题配置。\n\n\n\n### 在线交流\n\n使用 [道客](https://www.daovoice.io/) Daovoice\n\n接入方式\n\n1. 将下面代码粘贴在页面的 之前。\n\n```\n\n```\n\n2. 调用下面的 JavaScript 与注册用户沟通\n\n```\ndaovoice('init', {\n app_id: \"5e5fa370\",\n user_id: \"NO_89757\", // 必填: 该用户在您系统上的唯一ID\n email: \"daovoice@example.com\", // 选填: 该用户在您系统上的主邮箱\n name: \"道客船长\", // 选填: 用户名\n signed_up: 1449821660 // 选填: 用户的注册时间,用Unix时间戳表示\n});\ndaovoice('update');\n```\n\n3. 调用下面的 JavaScript 与匿名访客沟通\n\n```\ndaovoice('init', {\n app_id: \"5e5fa370\"\n});\ndaovoice('update');\n```\n\n完成代码粘贴后,检测是否成功接入: Ping 一下\n\n\n\n### 待解决问题\n\n- [x] 文章评论\n- [x] 在线编辑?\n- [x] 使用七牛图床\n- [ ] 脑图摆放 ([官方文档/数据文件](https://hexo.io/zh-cn/docs/data-files))\n- [x] 文件下载(可能还是要靠七牛)\n- [x] 用submodule管理主题 [在 hexo 中使用 git submodules 管理主题](https://juejin.im/post/5c2e22fcf265da615d72c596)\n- [ ] SEO\n- [ ] 访问量统计\n- [ ] 加速 [Github Pages + CDN全站加速](https://www.jianshu.com/p/ccc0cc8c14a0)\n\n- [ ] [在vps上部署hexo博客的那些事](https://segmentfault.com/a/1190000019104144)\n\n# 有趣插件\n\n- [x] [短地址 & 指定摘要](https://www.jianshu.com/p/805bd0b65d98) \n\n- [ ] [农历/很好的学习做插件的例子](https://github.com/inchei/hexo-lunar-calendar)\n\n- [ ] [插入pdf](https://github.com/superalsrk/hexo-pdf/) 可以学习如何插入epub\n\n- [ ] [hexo-include](https://github.com/pirtleshell/hexo-include) 加载文本内容, html, js, text\n\n- [x] [Hexo-NexT给文章添加结束语](https://wangc1993.github.io/2019/01/10/6/)\n\n- [x] [Hexo-NexT接入网页在线联系功能](https://wangc1993.github.io/2019/01/10/5/)\n\n- [ ] [include markdown](https://github.com/tea3/hexo-include-markdown)\n\n\n\n### ---\n\n\n\n[^1]: [Hexo博客搭建全攻略(一):基于Hexo+Github环境搭建](https://blog.annieyu.com/posts/207737771.html)\n[^2]: [Hexo博客搭建全攻略(二):NexT主题配置](https://blog.annieyu.com/posts/976961586.html)\n[^3]: [Hexo博客搭建全攻略(三):三方服务集成](https://blog.annieyu.com/posts/1209152972.html)\n[^4]: [Hexo博客搭建全攻略(四):高级应用](https://blog.annieyu.com/posts/3333782006.html)\n[^5]: [Hexo博客搭建全攻略(五):基于Github Issue搭建评论系统](https://blog.annieyu.com/posts/a341668e.html)\n[^6]: [Hexo博客搭建全攻略(六):博文图片处理](https://www.jianshu.com/p/2bb87ae49ff6)\n[^7]: [十步之内轻松搞定 Hexo + GitHub搭建个人博客](https://gavinlee1.github.io/2017/02/25/%E5%8D%81%E6%AD%A5%E4%B9%8B%E5%86%85%E8%BD%BB%E6%9D%BE%E6%90%9E%E5%AE%9A-Hexo-GitHub%E6%90%AD%E5%BB%BA%E4%B8%AA%E4%BA%BA%E5%8D%9A%E5%AE%A2/) ​​\n[^8]: [如何优雅的 隐藏博客](https://vanchchen.github.io/p/7587.html)\n[^9]: [为 Hexo 博客添加隐藏文章 / 限定公开功能](https://blessing.studio/hexo-plugin-to-make-posts-sage-unlisted/)\n[^10]: [Hexo 中文文档](https://hexo.io/zh-cn/docs/index.html)\n\n[multipages]: ttp://chitanda.me/2015/11/03/multiple-git-pages-in-one-github-account/\n\n[讲解详细的博客](https://binglumeng.github.io/2017/03/21/Hexo学习笔记/) \n\n[这个也不错](http://yearito.cn/posts/hexo-advanced-settings.html)\n\n\n","source":"_posts/IT/Web/搭建Hexo博客的流水账.md","raw":"---\ntitle: 搭建Hexo博客的流水账\ndate: 2019-07-25 05:49:15\nurlname: how-build-my-hexo-blog\ntoc: true\ntags: [Hexo]\ncategories: [IT, Web]\nnotshow: false\n\n---\n\n\n\n建网过程中的一些流水账。以备将来查询。\n\n\n\n# 建立网站\n\n## Github配置\n\n输入命令 `ssh-keygen -t rsa -b 4096 -C \"myname@gmail.com\"`。\n\n\n\n密码 `T1`。(下列展开后复制)\n\n> 将文件 ~/.ssh/id_rsa.pub 中的内容复制到 Github 的SSH-Key 内就可以了。(备份文件已上传百度网盘)\n\n3. 在Github上新建SSH-Key名称为`gmail`\n\n[具体步骤参阅此文章](https://gavinlee1.github.io/2017/02/25/十步之内轻松搞定-Hexo-GitHub搭建个人博客/)\n\n```\nssh-keygen -t rsa -b 4096 -C \"username@gmail.com\"\n[Enter]\n[password T..1]\n\neval \"$(ssh-agent -s)\"\nssh-add -K ~/.ssh/id_rsa\n\ncd ~\ncd .ssh\nls\nvim id_rsa.pub\n(然后复制钥匙串)\n```\n4. 测试公匙\n\n```\n$ ssh -T git@github.com\n\nHi username! You've successfully authenticated, but GitHub does not provide shell access.\n```\n\n## 安装Hexo\n\n参考资料[^1] [^7]。\n1. 安装node.js 因为以前已经安装过,所以跳过。\n2. 安装 Hexo `$ npm install hexo-cli -g` \n3. 创建网站\n```command\nmkdir mywiki\ncd mywiki\nhexo init\nnpm install\n```\n4. 生成静态页面 `hexo g` or `hexo generate`\n5. 启动本地网站服务 `hexo s` or `hexo server`\n> 网站一般会运行在 http://localhost:4000/\n> Press Ctrl+C to stop.\n\n6. 用pow做服务本地运行\n\n**Install**\n\n```\n$ curl get.pow.cx | sh\n```\n\n**Setup**\n\nSymlink the folder into `~/.pow`\n\n```\n$ cd ~/.pow\n$ ln -s /path/to/test\n```\n\n## 发布到Github\n\n终于搭建好站点部署环境啦,那么要怎么样将我们本地生成预览好的页面发布到github上呢?很简单,Follow!\n\n首先,打开blog目录下的`_config.yml`,找到deploy段,配置成这样\n\n> deploy:\n> type: git\n> repository: git@github.com:yourname/yourname.github.io.git\n> branch: master\n\n注意将代码里面的yourname换成你账号的username。\n\n设置git身份信息\n\n> git config --global user.name \"你的用户名\"\n> git config --global user.email \"你的邮箱\" \n\n执行以下指令进行部署\n\n`hexo d -g `\n\n如果提示没找到git,请先执行以下指令\n\n`cnpm install hexo-deployer-git --save` \n\n再次部署后,浏览器打开 [https://yourname.github.io](https://yourname.github.io/) 就可以看到刚才本地预览页面。\n\n## 网站基本配置\n\n### Next 主题\n\n主题配置文件说明\n\n{% fold 点击显/隐内容 %}\n\n```ini\n# Hexo 站点配置文件\n## Docs: https://hexo.io/docs/configuration.html\n## Source: https://github.com/hexojs/hexo/\n\n# 网站配置\ntitle: Hexo # 网站标题\nsubtitle: # 网站副标题\ndescription: # 网站描述\nauthor: John Doe # 你的昵称\nlanguage: # 网站使用的语言(英文:en, 简体中文:zh-Hans,繁体中文:zh-tw)\ntimezone: # 网站时区,用于生成页面时填充相关时间,默认使用电脑时区,一般不用改\n\n# URL\n## 如果你的站点要放入子目录, 请将url设置为'http://yoursite.com/child' 并将根目录设置为'/child/'\nurl: http://yoursite.com # 站点网址\nroot: / # 网站根目录\npermalink: :year/:month/:day/:title/ #文单的永久链接格式\npermalink_defaults: # 永久链接中各部分的默认值\n\n# 目录\nsource_dir: source # 资源文件夹,这个文件夹用来存放博客内容\npublic_dir: public # 公共文件夹,这个文件夹用来存放生成的站点静态文件\ntag_dir: tags # 标签文件夹\narchive_dir: archives # 归档文件夹\ncategory_dir: categories # 分类文件夹\ncode_dir: downloads/code # Include code文件夹\ni18n_dir: :lang # 国际化文件夹,存放各种语言定义\nskip_render: # 跳过指定文件的渲染\n\n# 写作\nnew_post_name: :title.md # 新文章的文件名称\ndefault_layout: post # 预设布局\ntitlecase: false # 把标题转换为 title case\nexternal_link: true # 在新标签中打开链接\nfilename_case: 0 # 把文件名称转换为 (1) 小写或 (2) 大写\nrender_drafts: false # 显示草稿\npost_asset_folder: false # 启动 Asset 文件夹\nrelative_link: false # 把链接改为与根目录的相对位址\nfuture: true # 显示未来的文章\nhighlight: # 代码块的设置\n enable: true\n line_number: true\n auto_detect: false\n tab_replace:\n\n# 分类 & 标签\ndefault_category: uncategorized # 默认分类\ncategory_map: # 分类别名\ntag_map: # 标签别名\n\n# 日期 / 时间格式\n## Hexo 使用 Moment.js 来解析和显示时间\n## http://momentjs.com/docs/#/displaying/format/\ndate_format: YYYY-MM-DD # 日期格式\ntime_format: HH:mm:ss # 时间格式\n\n# 分页\n## 每页显示的文章量 (0 = 关闭分页功能)\nper_page: 10\npagination_dir: page\n\n# 扩展\n## Plugins: https://hexo.io/plugins/\n## Themes: https://hexo.io/themes/\ntheme: landscape # 主题\n\n# 部署\n## Docs: https://hexo.io/docs/deployment.html\ndeploy:\n type:\n```\n\n{% endfold %}\n\n### Wikitten主题\n\n具体配置参考[开发者说明](https://github.com/zthxxx/hexo-theme-Wikitten/blob/master/README_zh-CN.md),更详细的描述参阅[hexo-theme-icarus](https://github.com/ppoffice/hexo-theme-icarus/wiki)。为了与主题Next不冲突,作以下修改。\n\n1. 自行修改 `tags`, `about`,`categories` 等`index.md`,而不能从主题复制,覆盖站点原有设置。\n2. `languages\\zh-CN.yml` 重命名为 `zh-Hans.yml`\n3. `_config.yml` 菜单作以下更改\n\n```ini\nmenu:\n 首页: /\n 归档: /archives/\n 分类: /categories/\n 标签: /tags/\n 关于: /about/\n```\n\n4. `thumbnail: true` 使得每个post在快速列表里,显示图标。但就是每个帖子都要设定,很麻烦。\n5. post 中的 toc 要设置为 true,如果需要显示目录的话。\n\n### 同时部署两个项目\n\n第一个项目使用 Github 上面默认的 Github Pages,即 `username.github.io` 。在站点配置文件中如下:\n\n```\nurl: http://username.github.io\nroot: /\n...\n...\ndeploy:\n type: git\n repository: git@github.com:username/username.github.io.git\n branch: master\n\n```\n\n\n第二个站点开通一个 普通的repository,添加名为`gh-pages` 的Branch,并将gh-pages` 设为默认Branch。我将第二个仓库命名为 wiki ,那第二个站点就运行在 `https://username.github.io/wiki`次级目录下面。\n\n站点配置文件更改如下:\n\n```\nurl: http://username.github.io/wiki\nroot: /wiki/\n...\n...\ndeploy:\n type: git\n repository: git@github.com:username/wiki.git\n branch: gh-pages\n```\n\n同样用 `hexo d -g` 部署命令发布,两个站点就都运行起来了。\n\n为了使得两个项目使用同一个笔记资源,将站点中的 source 文件夹移到项目意外,将配置文件里的 `source_dir: source` 改为 `source_dir: ../source`(这里使用了相对目录)。\n\n[参考文章][multipages] (细节已经失效,但思路值得参考)\n\n### 站内搜索\n\n1. 安装插件\n\n```shell\nnpm install hexo-generator-search --save\nnpm install hexo-generator-searchdb --save\n```\n\n2. 配置hexo站点主配置文件``_config.yml``, 添加\n\n```ini\nsearch:\n path: search.xml\n field: post\n format: html\n limit: 10000\n```\n\n3. 修改next主题配置文件`_config.yml`,启用 `local_search`\n\n```ini\nlocal_search:\n\tenable: true\n\ttrigger: auto\n\ttop_n_per_article: 1\n```\n\n4. 生成`search.xml`文件以及发布\n\n```shell\nhexo g\nhexo d -g # 本地运行 hexo s\n```\n\n### 去除主题字样\n\n关于添加头像、标签、分类、「关于」等具体的修改,跟着参考资料[^2]里面的步骤做就好了。最后说说如何去掉底部强力驱动及主题字样。\n\n1. 找到 `\\themes\\next\\layout_partials\\`下面的`footer.swig`文件,打开:\n\n```html\n
\n {{ __('footer.powered', 'Hexo') }}\n
\n
\n {{ __('footer.theme') }} -\n \n NexT.{{ theme.scheme }}\n \n
\n```\n\n第一条是“由Hexo驱动” 的Hexo链接,把xml段删除,只留两个单引号''。\n\n第二条是“主题-Next.XX”,将xml段都删掉,不留引号。\n\n```html\n
\n {{ __('footer.powered', '') }}\n
\n
\n {{ __('footer.theme') }}\n
\n```\n\n2. 找到这个地方`\\themes\\next\\languages\\ `下面的语言文件`zh-Hans.yml`(以中文为例):\n\n```ini\nfooter:\n powered: \"由 %s 强力驱动\"\n theme: 主题\n```\n\n将上面的文字改成自己想要的即可。\n\n## 添加评论功能\n\n#### Gitment\n\n**此项目已经终止!**改为Disqus,以及其它评论服务。\n\n1. 安装功能模块。在项目的根目录:\n\n```shell\nnpm i --save gitment\n```\n\n2. 在Github申请应用。`settings -> Developer Settings -> OAuth Apps`\n\n```ini\nApplication name:随便写\nHomepage URL:这个也可以随意写,就写你的博客地址就行\nApplication description:描述,也可以随意写\nAuthorization callback URL:这个必须写你的博客地址\n```\n\n申请好之后点注册,然后就可以看到两个东西`ClientID`和`Client Secret`,后面会用到。\n\n3. 配置Gitment,打开`themes/next/_config.yml`:\n\n```javascript\n# Gitment\n# Introduction: https://imsun.net/posts/gitment-introduction/\ngitment:\n enable: true\n mint: true # RECOMMEND, A mint on Gitment, to support count, language and proxy_gateway\n count: true # Show comments count in post meta area\n lazy: false # Comments lazy loading with a button\n cleanly: false # Hide 'Powered by ...' on footer, and more\n language: # Force language, or auto switch by theme\n github_user: {you github user id}\n github_repo: 随便写一个你的公开的git仓库就行,到时候评论会作为那个项目的issue\n client_id: {刚才申请的ClientID}\n client_secret: {刚才申请的Client Secret}\n proxy_gateway: # Address of api proxy, See: https://github.com/aimingoo/intersect\n redirect_protocol: # Protocol of redirect_uri with force_redirect_protocol when mint enabled\n```\n\n注意到这里基本上已经OK了,再看你的博客应该可以显示评论了.不过每篇博客都需要你手动初始化评论功能(如果你的历史博客很多那就一篇一篇去点吧,不过貌似有人写了批量处理脚本,没试过哈).\n\n而由于 github 中 `Issues` 的 `label` 长度限制为最大 `50` 个字符,当 文章标题长度过长时,该label就会生成失败,而导致初始化错误,弹出 `Validation Failed` 的提示。\n\n通过网上的搜索,发现可以使用文章创建时的时间来代替文章标题,作为这个唯一的label标签。\n\n找到giment的配置:`/themes/next/layout/_third-party/comments/gitment.swig` 文件, 并找到如下部分:\n\n```javascript\nvar gitment = new {{CommentsClass}}({\n id: window.location.pathname,\n owner: '{{ theme.gitment.github_user }}',\n repo: '{{ theme.gitment.github_repo }}',\n ...\n```\n\n将`id`后面的路径值修改为 'itfanr\\_blog\\_\\{{ date(page.date, \"YYYYMMDDhhmmss\") \\}}' 就可以了。\n\n#### Disqus\n\n目前只开通[Disqus](https://disqus.com/)的评论。\n\n1. 开通Disqus账号,并添加一个点 应用。具体步骤参看[Hexo搭建博客系列:(六)Hexo添加Disqus评论](https://www.jianshu.com/p/d68de067ea74)。\n2. 在`主题配置文件`(_config.yml)文件中找到以下代码,添加你Disqus设置的Website Name在shortname。\n\n```json\n# Disqus\ndisqus:\n enable: true\n shortname: tian-ya-de-zhi-fu\n count: true\n```\n\n更详细请参阅网上。\n\n\n\n## 新文章命名规则\n\n发表新文章后系统崩溃。\n\n在根目录的配置文件中找到类似的:\n\n```\n# Writing\nnew_post_name: 新文章.md # File name of new posts\ndefault_layout: post\n...\n```\n\n将其改为由时间和题目组成:\n\n```\n# Writing\nnew_post_name: year-:month-:day-:title.md # File name of new posts\ndefault_layout: post\n...\n```\n\n\n\n# 进阶设置\n\n## 显示\n\n### 首页文章显示预览\n\n默认设定下。首页的文章每一篇都显示全文,不方便浏览。需要到主题的配置文件里将`auto_excerpt` 的 `enable` 改为 `true`。而`length` 字节表示文章预览的长度。\n\n```\n# Automatically Excerpt. Not recommand.\nauto_excerpt:\n\tenable: true\n\tlength: 300\n```\n\n### 永久链接\n\n新文章的名字采用了中文([见上](#id_new_post_name)),中文出现在地址栏上不美观。也不利于SEO,以及增加了博文URL的层数。解决办法是给每篇文章制定链接地址。\n\n1. 修改网站的配置文件中永久地址的设定:\n\n```ini\npermalink: :urlname.html\n```\n\n2. 给每篇文章指定 `urlname`\n\n```ini\ntitle: 《少有人走的路》笔记\ndate: 2019-07-21 00:14:37\nurlname: road-less-traveled-summary\ntags:\n - 心理学\ncategories: 读书笔记\n```\n\n编译后新的地址为 `http://mywiki.test/road-less-traveled-summary.html`。看起来就清爽多了。\n\n### 图片链接\n\n1. 开通[资源文件夹](https://hexo.io/zh-cn/docs/asset-folders),创建新文章的时候会自动建立一个与文章同名的文件夹。可以将图片或者其它资源文件放到里面(*打算将思维导图放到这里*)。因为自定义了[文件名的方式](#id_new_post_name),所以根据官方描述无效。\n2. 安装第三方插件`hexo-asset-image`\n\n```bash\nnpm install hexo-asset-image --save\n```\n\n在文章中图片的链,可以省略路径,直接引用图片名:\n\n```markdown\n![mypicture](mypicture.jpg)\n```\n\n3. 修改插件代码\n\n我在使用永久链接的时候在每篇文章的实际地址都加上了`.html`。文章的地址显示如下\n\n```http\nhttp://mywebsite.com/my-articel-url.html\n```\n\n而插件生成的图片地址如下:\n\n```\nhttp://mywebsite.com/my-articel-url.htm/mypicture.jpg\n```\n\n多出了 `.htm` 这几个字符,而实际图片的地址应该是:\n\n```http\nhttp://mywebsite.com/my-articel-url/mypicture.jpg\n```\n\n找到 `node_modules/hexo-asset-imge` 目录下的 `index.js` 文件,将以下代码中的 `1` 改成 `5`,就可以正常显示图片了。\n\n```javascript\nvar endPos = link.length - 1\n```\n\n考虑到将来项目膨胀,应该将图片放到图床,比如七牛。\n\n### 站内链接\n\n导航到站内别的文章使用以下方式就可以。\n\n链接方式 `[文章名](urlname.html)`\n\n\n\n### 设定代码区的高度\n\nHexo自身的式样暂时还没找到。其实也不太需要。如果代码不长直接显示全部就好了。太长的话不如放到$Gits$,通过限制gist的高度实现。**Net**主题修改 `next/themes/next/source/css/_custom/custom.styl` ,Wikitten主题则在文件 `wikitten/themes/Wikitten/source/css/_partial/article.styl` 中修改。\n\n```CSS\n.gist \n.gist-file\n.gist-data {\n max-height: 450px;\n}\n```\n\n\n\n### 添加注脚支持\n\n[插件项目](https://github.com/LouisBarranqueiro/hexo-footnotes)\n\n1. 安装插件 `npm install hexo-footnotes --save`\n2. **项目配置文件** 添加\n\n```ini\n# 注意第二行的前面没有 \"-\" 符号,官方说明有. 但是会导致无法编译.\nplugins:\n hexo-footnotes\n```\n\n\n\n### 更换Markdown渲染\n\n[Markdown-it-plus](https://github.com/CHENXCHEN/hexo-renderer-markdown-it-plus)\n\n如果更换了这个渲染,就无需上面那个注脚插件, 因为已经支持了. 首先卸载掉旧的渲染, 然后安装新的.\n\n```sh\nnpm un hexo-renderer-marked --save\nnpm i hexo-renderer-markdown-it-plus --save\n# 查看是否已经安装\nnpm ls hexo-renderer-markdown-it-plus\n```\n\n然后在项目配置文件, 添加下面文字. 更深入的设置, 参看 markdown-it-plus 项目的说明文档.\n\n```ini\nmarkdown_it_plus:\n highlight: true\n html: true\n xhtmlOut: true\n breaks: true\n langPrefix:\n linkify: true\n typographer:\n quotes: “”‘’\n plugins:\n```\n\n\n\n## 辅助功能\n\n### 本地运行服务\n\n在Mac中可以用本地服务[Pow](http://pow.cx)运行网站,不用每次更改重启服务器`hexo s`。\n\n1. 安装Pow\n\n```bash\n$ curl get.pow.cx | sh\n```\n\n2. 建立项目链接,`myapp` 是项目的名字。比如真实路径`~/Project/mywiki`\n\n```bash\n$ cd ~/.pow\n$ ln -s /path/to/myapp\n```\n\n3. 执行完以上步骤后在浏览器打开链接 ``http://myapp.test/`` 就能看到网站。更改内容后要执行==生成== 命令才能看到更新`hexo generate` or `hexo g` 。\n4. 不想运行,直接把项目文件夹删除就可以。\n\n### 绑定个人域名\n\n1. 在万网买一个顶级域名,开通后添加两个域名解释\n\n```ini\n#记录名 主机记录 记录值\nCNAME www username.github.io\nCNAME @ username.github.io\n```\n\n2. 在项目的根目录添加一个名为 `CNAME` 的文件,然后填入万网注册的域名, 这里是 `goldentianya.pub` 。第一次我是手动添加的。添加后进入 repository 的 setting, 往下混动到 Custom domain ,可以看到系统已经自动把用户域名加进去了。\n3. 将来不希望用这个域名,域名重定向后,在浏览器输入 username.github.io 后 Chrome 会一直转向 goldentianya.pub 。需要打开`开发者工具`,选中 `disable cache` ,再刷新一遍地址就好了。\n4. `next` 项目要将 `CNAME` 文件复制到 `/themes/next/source` 目录下个,编译的时候会拷贝到 `public` 目录。`wikitten` 项目不需要,域名定向以后能找到 `goldentianya/wiki` 站点,十分神奇。\n\n### 隐藏文章\n\n#### 全隐藏\n\n根据插件`hext-sage-posts` 作者的博文[^9]中描述,安装插件\n\n```bash\nnpm install hexo-sage-posts --save\n```\n\n并将初创时的`Hello-world.md` 文章的Metadata中加入`sage: true`,文章就从网站上消失了。但在别的文章下面导航栏中,通过“下一篇”或者“上一篇”还是能被找到。被隐藏的文章其地址仍旧没有改变,只是不不出现在首页导航,和分类中而已。\n\n#### 从首页隐藏\n\n为了不让太琐碎的文章充斥首页,但又可以在分类中找到。可以采用这种方式。\n\n1. 在文章的Metadata部分添加关键字 `notshow: true`。\n2. 找到 `Hexo\\themes\\next\\layout\\index.swig` 文件中以下部分:\n\n```html\n{% block content %}\n
\n {% for post in page.posts %}\n {{ post_template.render(post, true) }} \n {% endfor %}\n
\n\n {% include '_partials/pagination.swig' %}\n{% endblock %}\n```\n\n将以上代码第四行修改为\n\n```html\n{% if post.notshow != true %}\n\t{{ post_template.render(post, true) }}\n{% endif %}\n```\n\n\n\n#### 文章加密\n\n1. 安装插件 `hexo-blog-encrypt`\n\n```\nnpm install --save hexo-blog-encrypt\n```\n\n并在**站点配置**文件中启用该插件:\n\n```json\nencrypt:\n enable: true\n```\n\n2. 然后在文章的头部添加上对应的字段\n\n```ini\n---\ntitle: 文章加密\ndate: 2019-01-04T22:20:13.000Z\ncategory: 教程\ntags:\n - 博客\n - Hexo\nkeywords: 博客文章密码\npassword: TloveY\nabstract: 此文章含有敏感内容。\nmessage: 输入密码,查看文章\n---\n```\n\n- password: 是该博客加密使用的密码\n\n- abstract: 是该博客的摘要,会显示在博客的列表页\n\n- message: 这个是博客查看时,密码输入框上面的描述性文字\n\n\n\n### Hexo Admin\n\n安装后台管理插件 `hexo-damin`\n\n```bash\nnpm install --save hexo-admin\nhexo server -d\nopen http://localhost:4000/admin/\n```\n\n初次运行后,设置管理账户。\n\n```\nadmin:\n username: maiernte\n password_hash: $2a$10$QeeWfDwIxbJ94h8EDfplDe9aLB0uaNrjMeVGhaYnfF0BBDosDze0S\n secret: NamoAmitabha!\n```\n\n### 访问量统计\n\n[介绍文章](https://bjtu-hxs.github.io/2018/06/12/leancloud-config/) (*有图*)\n\n[原文(有代码)](https://notes.doublemine.me/2015-10-21-%E4%B8%BANexT%E4%B8%BB%E9%A2%98%E6%B7%BB%E5%8A%A0%E6%96%87%E7%AB%A0%E9%98%85%E8%AF%BB%E9%87%8F%E7%BB%9F%E8%AE%A1%E5%8A%9F%E8%83%BD.html#%E9%85%8D%E7%BD%AELeanCloud)\n\n1. 第一步, 到Lean Cloud增添一个应用,并创建类似Counter 的类。设置成 $ 所有人可读可写 $\n2. 在安全中心添加 **Web 安全域名**, 添加Blog域名,防止有人Hack我们的数据库。\n\n3. 按上面的文章修改 Hexo 以及主题配置。\n\n\n\n### 在线交流\n\n使用 [道客](https://www.daovoice.io/) Daovoice\n\n接入方式\n\n1. 将下面代码粘贴在页面的 之前。\n\n```\n\n```\n\n2. 调用下面的 JavaScript 与注册用户沟通\n\n```\ndaovoice('init', {\n app_id: \"5e5fa370\",\n user_id: \"NO_89757\", // 必填: 该用户在您系统上的唯一ID\n email: \"daovoice@example.com\", // 选填: 该用户在您系统上的主邮箱\n name: \"道客船长\", // 选填: 用户名\n signed_up: 1449821660 // 选填: 用户的注册时间,用Unix时间戳表示\n});\ndaovoice('update');\n```\n\n3. 调用下面的 JavaScript 与匿名访客沟通\n\n```\ndaovoice('init', {\n app_id: \"5e5fa370\"\n});\ndaovoice('update');\n```\n\n完成代码粘贴后,检测是否成功接入: Ping 一下\n\n\n\n### 待解决问题\n\n- [x] 文章评论\n- [x] 在线编辑?\n- [x] 使用七牛图床\n- [ ] 脑图摆放 ([官方文档/数据文件](https://hexo.io/zh-cn/docs/data-files))\n- [x] 文件下载(可能还是要靠七牛)\n- [x] 用submodule管理主题 [在 hexo 中使用 git submodules 管理主题](https://juejin.im/post/5c2e22fcf265da615d72c596)\n- [ ] SEO\n- [ ] 访问量统计\n- [ ] 加速 [Github Pages + CDN全站加速](https://www.jianshu.com/p/ccc0cc8c14a0)\n\n- [ ] [在vps上部署hexo博客的那些事](https://segmentfault.com/a/1190000019104144)\n\n# 有趣插件\n\n- [x] [短地址 & 指定摘要](https://www.jianshu.com/p/805bd0b65d98) \n\n- [ ] [农历/很好的学习做插件的例子](https://github.com/inchei/hexo-lunar-calendar)\n\n- [ ] [插入pdf](https://github.com/superalsrk/hexo-pdf/) 可以学习如何插入epub\n\n- [ ] [hexo-include](https://github.com/pirtleshell/hexo-include) 加载文本内容, html, js, text\n\n- [x] [Hexo-NexT给文章添加结束语](https://wangc1993.github.io/2019/01/10/6/)\n\n- [x] [Hexo-NexT接入网页在线联系功能](https://wangc1993.github.io/2019/01/10/5/)\n\n- [ ] [include markdown](https://github.com/tea3/hexo-include-markdown)\n\n\n\n### ---\n\n\n\n[^1]: [Hexo博客搭建全攻略(一):基于Hexo+Github环境搭建](https://blog.annieyu.com/posts/207737771.html)\n[^2]: [Hexo博客搭建全攻略(二):NexT主题配置](https://blog.annieyu.com/posts/976961586.html)\n[^3]: [Hexo博客搭建全攻略(三):三方服务集成](https://blog.annieyu.com/posts/1209152972.html)\n[^4]: [Hexo博客搭建全攻略(四):高级应用](https://blog.annieyu.com/posts/3333782006.html)\n[^5]: [Hexo博客搭建全攻略(五):基于Github Issue搭建评论系统](https://blog.annieyu.com/posts/a341668e.html)\n[^6]: [Hexo博客搭建全攻略(六):博文图片处理](https://www.jianshu.com/p/2bb87ae49ff6)\n[^7]: [十步之内轻松搞定 Hexo + GitHub搭建个人博客](https://gavinlee1.github.io/2017/02/25/%E5%8D%81%E6%AD%A5%E4%B9%8B%E5%86%85%E8%BD%BB%E6%9D%BE%E6%90%9E%E5%AE%9A-Hexo-GitHub%E6%90%AD%E5%BB%BA%E4%B8%AA%E4%BA%BA%E5%8D%9A%E5%AE%A2/) ​​\n[^8]: [如何优雅的 隐藏博客](https://vanchchen.github.io/p/7587.html)\n[^9]: [为 Hexo 博客添加隐藏文章 / 限定公开功能](https://blessing.studio/hexo-plugin-to-make-posts-sage-unlisted/)\n[^10]: [Hexo 中文文档](https://hexo.io/zh-cn/docs/index.html)\n\n[multipages]: ttp://chitanda.me/2015/11/03/multiple-git-pages-in-one-github-account/\n\n[讲解详细的博客](https://binglumeng.github.io/2017/03/21/Hexo学习笔记/) \n\n[这个也不错](http://yearito.cn/posts/hexo-advanced-settings.html)\n\n\n","slug":"IT/Web/搭建Hexo博客的流水账","published":1,"updated":"2019-08-15T10:44:25.000Z","_id":"cka1y59a2004u4huur56brcea","comments":1,"layout":"post","photos":[],"link":"","content":"

建立网站

\n

Github配置

\n

输入命令 ssh-keygen -t rsa -b 4096 -C "myname@gmail.com"

\n

密码 T1。(下列展开后复制)

\n
\n

将文件 ~/.ssh/id_rsa.pub 中的内容复制到 Github 的SSH-Key 内就可以了。(备份文件已上传百度网盘)

\n
\n
    \n
  1. 在Github上新建SSH-Key名称为gmail
  2. \n
\n

具体步骤参阅此文章

\n
1
2
3
4
5
6
7
8
9
10
11
12
ssh-keygen -t rsa -b 4096 -C "username@gmail.com"
[Enter]
[password T..1]

eval "$(ssh-agent -s)"
ssh-add -K ~/.ssh/id_rsa

cd ~
cd .ssh
ls
vim id_rsa.pub
(然后复制钥匙串)
\n
    \n
  1. 测试公匙
  2. \n
\n
1
2
3
$ ssh -T git@github.com

Hi username! You've successfully authenticated, but GitHub does not provide shell access.
\n

安装Hexo

\n

参考资料1 7

\n
    \n
  1. 安装node.js 因为以前已经安装过,所以跳过。
  2. \n
  3. 安装 Hexo $ npm install hexo-cli -g
  4. \n
  5. 创建网站
  6. \n
\n
1
2
3
4
mkdir mywiki
cd mywiki
hexo init
npm install
\n
    \n
  1. 生成静态页面 hexo g or hexo generate
  2. \n
  3. 启动本地网站服务 hexo s or hexo server
  4. \n
\n
\n

网站一般会运行在 http://localhost:4000/
\nPress Ctrl+C to stop.

\n
\n
    \n
  1. 用pow做服务本地运行
  2. \n
\n

Install

\n
1
$ curl get.pow.cx | sh
\n

Setup

\n

Symlink the folder into ~/.pow

\n
1
2
$ cd ~/.pow
$ ln -s /path/to/test
\n

发布到Github

\n

终于搭建好站点部署环境啦,那么要怎么样将我们本地生成预览好的页面发布到github上呢?很简单,Follow!

\n

首先,打开blog目录下的_config.yml,找到deploy段,配置成这样

\n
\n

deploy:
\ntype: git
\nrepository: git@github.com:yourname/yourname.github.io.git
\nbranch: master

\n
\n

注意将代码里面的yourname换成你账号的username。

\n

设置git身份信息

\n
\n

git config --global user.name “你的用户名”
\ngit config --global user.email “你的邮箱”

\n
\n

执行以下指令进行部署

\n

hexo d -g

\n

如果提示没找到git,请先执行以下指令

\n

cnpm install hexo-deployer-git --save

\n

再次部署后,浏览器打开 https://yourname.github.io 就可以看到刚才本地预览页面。

\n

网站基本配置

\n

Next 主题

\n

主题配置文件说明

\n
点击显/隐内容
\n
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
# Hexo 站点配置文件
## Docs: https://hexo.io/docs/configuration.html
## Source: https://github.com/hexojs/hexo/

# 网站配置
title: Hexo # 网站标题
subtitle: # 网站副标题
description: # 网站描述
author: John Doe # 你的昵称
language: # 网站使用的语言(英文:en, 简体中文:zh-Hans,繁体中文:zh-tw)
timezone: # 网站时区,用于生成页面时填充相关时间,默认使用电脑时区,一般不用改

# URL
## 如果你的站点要放入子目录, 请将url设置为'http://yoursite.com/child' 并将根目录设置为'/child/'
url: http://yoursite.com # 站点网址
root: / # 网站根目录
permalink: :year/:month/:day/:title/ #文单的永久链接格式
permalink_defaults: # 永久链接中各部分的默认值

# 目录
source_dir: source # 资源文件夹,这个文件夹用来存放博客内容
public_dir: public # 公共文件夹,这个文件夹用来存放生成的站点静态文件
tag_dir: tags # 标签文件夹
archive_dir: archives # 归档文件夹
category_dir: categories # 分类文件夹
code_dir: downloads/code # Include code文件夹
i18n_dir: :lang # 国际化文件夹,存放各种语言定义
skip_render: # 跳过指定文件的渲染

# 写作
new_post_name: :title.md # 新文章的文件名称
default_layout: post # 预设布局
titlecase: false # 把标题转换为 title case
external_link: true # 在新标签中打开链接
filename_case: 0 # 把文件名称转换为 (1) 小写或 (2) 大写
render_drafts: false # 显示草稿
post_asset_folder: false # 启动 Asset 文件夹
relative_link: false # 把链接改为与根目录的相对位址
future: true # 显示未来的文章
highlight: # 代码块的设置
enable: true
line_number: true
auto_detect: false
tab_replace:

# 分类 & 标签
default_category: uncategorized # 默认分类
category_map: # 分类别名
tag_map: # 标签别名

# 日期 / 时间格式
## Hexo 使用 Moment.js 来解析和显示时间
## http://momentjs.com/docs/#/displaying/format/
date_format: YYYY-MM-DD # 日期格式
time_format: HH:mm:ss # 时间格式

# 分页
## 每页显示的文章量 (0 = 关闭分页功能)
per_page: 10
pagination_dir: page

# 扩展
## Plugins: https://hexo.io/plugins/
## Themes: https://hexo.io/themes/
theme: landscape # 主题

# 部署
## Docs: https://hexo.io/docs/deployment.html
deploy:
type:
\n\n
\n

Wikitten主题

\n

具体配置参考开发者说明,更详细的描述参阅hexo-theme-icarus。为了与主题Next不冲突,作以下修改。

\n
    \n
  1. 自行修改 tags, about,categoriesindex.md,而不能从主题复制,覆盖站点原有设置。
  2. \n
  3. languages\\zh-CN.yml 重命名为 zh-Hans.yml
  4. \n
  5. _config.yml 菜单作以下更改
  6. \n
\n
1
2
3
4
5
6
menu:
首页: /
归档: /archives/
分类: /categories/
标签: /tags/
关于: /about/
\n
    \n
  1. thumbnail: true 使得每个post在快速列表里,显示图标。但就是每个帖子都要设定,很麻烦。
  2. \n
  3. post 中的 toc 要设置为 true,如果需要显示目录的话。
  4. \n
\n

同时部署两个项目

\n

第一个项目使用 Github 上面默认的 Github Pages,即 username.github.io 。在站点配置文件中如下:

\n
1
2
3
4
5
6
7
8
url: http://username.github.io
root: /
...
...
deploy:
type: git
repository: git@github.com:username/username.github.io.git
branch: master
\n

第二个站点开通一个 普通的repository,添加名为gh-pages 的Branch,并将gh-pages设为默认Branch。我将第二个仓库命名为 wiki ,那第二个站点就运行在https://username.github.io/wiki`次级目录下面。

\n

站点配置文件更改如下:

\n
1
2
3
4
5
6
7
8
url: http://username.github.io/wiki
root: /wiki/
...
...
deploy:
type: git
repository: git@github.com:username/wiki.git
branch: gh-pages
\n

同样用 hexo d -g 部署命令发布,两个站点就都运行起来了。

\n

为了使得两个项目使用同一个笔记资源,将站点中的 source 文件夹移到项目意外,将配置文件里的 source_dir: source 改为 source_dir: ../source(这里使用了相对目录)。

\n

参考文章 (细节已经失效,但思路值得参考)

\n

站内搜索

\n
    \n
  1. 安装插件
  2. \n
\n
1
2
npm install hexo-generator-search --save
npm install hexo-generator-searchdb --save
\n
    \n
  1. 配置hexo站点主配置文件_config.yml, 添加
  2. \n
\n
1
2
3
4
5
search:
path: search.xml
field: post
format: html
limit: 10000
\n
    \n
  1. 修改next主题配置文件_config.yml,启用 local_search
  2. \n
\n
1
2
3
4
local_search:
\tenable: true
\ttrigger: auto
\ttop_n_per_article: 1
\n
    \n
  1. 生成search.xml文件以及发布
  2. \n
\n
1
2
hexo g
hexo d -g # 本地运行 hexo s
\n

去除主题字样

\n

关于添加头像、标签、分类、「关于」等具体的修改,跟着参考资料2里面的步骤做就好了。最后说说如何去掉底部强力驱动及主题字样。

\n
    \n
  1. 找到 \\themes\\next\\layout_partials\\下面的footer.swig文件,打开:
  2. \n
\n
1
2
3
4
5
6
7
8
9
<div class=\"powered-by\">
{{ __('footer.powered', '<a class=\"theme-link\" href=\"https://hexo.io\">Hexo</a>') }}
</div>
<div class=\"theme-info\">
{{ __('footer.theme') }} -
<a class=\"theme-link\" href=\"https://github.com/iissnan/hexo-theme-next\">
NexT.{{ theme.scheme }}
</a>
</div>
\n

第一条是“由Hexo驱动” 的Hexo链接,把xml段删除,只留两个单引号’’。

\n

第二条是“主题-Next.XX”,将xml段都删掉,不留引号。

\n
1
2
3
4
5
6
<div class=\"powered-by\">
{{ __('footer.powered', '') }}
</div>
<div class=\"theme-info\">
{{ __('footer.theme') }}
</div>
\n
    \n
  1. 找到这个地方\\themes\\next\\languages\\ 下面的语言文件zh-Hans.yml(以中文为例):
  2. \n
\n
1
2
3
footer:
powered: \"由 %s 强力驱动\"
theme: 主题
\n

将上面的文字改成自己想要的即可。

\n

添加评论功能

\n

Gitment

\n

**此项目已经终止!**改为Disqus,以及其它评论服务。

\n
    \n
  1. 安装功能模块。在项目的根目录:
  2. \n
\n
1
npm i --save gitment
\n
    \n
  1. 在Github申请应用。settings -> Developer Settings -> OAuth Apps
  2. \n
\n
1
2
3
4
Application name:随便写
Homepage URL:这个也可以随意写,就写你的博客地址就行
Application description:描述,也可以随意写
Authorization callback URL:这个必须写你的博客地址
\n

申请好之后点注册,然后就可以看到两个东西ClientIDClient Secret,后面会用到。

\n
    \n
  1. 配置Gitment,打开themes/next/_config.yml:
  2. \n
\n
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
# Gitment
# Introduction: https://imsun.net/posts/gitment-introduction/
gitment:
enable: true
mint: true # RECOMMEND, A mint on Gitment, to support count, language and proxy_gateway
count: true # Show comments count in post meta area
lazy: false # Comments lazy loading with a button
cleanly: false # Hide 'Powered by ...' on footer, and more
language: # Force language, or auto switch by theme
github_user: {you github user id}
github_repo: 随便写一个你的公开的git仓库就行,到时候评论会作为那个项目的issue
client_id: {刚才申请的ClientID}
client_secret: {刚才申请的Client Secret}
proxy_gateway: # Address of api proxy, See: https://github.com/aimingoo/intersect
redirect_protocol: # Protocol of redirect_uri with force_redirect_protocol when mint enabled
\n

注意到这里基本上已经OK了,再看你的博客应该可以显示评论了.不过每篇博客都需要你手动初始化评论功能(如果你的历史博客很多那就一篇一篇去点吧,不过貌似有人写了批量处理脚本,没试过哈).

\n

而由于 github 中 Issueslabel 长度限制为最大 50 个字符,当 文章标题长度过长时,该label就会生成失败,而导致初始化错误,弹出 Validation Failed 的提示。

\n

通过网上的搜索,发现可以使用文章创建时的时间来代替文章标题,作为这个唯一的label标签。

\n

找到giment的配置:/themes/next/layout/_third-party/comments/gitment.swig 文件, 并找到如下部分:

\n
1
2
3
4
5
var gitment = new {{CommentsClass}}({
id: window.location.pathname,
owner: '{{ theme.gitment.github_user }}',
repo: '{{ theme.gitment.github_repo }}',
...
\n

id后面的路径值修改为 ‘itfanr_blog_<!–1–>’ 就可以了。

\n

Disqus

\n

目前只开通Disqus的评论。

\n
    \n
  1. 开通Disqus账号,并添加一个点 应用。具体步骤参看Hexo搭建博客系列:(六)Hexo添加Disqus评论
  2. \n
  3. 主题配置文件(_config.yml)文件中找到以下代码,添加你Disqus设置的Website Name在shortname。
  4. \n
\n
1
2
3
4
5
# Disqus
disqus:
enable: true
shortname: tian-ya-de-zhi-fu
count: true
\n

更详细请参阅网上。

\n

新文章命名规则

\n

发表新文章后系统崩溃。

\n

在根目录的配置文件中找到类似的:

\n
1
2
3
4
# Writing
new_post_name: 新文章.md # File name of new posts
default_layout: post
...
\n

将其改为由时间和题目组成:

\n
1
2
3
4
# Writing
new_post_name: year-:month-:day-:title.md # File name of new posts
default_layout: post
...
\n

进阶设置

\n

显示

\n

首页文章显示预览

\n

默认设定下。首页的文章每一篇都显示全文,不方便浏览。需要到主题的配置文件里将auto_excerptenable 改为 true。而length 字节表示文章预览的长度。

\n
1
2
3
4
# Automatically Excerpt. Not recommand.
auto_excerpt:
\tenable: true
\tlength: 300
\n

永久链接

\n

新文章的名字采用了中文(见上),中文出现在地址栏上不美观。也不利于SEO,以及增加了博文URL的层数。解决办法是给每篇文章制定链接地址。

\n
    \n
  1. 修改网站的配置文件中永久地址的设定:
  2. \n
\n
1
permalink: :urlname.html
\n
    \n
  1. 给每篇文章指定 urlname
  2. \n
\n
1
2
3
4
5
6
title: 《少有人走的路》笔记
date: 2019-07-21 00:14:37
urlname: road-less-traveled-summary
tags:
- 心理学
categories: 读书笔记
\n

编译后新的地址为 http://mywiki.test/road-less-traveled-summary.html。看起来就清爽多了。

\n

图片链接

\n
    \n
  1. 开通资源文件夹,创建新文章的时候会自动建立一个与文章同名的文件夹。可以将图片或者其它资源文件放到里面(打算将思维导图放到这里)。因为自定义了文件名的方式,所以根据官方描述无效。
  2. \n
  3. 安装第三方插件hexo-asset-image
  4. \n
\n
1
npm install hexo-asset-image --save
\n

在文章中图片的链,可以省略路径,直接引用图片名:

\n
1
![mypicture](mypicture.jpg)
\n
    \n
  1. 修改插件代码
  2. \n
\n

我在使用永久链接的时候在每篇文章的实际地址都加上了.html。文章的地址显示如下

\n
1
http://mywebsite.com/my-articel-url.html
\n

而插件生成的图片地址如下:

\n
1
http://mywebsite.com/my-articel-url.htm/mypicture.jpg
\n

多出了 .htm 这几个字符,而实际图片的地址应该是:

\n
1
http://mywebsite.com/my-articel-url/mypicture.jpg
\n

找到 node_modules/hexo-asset-imge 目录下的 index.js 文件,将以下代码中的 1 改成 5,就可以正常显示图片了。

\n
1
var endPos = link.length - 1
\n

考虑到将来项目膨胀,应该将图片放到图床,比如七牛。

\n

站内链接

\n

导航到站内别的文章使用以下方式就可以。

\n

链接方式 [文章名](urlname.html)

\n

设定代码区的高度

\n

Hexo自身的式样暂时还没找到。其实也不太需要。如果代码不长直接显示全部就好了。太长的话不如放到$Gits$,通过限制gist的高度实现。Net主题修改 next/themes/next/source/css/_custom/custom.styl ,Wikitten主题则在文件 wikitten/themes/Wikitten/source/css/_partial/article.styl 中修改。

\n
1
2
3
4
5
.gist 
.gist-file
.gist-data {
max-height: 450px;
}
\n

添加注脚支持

\n

插件项目

\n
    \n
  1. 安装插件 npm install hexo-footnotes --save
  2. \n
  3. 项目配置文件 添加
  4. \n
\n
1
2
3
# 注意第二行的前面没有 \"-\" 符号,官方说明有. 但是会导致无法编译.
plugins:
hexo-footnotes
\n

更换Markdown渲染

\n

Markdown-it-plus

\n

如果更换了这个渲染,就无需上面那个注脚插件, 因为已经支持了. 首先卸载掉旧的渲染, 然后安装新的.

\n
1
2
3
4
npm un hexo-renderer-marked --save
npm i hexo-renderer-markdown-it-plus --save
# 查看是否已经安装
npm ls hexo-renderer-markdown-it-plus
\n

然后在项目配置文件, 添加下面文字. 更深入的设置, 参看 markdown-it-plus 项目的说明文档.

\n
1
2
3
4
5
6
7
8
9
10
markdown_it_plus:
highlight: true
html: true
xhtmlOut: true
breaks: true
langPrefix:
linkify: true
typographer:
quotes: “”‘’
plugins:
\n

辅助功能

\n

本地运行服务

\n

在Mac中可以用本地服务Pow运行网站,不用每次更改重启服务器hexo s

\n
    \n
  1. 安装Pow
  2. \n
\n
1
$ curl get.pow.cx | sh
\n
    \n
  1. 建立项目链接,myapp 是项目的名字。比如真实路径~/Project/mywiki
  2. \n
\n
1
2
$ cd ~/.pow
$ ln -s /path/to/myapp
\n
    \n
  1. 执行完以上步骤后在浏览器打开链接 http://myapp.test/ 就能看到网站。更改内容后要执行==生成== 命令才能看到更新hexo generate or hexo g
  2. \n
  3. 不想运行,直接把项目文件夹删除就可以。
  4. \n
\n

绑定个人域名

\n
    \n
  1. 在万网买一个顶级域名,开通后添加两个域名解释
  2. \n
\n
1
2
3
#记录名  主机记录  记录值
CNAME www username.github.io
CNAME @ username.github.io
\n
    \n
  1. 在项目的根目录添加一个名为 CNAME 的文件,然后填入万网注册的域名, 这里是 goldentianya.pub 。第一次我是手动添加的。添加后进入 repository 的 setting, 往下混动到 Custom domain ,可以看到系统已经自动把用户域名加进去了。
  2. \n
  3. 将来不希望用这个域名,域名重定向后,在浏览器输入 username.github.io 后 Chrome 会一直转向 goldentianya.pub 。需要打开开发者工具,选中 disable cache ,再刷新一遍地址就好了。
  4. \n
  5. next 项目要将 CNAME 文件复制到 /themes/next/source 目录下个,编译的时候会拷贝到 public 目录。wikitten 项目不需要,域名定向以后能找到 goldentianya/wiki 站点,十分神奇。
  6. \n
\n

隐藏文章

\n

全隐藏

\n

根据插件hext-sage-posts 作者的博文9中描述,安装插件

\n
1
npm install hexo-sage-posts --save
\n

并将初创时的Hello-world.md 文章的Metadata中加入sage: true,文章就从网站上消失了。但在别的文章下面导航栏中,通过“下一篇”或者“上一篇”还是能被找到。被隐藏的文章其地址仍旧没有改变,只是不不出现在首页导航,和分类中而已。

\n

从首页隐藏

\n

为了不让太琐碎的文章充斥首页,但又可以在分类中找到。可以采用这种方式。

\n
    \n
  1. 在文章的Metadata部分添加关键字 notshow: true
  2. \n
  3. 找到 Hexo\\themes\\next\\layout\\index.swig 文件中以下部分:
  4. \n
\n
1
2
3
4
5
6
7
8
9
{% block content %}
<section id=\"posts\" class=\"posts-expand\">
{% for post in page.posts %}
{{ post_template.render(post, true) }} <!--修改此行-->
{% endfor %}
</section>

{% include '_partials/pagination.swig' %}
{% endblock %}
\n

将以上代码第四行修改为

\n
1
2
3
{% if post.notshow != true %}
\t{{ post_template.render(post, true) }}
{% endif %}
\n

文章加密

\n
    \n
  1. 安装插件 hexo-blog-encrypt
  2. \n
\n
1
npm install --save hexo-blog-encrypt
\n

并在站点配置文件中启用该插件:

\n
1
2
encrypt:
enable: true
\n
    \n
  1. 然后在文章的头部添加上对应的字段
  2. \n
\n
1
2
3
4
5
6
7
8
9
10
11
12
---
title: 文章加密
date: 2019-01-04T22:20:13.000Z
category: 教程
tags:
- 博客
- Hexo
keywords: 博客文章密码
password: TloveY
abstract: 此文章含有敏感内容。
message: 输入密码,查看文章
---
\n
    \n
  • \n

    password: 是该博客加密使用的密码

    \n
  • \n
  • \n

    abstract: 是该博客的摘要,会显示在博客的列表页

    \n
  • \n
  • \n

    message: 这个是博客查看时,密码输入框上面的描述性文字

    \n
  • \n
\n

Hexo Admin

\n

安装后台管理插件 hexo-damin

\n
1
2
3
npm install --save hexo-admin
hexo server -d
open http://localhost:4000/admin/
\n

初次运行后,设置管理账户。

\n
1
2
3
4
admin:
username: maiernte
password_hash: $2a$10$QeeWfDwIxbJ94h8EDfplDe9aLB0uaNrjMeVGhaYnfF0BBDosDze0S
secret: NamoAmitabha!
\n

访问量统计

\n

介绍文章有图

\n

原文(有代码)

\n
    \n
  1. \n

    第一步, 到Lean Cloud增添一个应用,并创建类似Counter 的类。设置成 $ 所有人可读可写 $

    \n
  2. \n
  3. \n

    在安全中心添加 Web 安全域名, 添加Blog域名,防止有人Hack我们的数据库。

    \n
  4. \n
  5. \n

    按上面的文章修改 Hexo 以及主题配置。

    \n
  6. \n
\n

在线交流

\n

使用 道客 Daovoice

\n

接入方式

\n
    \n
  1. 将下面代码粘贴在页面的 之前。
  2. \n
\n
1
<script>(function(i,s,o,g,r,a,m){i["DaoVoiceObject"]=r;i[r]=i[r]||function(){(i[r].q=i[r].q||[]).push(arguments)},i[r].l=1*new Date();a=s.createElement(o),m=s.getElementsByTagName(o)[0];a.async=1;a.src=g;a.charset="utf-8";m.parentNode.insertBefore(a,m)})(window,document,"script",('https:' == document.location.protocol ? 'https:' : 'http:') + "//widget.daovoice.io/widget/5e5fa370.js","daovoice")</script>
\n
    \n
  1. 调用下面的 JavaScript 与注册用户沟通
  2. \n
\n
1
2
3
4
5
6
7
8
daovoice('init', {
app_id: "5e5fa370",
user_id: "NO_89757", // 必填: 该用户在您系统上的唯一ID
email: "daovoice@example.com", // 选填: 该用户在您系统上的主邮箱
name: "道客船长", // 选填: 用户名
signed_up: 1449821660 // 选填: 用户的注册时间,用Unix时间戳表示
});
daovoice('update');
\n
    \n
  1. 调用下面的 JavaScript 与匿名访客沟通
  2. \n
\n
1
2
3
4
daovoice('init', {
app_id: "5e5fa370"
});
daovoice('update');
\n

完成代码粘贴后,检测是否成功接入: Ping 一下

\n

待解决问题

\n\n

有趣插件

\n\n

\n

讲解详细的博客

\n

这个也不错

\n","site":{"data":{}},"excerpt":"

建网过程中的一些流水账。以备将来查询。

","more":"

建立网站

\n

Github配置

\n

输入命令 ssh-keygen -t rsa -b 4096 -C "myname@gmail.com"

\n

密码 T1。(下列展开后复制)

\n
\n

将文件 ~/.ssh/id_rsa.pub 中的内容复制到 Github 的SSH-Key 内就可以了。(备份文件已上传百度网盘)

\n
\n
    \n
  1. 在Github上新建SSH-Key名称为gmail
  2. \n
\n

具体步骤参阅此文章

\n\n
    \n
  1. 测试公匙
  2. \n
\n\n

安装Hexo

\n

参考资料1 7

\n
    \n
  1. 安装node.js 因为以前已经安装过,所以跳过。
  2. \n
  3. 安装 Hexo $ npm install hexo-cli -g
  4. \n
  5. 创建网站
  6. \n
\n\n
    \n
  1. 生成静态页面 hexo g or hexo generate
  2. \n
  3. 启动本地网站服务 hexo s or hexo server
  4. \n
\n
\n

网站一般会运行在 http://localhost:4000/
\nPress Ctrl+C to stop.

\n
\n
    \n
  1. 用pow做服务本地运行
  2. \n
\n

Install

\n\n

Setup

\n

Symlink the folder into ~/.pow

\n\n

发布到Github

\n

终于搭建好站点部署环境啦,那么要怎么样将我们本地生成预览好的页面发布到github上呢?很简单,Follow!

\n

首先,打开blog目录下的_config.yml,找到deploy段,配置成这样

\n
\n

deploy:
\ntype: git
\nrepository: git@github.com:yourname/yourname.github.io.git
\nbranch: master

\n
\n

注意将代码里面的yourname换成你账号的username。

\n

设置git身份信息

\n
\n

git config --global user.name “你的用户名”
\ngit config --global user.email “你的邮箱”

\n
\n

执行以下指令进行部署

\n

hexo d -g

\n

如果提示没找到git,请先执行以下指令

\n

cnpm install hexo-deployer-git --save

\n

再次部署后,浏览器打开 https://yourname.github.io 就可以看到刚才本地预览页面。

\n

网站基本配置

\n

Next 主题

\n

主题配置文件说明

\n
点击显/隐内容
\n\n\n
\n

Wikitten主题

\n

具体配置参考开发者说明,更详细的描述参阅hexo-theme-icarus。为了与主题Next不冲突,作以下修改。

\n
    \n
  1. 自行修改 tags, about,categoriesindex.md,而不能从主题复制,覆盖站点原有设置。
  2. \n
  3. languages\\zh-CN.yml 重命名为 zh-Hans.yml
  4. \n
  5. _config.yml 菜单作以下更改
  6. \n
\n\n
    \n
  1. thumbnail: true 使得每个post在快速列表里,显示图标。但就是每个帖子都要设定,很麻烦。
  2. \n
  3. post 中的 toc 要设置为 true,如果需要显示目录的话。
  4. \n
\n

同时部署两个项目

\n

第一个项目使用 Github 上面默认的 Github Pages,即 username.github.io 。在站点配置文件中如下:

\n\n

第二个站点开通一个 普通的repository,添加名为gh-pages 的Branch,并将gh-pages设为默认Branch。我将第二个仓库命名为 wiki ,那第二个站点就运行在https://username.github.io/wiki`次级目录下面。

\n

站点配置文件更改如下:

\n\n

同样用 hexo d -g 部署命令发布,两个站点就都运行起来了。

\n

为了使得两个项目使用同一个笔记资源,将站点中的 source 文件夹移到项目意外,将配置文件里的 source_dir: source 改为 source_dir: ../source(这里使用了相对目录)。

\n

参考文章 (细节已经失效,但思路值得参考)

\n

站内搜索

\n
    \n
  1. 安装插件
  2. \n
\n\n
    \n
  1. 配置hexo站点主配置文件_config.yml, 添加
  2. \n
\n\n
    \n
  1. 修改next主题配置文件_config.yml,启用 local_search
  2. \n
\n\n
    \n
  1. 生成search.xml文件以及发布
  2. \n
\n\n

去除主题字样

\n

关于添加头像、标签、分类、「关于」等具体的修改,跟着参考资料2里面的步骤做就好了。最后说说如何去掉底部强力驱动及主题字样。

\n
    \n
  1. 找到 \\themes\\next\\layout_partials\\下面的footer.swig文件,打开:
  2. \n
\n\n

第一条是“由Hexo驱动” 的Hexo链接,把xml段删除,只留两个单引号’’。

\n

第二条是“主题-Next.XX”,将xml段都删掉,不留引号。

\n\n
    \n
  1. 找到这个地方\\themes\\next\\languages\\ 下面的语言文件zh-Hans.yml(以中文为例):
  2. \n
\n\n

将上面的文字改成自己想要的即可。

\n

添加评论功能

\n

Gitment

\n

**此项目已经终止!**改为Disqus,以及其它评论服务。

\n
    \n
  1. 安装功能模块。在项目的根目录:
  2. \n
\n\n
    \n
  1. 在Github申请应用。settings -> Developer Settings -> OAuth Apps
  2. \n
\n\n

申请好之后点注册,然后就可以看到两个东西ClientIDClient Secret,后面会用到。

\n
    \n
  1. 配置Gitment,打开themes/next/_config.yml:
  2. \n
\n\n

注意到这里基本上已经OK了,再看你的博客应该可以显示评论了.不过每篇博客都需要你手动初始化评论功能(如果你的历史博客很多那就一篇一篇去点吧,不过貌似有人写了批量处理脚本,没试过哈).

\n

而由于 github 中 Issueslabel 长度限制为最大 50 个字符,当 文章标题长度过长时,该label就会生成失败,而导致初始化错误,弹出 Validation Failed 的提示。

\n

通过网上的搜索,发现可以使用文章创建时的时间来代替文章标题,作为这个唯一的label标签。

\n

找到giment的配置:/themes/next/layout/_third-party/comments/gitment.swig 文件, 并找到如下部分:

\n\n

id后面的路径值修改为 ‘itfanr_blog_<!–1–>’ 就可以了。

\n

Disqus

\n

目前只开通Disqus的评论。

\n
    \n
  1. 开通Disqus账号,并添加一个点 应用。具体步骤参看Hexo搭建博客系列:(六)Hexo添加Disqus评论
  2. \n
  3. 主题配置文件(_config.yml)文件中找到以下代码,添加你Disqus设置的Website Name在shortname。
  4. \n
\n\n

更详细请参阅网上。

\n

新文章命名规则

\n

发表新文章后系统崩溃。

\n

在根目录的配置文件中找到类似的:

\n\n

将其改为由时间和题目组成:

\n\n

进阶设置

\n

显示

\n

首页文章显示预览

\n

默认设定下。首页的文章每一篇都显示全文,不方便浏览。需要到主题的配置文件里将auto_excerptenable 改为 true。而length 字节表示文章预览的长度。

\n\n

永久链接

\n

新文章的名字采用了中文(见上),中文出现在地址栏上不美观。也不利于SEO,以及增加了博文URL的层数。解决办法是给每篇文章制定链接地址。

\n
    \n
  1. 修改网站的配置文件中永久地址的设定:
  2. \n
\n\n
    \n
  1. 给每篇文章指定 urlname
  2. \n
\n\n

编译后新的地址为 http://mywiki.test/road-less-traveled-summary.html。看起来就清爽多了。

\n

图片链接

\n
    \n
  1. 开通资源文件夹,创建新文章的时候会自动建立一个与文章同名的文件夹。可以将图片或者其它资源文件放到里面(打算将思维导图放到这里)。因为自定义了文件名的方式,所以根据官方描述无效。
  2. \n
  3. 安装第三方插件hexo-asset-image
  4. \n
\n\n

在文章中图片的链,可以省略路径,直接引用图片名:

\n\n
    \n
  1. 修改插件代码
  2. \n
\n

我在使用永久链接的时候在每篇文章的实际地址都加上了.html。文章的地址显示如下

\n\n

而插件生成的图片地址如下:

\n\n

多出了 .htm 这几个字符,而实际图片的地址应该是:

\n\n

找到 node_modules/hexo-asset-imge 目录下的 index.js 文件,将以下代码中的 1 改成 5,就可以正常显示图片了。

\n\n

考虑到将来项目膨胀,应该将图片放到图床,比如七牛。

\n

站内链接

\n

导航到站内别的文章使用以下方式就可以。

\n

链接方式 [文章名](urlname.html)

\n

设定代码区的高度

\n

Hexo自身的式样暂时还没找到。其实也不太需要。如果代码不长直接显示全部就好了。太长的话不如放到$Gits$,通过限制gist的高度实现。Net主题修改 next/themes/next/source/css/_custom/custom.styl ,Wikitten主题则在文件 wikitten/themes/Wikitten/source/css/_partial/article.styl 中修改。

\n\n

添加注脚支持

\n

插件项目

\n
    \n
  1. 安装插件 npm install hexo-footnotes --save
  2. \n
  3. 项目配置文件 添加
  4. \n
\n\n

更换Markdown渲染

\n

Markdown-it-plus

\n

如果更换了这个渲染,就无需上面那个注脚插件, 因为已经支持了. 首先卸载掉旧的渲染, 然后安装新的.

\n\n

然后在项目配置文件, 添加下面文字. 更深入的设置, 参看 markdown-it-plus 项目的说明文档.

\n\n

辅助功能

\n

本地运行服务

\n

在Mac中可以用本地服务Pow运行网站,不用每次更改重启服务器hexo s

\n
    \n
  1. 安装Pow
  2. \n
\n\n
    \n
  1. 建立项目链接,myapp 是项目的名字。比如真实路径~/Project/mywiki
  2. \n
\n\n
    \n
  1. 执行完以上步骤后在浏览器打开链接 http://myapp.test/ 就能看到网站。更改内容后要执行==生成== 命令才能看到更新hexo generate or hexo g
  2. \n
  3. 不想运行,直接把项目文件夹删除就可以。
  4. \n
\n

绑定个人域名

\n
    \n
  1. 在万网买一个顶级域名,开通后添加两个域名解释
  2. \n
\n\n
    \n
  1. 在项目的根目录添加一个名为 CNAME 的文件,然后填入万网注册的域名, 这里是 goldentianya.pub 。第一次我是手动添加的。添加后进入 repository 的 setting, 往下混动到 Custom domain ,可以看到系统已经自动把用户域名加进去了。
  2. \n
  3. 将来不希望用这个域名,域名重定向后,在浏览器输入 username.github.io 后 Chrome 会一直转向 goldentianya.pub 。需要打开开发者工具,选中 disable cache ,再刷新一遍地址就好了。
  4. \n
  5. next 项目要将 CNAME 文件复制到 /themes/next/source 目录下个,编译的时候会拷贝到 public 目录。wikitten 项目不需要,域名定向以后能找到 goldentianya/wiki 站点,十分神奇。
  6. \n
\n

隐藏文章

\n

全隐藏

\n

根据插件hext-sage-posts 作者的博文9中描述,安装插件

\n\n

并将初创时的Hello-world.md 文章的Metadata中加入sage: true,文章就从网站上消失了。但在别的文章下面导航栏中,通过“下一篇”或者“上一篇”还是能被找到。被隐藏的文章其地址仍旧没有改变,只是不不出现在首页导航,和分类中而已。

\n

从首页隐藏

\n

为了不让太琐碎的文章充斥首页,但又可以在分类中找到。可以采用这种方式。

\n
    \n
  1. 在文章的Metadata部分添加关键字 notshow: true
  2. \n
  3. 找到 Hexo\\themes\\next\\layout\\index.swig 文件中以下部分:
  4. \n
\n\n

将以上代码第四行修改为

\n\n

文章加密

\n
    \n
  1. 安装插件 hexo-blog-encrypt
  2. \n
\n\n

并在站点配置文件中启用该插件:

\n\n
    \n
  1. 然后在文章的头部添加上对应的字段
  2. \n
\n\n
    \n
  • \n

    password: 是该博客加密使用的密码

    \n
  • \n
  • \n

    abstract: 是该博客的摘要,会显示在博客的列表页

    \n
  • \n
  • \n

    message: 这个是博客查看时,密码输入框上面的描述性文字

    \n
  • \n
\n

Hexo Admin

\n

安装后台管理插件 hexo-damin

\n\n

初次运行后,设置管理账户。

\n\n

访问量统计

\n

介绍文章有图

\n

原文(有代码)

\n
    \n
  1. \n

    第一步, 到Lean Cloud增添一个应用,并创建类似Counter 的类。设置成 $ 所有人可读可写 $

    \n
  2. \n
  3. \n

    在安全中心添加 Web 安全域名, 添加Blog域名,防止有人Hack我们的数据库。

    \n
  4. \n
  5. \n

    按上面的文章修改 Hexo 以及主题配置。

    \n
  6. \n
\n

在线交流

\n

使用 道客 Daovoice

\n

接入方式

\n
    \n
  1. 将下面代码粘贴在页面的 之前。
  2. \n
\n\n
    \n
  1. 调用下面的 JavaScript 与注册用户沟通
  2. \n
\n\n
    \n
  1. 调用下面的 JavaScript 与匿名访客沟通
  2. \n
\n\n

完成代码粘贴后,检测是否成功接入: Ping 一下

\n

待解决问题

\n\n

有趣插件

\n\n

\n

讲解详细的博客

\n

这个也不错

\n"},{"title":"Hexo 在线编辑","urlname":"hexo-onlineeditor","updated":"2021-07-18T21:19:08.000Z","date":"2021-07-18T21:19:08.000Z","_content":"\n使用过一个在线网站\n\ntitle: 斯多葛主义手册\ndate: 2019-08-03 21:16:47\nurlname: storic-summary\ntoc: true\ntags: [哲理, 书籍]\ncategories: [读书笔记]\n\n[网站:静态博客](https://jingtaiboke.com/my.php?siteID=0 \"网站:静态博客\")\n\n","source":"_posts/Hexo在线编辑.md","raw":"---\ntitle: Hexo 在线编辑\nurlname: hexo-onlineeditor\nupdated: 2021-07-18 23:19:08\ndate: 2021-07-18 23:19:08\ncategories: [IT, Blog]\ntags: [Hexo]\n---\n\n使用过一个在线网站\n\ntitle: 斯多葛主义手册\ndate: 2019-08-03 21:16:47\nurlname: storic-summary\ntoc: true\ntags: [哲理, 书籍]\ncategories: [读书笔记]\n\n[网站:静态博客](https://jingtaiboke.com/my.php?siteID=0 \"网站:静态博客\")\n\n","slug":"Hexo在线编辑","published":1,"_id":"ckr9qy9q80000g9shy5e4v2m1","comments":1,"layout":"post","photos":[],"link":"","content":"

使用过一个在线网站

\n

title: 斯多葛主义手册
\ndate: 2019-08-03 21:16:47
\nurlname: storic-summary
\ntoc: true
\ntags: [哲理, 书籍]
\ncategories: [读书笔记]

\n

网站:静态博客

\n","site":{"data":{}},"excerpt":"","more":"

使用过一个在线网站

\n

title: 斯多葛主义手册
\ndate: 2019-08-03 21:16:47
\nurlname: storic-summary
\ntoc: true
\ntags: [哲理, 书籍]
\ncategories: [读书笔记]

\n

网站:静态博客

\n"}],"PostAsset":[],"PostCategory":[{"post_id":"cka1y594p00044huusb0xswfi","category_id":"cka1y594t00064huuvvjmyzwy","_id":"cka1y5955000f4huuavh4y5b7"},{"post_id":"cka1y594r00054huunm0reb46","category_id":"cka1y5953000b4huuyyfu5z4d","_id":"cka1y595a000k4huuvsrdkk3n"},{"post_id":"cka1y594x00084huu6k4ch39z","category_id":"cka1y5953000b4huuyyfu5z4d","_id":"cka1y595b000n4huupqz7l7uk"},{"post_id":"cka1y595000094huuoh5kztsj","category_id":"cka1y5959000j4huug5k1h4j7","_id":"cka1y595d000q4huujzi9cbtg"},{"post_id":"cka1y5952000a4huuo6qb7h3o","category_id":"cka1y595b000o4huul85o0vh5","_id":"cka1y595e000r4huudibumejw"},{"post_id":"cka1y596d000s4huu6s41uv14","category_id":"cka1y5953000b4huuyyfu5z4d","_id":"cka1y596h000x4huuewz15l41"},{"post_id":"cka1y596e000t4huuu6ed1frz","category_id":"cka1y596g000v4huufrvfyl7e","_id":"cka1y596j000z4huuep0zhq22"},{"post_id":"cka1y597o00124huu1wtf5iy9","category_id":"cka1y596g000v4huufrvfyl7e","_id":"cka1y597u00174huuuxk19v3o"},{"post_id":"cka1y597q00134huu98tdadd8","category_id":"cka1y596g000v4huufrvfyl7e","_id":"cka1y597v001b4huutjytdbb1"},{"post_id":"cka1y597w001d4huu070sswhu","category_id":"cka1y597u00184huu67j8phqt","_id":"cka1y598e00224huude7qq2nl"},{"post_id":"cka1y597w001d4huu070sswhu","category_id":"cka1y5987001q4huu2h0pcxc7","_id":"cka1y598g00274huuqt9x226m"},{"post_id":"cka1y597r00154huu5w41rgul","category_id":"cka1y597u00184huu67j8phqt","_id":"cka1y598h002a4huuv4qc79od"},{"post_id":"cka1y597r00154huu5w41rgul","category_id":"cka1y598b001w4huu0hxl1aoy","_id":"cka1y598j002f4huuabno4va2"},{"post_id":"cka1y597x001e4huuv3ebsp4j","category_id":"cka1y597u00184huu67j8phqt","_id":"cka1y598o002k4huubdx47g0s"},{"post_id":"cka1y597x001e4huuv3ebsp4j","category_id":"cka1y598e00234huu3y8d3uke","_id":"cka1y598q002o4huuiwbqiz7r"},{"post_id":"cka1y597z001h4huur126uc0a","category_id":"cka1y597u00184huu67j8phqt","_id":"cka1y598s002s4huu123t8obl"},{"post_id":"cka1y597z001h4huur126uc0a","category_id":"cka1y598e00234huu3y8d3uke","_id":"cka1y598t002u4huuuusrp5uf"},{"post_id":"cka1y597t00164huuyti606sh","category_id":"cka1y597u00184huu67j8phqt","_id":"cka1y598u002x4huuvof25rfi"},{"post_id":"cka1y597t00164huuyti606sh","category_id":"cka1y5987001q4huu2h0pcxc7","_id":"cka1y598w002z4huu71gvxwrk"},{"post_id":"cka1y5981001j4huuk1yz6awj","category_id":"cka1y597u00184huu67j8phqt","_id":"cka1y598w00324huuzt7qlork"},{"post_id":"cka1y5981001j4huuk1yz6awj","category_id":"cka1y598e00234huu3y8d3uke","_id":"cka1y598x00344huu11z99kzj"},{"post_id":"cka1y5983001n4huuemw79ybo","category_id":"cka1y597u00184huu67j8phqt","_id":"cka1y598y00374huu7kdrdbh8"},{"post_id":"cka1y5983001n4huuemw79ybo","category_id":"cka1y598e00234huu3y8d3uke","_id":"cka1y598z00394huuyhhgk2zf"},{"post_id":"cka1y597u001a4huuspnhsflr","category_id":"cka1y597u00184huu67j8phqt","_id":"cka1y5990003c4huusbmzttfh"},{"post_id":"cka1y597u001a4huuspnhsflr","category_id":"cka1y598e00234huu3y8d3uke","_id":"cka1y5991003e4huufvyl6wez"},{"post_id":"cka1y5986001p4huuxt1btjua","category_id":"cka1y597u00184huu67j8phqt","_id":"cka1y5991003g4huuhm5iv2oz"},{"post_id":"cka1y5986001p4huuxt1btjua","category_id":"cka1y598e00234huu3y8d3uke","_id":"cka1y5993003j4huuke8eg1wd"},{"post_id":"cka1y5988001t4huux85puqey","category_id":"cka1y597u00184huu67j8phqt","_id":"cka1y5996003m4huui5twjhmb"},{"post_id":"cka1y5988001t4huux85puqey","category_id":"cka1y598z003b4huuyf8flxmz","_id":"cka1y5997003o4huuf2s6yarp"},{"post_id":"cka1y598a001v4huunsgdb908","category_id":"cka1y597u00184huu67j8phqt","_id":"cka1y5997003r4huu1ryhxyt6"},{"post_id":"cka1y598a001v4huunsgdb908","category_id":"cka1y598z003b4huuyf8flxmz","_id":"cka1y5999003t4huutt02fr4i"},{"post_id":"cka1y598b001y4huuppnodfz2","category_id":"cka1y597u00184huu67j8phqt","_id":"cka1y5999003v4huu5g4xan28"},{"post_id":"cka1y598b001y4huuppnodfz2","category_id":"cka1y598z003b4huuyf8flxmz","_id":"cka1y599a003x4huuhgtsb5j8"},{"post_id":"cka1y598d00214huuioh2rw8e","category_id":"cka1y597u00184huu67j8phqt","_id":"cka1y599b003z4huutfrxgwz9"},{"post_id":"cka1y598d00214huuioh2rw8e","category_id":"cka1y5997003q4huuzp1l2yal","_id":"cka1y599b00414huuobbv9nmd"},{"post_id":"cka1y598f00254huufdsy7udi","category_id":"cka1y5953000b4huuyyfu5z4d","_id":"cka1y599c00424huue4frz85l"},{"post_id":"cka1y598f00254huufdsy7udi","category_id":"cka1y599a003w4huuplb2sm25","_id":"cka1y599c00444huu4y9mter5"},{"post_id":"cka1y598g00294huuytpjchoh","category_id":"cka1y5953000b4huuyyfu5z4d","_id":"cka1y599d00464huuuo9u8mcw"},{"post_id":"cka1y598g00294huuytpjchoh","category_id":"cka1y599b00404huu2nbcrdvc","_id":"cka1y599e00474huut3xryk5u"},{"post_id":"cka1y598i002d4huu06onppzf","category_id":"cka1y5953000b4huuyyfu5z4d","_id":"cka1y599e00494huu3mvwk79i"},{"post_id":"cka1y598i002d4huu06onppzf","category_id":"cka1y599a003w4huuplb2sm25","_id":"cka1y599f004a4huuvxibk9ev"},{"post_id":"cka1y598k002h4huuc3fgsb7o","category_id":"cka1y5953000b4huuyyfu5z4d","_id":"cka1y599f004c4huuj9j32oee"},{"post_id":"cka1y598k002h4huuc3fgsb7o","category_id":"cka1y599a003w4huuplb2sm25","_id":"cka1y599g004d4huuxu7lsg0c"},{"post_id":"cka1y598o002l4huuoby01avt","category_id":"cka1y5953000b4huuyyfu5z4d","_id":"cka1y599g004e4huulan4zmb7"},{"post_id":"cka1y598o002l4huuoby01avt","category_id":"cka1y599a003w4huuplb2sm25","_id":"cka1y599h004f4huufhqmspm7"},{"post_id":"cka1y598q002p4huudjt7uk0a","category_id":"cka1y5953000b4huuyyfu5z4d","_id":"cka1y599h004g4huuhwkznvlk"},{"post_id":"cka1y598q002p4huudjt7uk0a","category_id":"cka1y599a003w4huuplb2sm25","_id":"cka1y599h004h4huuzytw6gr0"},{"post_id":"cka1y599o004i4huuvxxo90p7","category_id":"cka1y597u00184huu67j8phqt","_id":"cka1y599s004n4huu9k8s6rm6"},{"post_id":"cka1y599o004i4huuvxxo90p7","category_id":"cka1y598e00234huu3y8d3uke","_id":"cka1y599s004p4huu2rwib2tg"},{"post_id":"cka1y599p004j4huucopvbcs0","category_id":"cka1y597u00184huu67j8phqt","_id":"cka1y599t004q4huulsh7ujtl"},{"post_id":"cka1y599p004j4huucopvbcs0","category_id":"cka1y5997003q4huuzp1l2yal","_id":"cka1y599t004r4huul19yoh59"},{"post_id":"cka1y599q004l4huuz9r1vgbn","category_id":"cka1y597u00184huu67j8phqt","_id":"cka1y599t004s4huupqp5vr9t"},{"post_id":"cka1y599q004l4huuz9r1vgbn","category_id":"cka1y5997003q4huuzp1l2yal","_id":"cka1y599u004t4huuo3k58azn"},{"post_id":"cka1y59a2004u4huur56brcea","category_id":"cka1y597u00184huu67j8phqt","_id":"cka1y59a7004w4huu7wd3n1pk"},{"post_id":"cka1y59a2004u4huur56brcea","category_id":"cka1y598z003b4huuyf8flxmz","_id":"cka1y59a9004x4huu0j3d865x"},{"post_id":"ckr9qy9q80000g9shy5e4v2m1","category_id":"cka1y597u00184huu67j8phqt","_id":"ckr9qy9r50003g9shljfbfngv"},{"post_id":"ckr9qy9q80000g9shy5e4v2m1","category_id":"ckr9qy9qo0002g9sht8n0g8qc","_id":"ckr9qy9r50004g9shlorl3t63"}],"PostTag":[{"post_id":"cka1y594p00044huusb0xswfi","tag_id":"cka1y594w00074huuttkx39vr","_id":"cka1y5955000d4huu9fo10can"},{"post_id":"cka1y5952000a4huuo6qb7h3o","tag_id":"cka1y594w00074huuttkx39vr","_id":"cka1y5955000e4huu2isd10jc"},{"post_id":"cka1y594r00054huunm0reb46","tag_id":"cka1y5954000c4huurnts5s23","_id":"cka1y5959000i4huupv2tq46c"},{"post_id":"cka1y594x00084huu6k4ch39z","tag_id":"cka1y5956000h4huujc504cfl","_id":"cka1y595b000m4huuyc267a8u"},{"post_id":"cka1y595000094huuoh5kztsj","tag_id":"cka1y595a000l4huu5t4fsi8t","_id":"cka1y595d000p4huubql3yxvf"},{"post_id":"cka1y596d000s4huu6s41uv14","tag_id":"cka1y5954000c4huurnts5s23","_id":"cka1y596g000u4huu4o7prlyh"},{"post_id":"cka1y596e000t4huuu6ed1frz","tag_id":"cka1y596h000w4huu96c70yd8","_id":"cka1y596j00104huu1x6cnerc"},{"post_id":"cka1y596e000t4huuu6ed1frz","tag_id":"cka1y596i000y4huu4e1c2vta","_id":"cka1y596k00114huu4rph259l"},{"post_id":"cka1y597r00154huu5w41rgul","tag_id":"cka1y594w00074huuttkx39vr","_id":"cka1y597u00194huux4g0d800"},{"post_id":"cka1y597o00124huu1wtf5iy9","tag_id":"cka1y597r00144huuuuhayln8","_id":"cka1y5980001i4huutd2uvz1s"},{"post_id":"cka1y597o00124huu1wtf5iy9","tag_id":"cka1y597w001c4huulh745qk4","_id":"cka1y5982001l4huu83cl2dgs"},{"post_id":"cka1y597q00134huu98tdadd8","tag_id":"cka1y597z001g4huuaqzwp1zm","_id":"cka1y5986001o4huuxpz9siof"},{"post_id":"cka1y597q00134huu98tdadd8","tag_id":"cka1y596h000w4huu96c70yd8","_id":"cka1y5987001r4huu4eq0lqut"},{"post_id":"cka1y597t00164huuyti606sh","tag_id":"cka1y5983001m4huuufmyhgoa","_id":"cka1y5989001u4huumst1bdhn"},{"post_id":"cka1y5988001t4huux85puqey","tag_id":"cka1y594w00074huuttkx39vr","_id":"cka1y598b001x4huuvtlgi297"},{"post_id":"cka1y598a001v4huunsgdb908","tag_id":"cka1y594w00074huuttkx39vr","_id":"cka1y598d00204huuqyf5kwkk"},{"post_id":"cka1y598a001v4huunsgdb908","tag_id":"cka1y5983001m4huuufmyhgoa","_id":"cka1y598f00244huu61bh68rw"},{"post_id":"cka1y597u001a4huuspnhsflr","tag_id":"cka1y5987001s4huudyci9yx0","_id":"cka1y598g00284huu6fa44eml"},{"post_id":"cka1y598b001y4huuppnodfz2","tag_id":"cka1y594w00074huuttkx39vr","_id":"cka1y598h002b4huu2q6wen8j"},{"post_id":"cka1y598d00214huuioh2rw8e","tag_id":"cka1y5987001s4huudyci9yx0","_id":"cka1y598j002g4huum7z8unxb"},{"post_id":"cka1y597w001d4huu070sswhu","tag_id":"cka1y5983001m4huuufmyhgoa","_id":"cka1y598n002i4huu4w25jlcw"},{"post_id":"cka1y597x001e4huuv3ebsp4j","tag_id":"cka1y5987001s4huudyci9yx0","_id":"cka1y598q002n4huudhcmzd8l"},{"post_id":"cka1y597z001h4huur126uc0a","tag_id":"cka1y5987001s4huudyci9yx0","_id":"cka1y598r002q4huu534ex9n3"},{"post_id":"cka1y5981001j4huuk1yz6awj","tag_id":"cka1y5987001s4huudyci9yx0","_id":"cka1y598t002v4huupck4woiq"},{"post_id":"cka1y5983001n4huuemw79ybo","tag_id":"cka1y5987001s4huudyci9yx0","_id":"cka1y598w00304huuo1c12ur3"},{"post_id":"cka1y5986001p4huuxt1btjua","tag_id":"cka1y5987001s4huudyci9yx0","_id":"cka1y598y00354huuzezeifpl"},{"post_id":"cka1y598f00254huufdsy7udi","tag_id":"cka1y598x00334huu7wbssbi7","_id":"cka1y598z003a4huuxhbpr7nd"},{"post_id":"cka1y598g00294huuytpjchoh","tag_id":"cka1y598z00384huu1rilsu1z","_id":"cka1y5991003f4huupklqu83q"},{"post_id":"cka1y598i002d4huu06onppzf","tag_id":"cka1y598x00334huu7wbssbi7","_id":"cka1y5994003k4huu5xvxb95n"},{"post_id":"cka1y598k002h4huuc3fgsb7o","tag_id":"cka1y598x00334huu7wbssbi7","_id":"cka1y5997003p4huuyeqchn46"},{"post_id":"cka1y598o002l4huuoby01avt","tag_id":"cka1y598x00334huu7wbssbi7","_id":"cka1y5999003u4huuuqsut2y0"},{"post_id":"cka1y598q002p4huudjt7uk0a","tag_id":"cka1y598x00334huu7wbssbi7","_id":"cka1y599a003y4huuwn5y4qut"},{"post_id":"cka1y599o004i4huuvxxo90p7","tag_id":"cka1y5987001s4huudyci9yx0","_id":"cka1y599q004k4huuco1uino6"},{"post_id":"cka1y599p004j4huucopvbcs0","tag_id":"cka1y5987001s4huudyci9yx0","_id":"cka1y599r004m4huukspe62yo"},{"post_id":"cka1y599q004l4huuz9r1vgbn","tag_id":"cka1y5987001s4huudyci9yx0","_id":"cka1y599s004o4huu1v1cjhvs"},{"post_id":"cka1y59a2004u4huur56brcea","tag_id":"cka1y594w00074huuttkx39vr","_id":"cka1y59a4004v4huufjih59wt"},{"post_id":"ckr9qy9q80000g9shy5e4v2m1","tag_id":"cka1y594w00074huuttkx39vr","_id":"ckr9qy9qn0001g9shqbgixb6q"}],"Tag":[{"name":"Hexo","_id":"cka1y594w00074huuttkx39vr"},{"name":"影视","_id":"cka1y5954000c4huurnts5s23"},{"name":"历史政治","_id":"cka1y5956000h4huujc504cfl"},{"name":"工作","_id":"cka1y595a000l4huu5t4fsi8t"},{"name":"成长","_id":"cka1y596h000w4huu96c70yd8"},{"name":"经济","_id":"cka1y596i000y4huu4e1c2vta"},{"name":"哲理","_id":"cka1y597r00144huuuuhayln8"},{"name":"书籍","_id":"cka1y597w001c4huulh745qk4"},{"name":"心理","_id":"cka1y597z001g4huuaqzwp1zm"},{"name":"Mac","_id":"cka1y5983001m4huuufmyhgoa"},{"name":"工具","_id":"cka1y5987001s4huudyci9yx0"},{"name":"文学","_id":"cka1y598x00334huu7wbssbi7"},{"name":"娱乐","_id":"cka1y598z00384huu1rilsu1z"}]}} \ No newline at end of file diff --git a/docs/Editor-Skills-Summary.html b/docs/Editor-Skills-Summary.html index 9f34665..e69de29 100644 --- a/docs/Editor-Skills-Summary.html +++ b/docs/Editor-Skills-Summary.html @@ -1,581 +0,0 @@ - - - - - - 编辑器工具使用技巧汇总 | 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
- - -
- - - - -
-
- - -
- - - - - -

- 编辑器工具使用技巧汇总 -

- - -
- - -
- - - -
- 文章目录 -
  1. 1. VSCode
  2. 2. Typora
    1. 2.1. 个性化快捷键
    2. 2.2. 更改风格
    3. 2.3. 文本搜索
-
- - - -

VSCode

-
    -
  1. Wechseln zwischen Text-Editor und Terminal -
      -
    1. Command+K+S oder in Menü Code->Pereferenc->Hotky, öffnet Hot-Key Editor Fenster.
    2. -
    3. Tip terminal in Suchfeld, findet die Binding `^``, löscht diese Einstellung.
    4. -
    5. Sucht den “workbench.action.terminal.focus”, bindet es mit Key ⌃<.
    6. -
    7. Sucht den “workbench.action.focusActiveEditorGroup”, bindet es wiederum mit Schlüssel ⌃<, und Wenn-Kondition “terminalFocus”.
    8. -
    -
  2. -
- -

Typora

-

更多更详细的内容请参阅 Typora Wiki

-

Typora Wiki (wiki-website Project)

-

个性化快捷键

-

Windows

-

文件—>偏好设置—>往高级设置 ,点击看到两个json格式的文件,打开第二个(conf.user.json), 用记事本打开,第17行keyBinding,在大括号中写 代码块:“你要设置的快捷键”,比如我的是代码块:Ctrl+Alt+P,保存文件,重启typora即可生效。更详细介绍

-
1
2
3
4
5
6
7
8
// Custom key binding, which will override the default ones.
"keyBinding": {
// for example:
// "Always on Top": "Ctrl+Shift+P"
"注释":"Ctrl+Alt+/",
"代码块":"Ctrl+Alt+P",
"打开文件夹…":"Ctrl+Alt+O"
},
-

Mac

-

官方说明

-

需要到系统偏好设置—>键盘-->快捷键-->应用快捷键那边设置。找到 Typora.App,菜单名称填 代码,然后输入希望的快捷键。我的设置是⌃+⌘+C

-

更改风格

-

开发好的工具 如何客制化格式

-

简单使用:添加 base.user.css 文件,并改变行内代码的颜色,以及公式颜色

-
1
2
3
4
5
6
7
8
9
# 行内代码
code {
color: red
}

# 行内公式
.MathJax_SVG{
color: DarkBlue;
}
-

Typora的代码使用 CodeMirror 项目,尝试了一下修改 base.user.css 文件确实可以改变代码段的高度,并带滚动。但同时也限定了进行代码编辑时的整个窗口高度。所以没有用

-
1
2
3
4
5
6
7
8
9
# 缺点:打开源代码模式的时候,整个页面也被限制成了只有300px
.CodeMirror {
max-height: 300px;
}
.CodeMirror-scroll {
overflow-y: auto;
overflow-x: auto;
max-height: 300px;
}
-

注意到书写模式的时候,整个编辑器都被包裹在 <div id="write"> </div> 里面。在源代码模式的时候,没有这个 write 元素的包裹,而整个源代码窗口都被作用为一个 CodeMirror 元素对待。因此,作一些改变就能满足要求

-
1
2
3
4
5
6
7
8
9
10
11
#write .CodeMirror {
max-height: 350px;
}
# 设定上下 padding 会让滚动条在小代码区消失
#write .CodeMirror-scroll {
overflow-y: auto;
overflow-x: auto;
max-height: 330px;
padding-top: 10px;
padding-bottom: 10px;
}
-
1
# 避免只有一行的代码区,因为会显示滚动条,不好看。一行代码就用行内代码好了。
-

如果要限制来自 GistHub 的代码高度,只能限定其父元素 iframe

-
1
2
3
iframe {
max-height: 500px;
}
-

Windows版的 Typora 的数学模块保存在 path/resource/app/lib.asar 压缩文件中。需要用asar解压

-

如何查看 asar 内部结构

-

asar 如何加密解密

-
1
2
3
npm install -g asar
asar extract 压缩文件 解压文件夹
asar pack 文件夹 压缩文件名
-

文本搜索

-

打开的单篇文章内搜索:

-
-

Windows Control + F

-

Mac ⌘+F

-
-

文件夹内的搜索

-
-

Windows Control + Shift + F

-

Mac ⇧+⌘+F

-
- -
- -
-
-
-
- - - - - - - - - - - -
-
- -
-
- - - - - - - -
-
-
-
- -
-
- - - - - - - - - - - - - - - - - - - - - - - - - - - - -
- - - - \ No newline at end of file diff --git a/docs/TypeScript-build-JS-Package.html b/docs/TypeScript-build-JS-Package.html index 24c3050..e69de29 100644 --- a/docs/TypeScript-build-JS-Package.html +++ b/docs/TypeScript-build-JS-Package.html @@ -1,686 +0,0 @@ - - - - - - 用TypeScript编写JS函数库 | 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
- - -
- - - - -
-
- - -
- - - - - -

- 用TypeScript编写JS函数库 -

- - -
- - -
- - - -
- 文章目录 -
  1. 1. 安装 TypeScript
  2. 2. 创建工程
  3. 3. 调用JavaScript文件
  4. 4. Unit-Test
    1. 4.1. 错误处理
  5. 5. 打包
-
- - - -

本文具体介绍如何用TypeScript编写JavaScript库文件,以及制作npm工具包。主要参考下面两篇文章。我也省却一步步解释,只罗列相关的代码和我遇到的坑。想知道代码含义的请参阅原帖

- - -

安装 TypeScript

-

终端执行 npm install typescript -g

-
1
2
$ tsc --version
Version 3.5.3
-

创建工程

-
    -
  1. 初始化项目
  2. -
-
1
2
mkdir typescript_demo && cd typescript_demo
npm init -y # 初始化项目,会生成 package.json 文件
-
    -
  1. 安装Gulp, 并在项目根目录下新建 gulpfile.js 文件
  2. -
-
1
npm install gulp-cli gulp typescript gulp-typescript --save-dev
-
    -
  1. -

    在命令行中执行 tsc --init 可以在当前目录中快速创建一个 tsconfig.json 文件。

    -
  2. -
  3. -

    安装 Browserify :目的是把所有ts文件打包成一个单一的js文件。

    -
  4. -
-
1
npm install browserify tsify vinyl-source-stream --save-dev
-
    -
  1. Watchify、Babel和Uglify :目的是让编译器保持运行,无需每次修改手动编译。
  2. -
-

npm install watchify gulp-util --save-dev

-
1
npm install watchify gulp-util --save-dev
-
    -
  1. 安装 Uglify : 将输出文件 bundle.js 压缩
  2. -
-
1
npm install gulp-uglify vinyl-buffer gulp-sourcemaps --save-dev
-
    -
  1. Babel :允许按新标准ES6编写代码,而最终会编译es05标准,兼容低版本浏览器。
  2. -
-
1
npm install babelify babel-core babel-preset-env vinyl-buffer gulp-sourcemaps --save-dev
-

:bangbang: 安装中出现了错误, 显示babelify 版本太低. 将命令改为 npm install babelify@8 就能顺利进行下去了.

-
    -
  1. -

    编写主文件 src/main.ts (名字随便起),在 package.json 中改为 $ “main”: “./dist/main.js”, $。创建两文件夹 srcdist,分别放置原文件和编译后的文件。为演示调用,再新建一个 src/greet.ts 文件

    -
    1
    2
    3
    4
    5
    6
    7
    # src/greet.ts
    declare function require(path: string): any;

    export function sayHello(name: string) {
    console.log(ln)
    return `Hallo von ${name}`;
    }
    -
    1
    2
    3
    4
    5
    6
    7
    8
    9
    # src/main.ts
    import { sayHello } from "./greet";

    function showHello(idName: string, name: string) {
    const elt = document.getElementById(idName);
    elt.innerText = sayHello(name);
    }

    showHello("greeting", "TypeScript");
    -
  2. -
  3. -

    新建 src/index.html

    -
  4. -
-
1
2
3
4
5
6
7
8
9
10
11
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8" />
<title>Hello World!</title>
</head>
<body>
<p id="greeting">Loading ...</p>
<script src="bundle.js"></script>
</body>
</html>
-
    -
  1. 修改 gulpfile.js
  2. -
-
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
const gulp = require("gulp");
const browserify = require("browserify");
const source = require('vinyl-source-stream');
const tsify = require("tsify");
const watchify = require("watchify");
const gutil = require("gulp-util");
const uglify = require('gulp-uglify');
const sourcemaps = require('gulp-sourcemaps');
const buffer = require('vinyl-buffer');
const paths = {
pages: ['src/*.html']
};

const watchedBrowserify = watchify(browserify({
basedir: '.',
debug: true,
entries: ['src/main.ts'],
cache: {},
packageCache: {}
}).plugin(tsify));

gulp.task("copy-html", function () {
return gulp.src(paths.pages)
.pipe(gulp.dest("dist"));
})

function browserifyBundle() {
return watchedBrowserify
.transform('babelify', {
presets: ['env'],
extensions: ['.ts']
})
.bundle()
.pipe(source('bundle.js'))
.pipe(buffer())
.pipe(sourcemaps.init({
loadMaps: true
}))
.pipe(uglify())
.pipe(sourcemaps.write('./'))
.pipe(gulp.dest("dist"));
}

gulp.task("browserify", function () {
return browserifyBundle();
})

gulp.task("default", gulp.series('copy-html', 'browserify'));
watchedBrowserify.on("update", browserifyBundle);
watchedBrowserify.on("log", gutil.log);
-
    -
  1. -

    修改 tsconfig.json

    -
    1
    2
    3
    4
    5
    6
    7
    8
    9
    {
    "files": [
    "src/*.ts"
    ],
    "compilerOptions": {
    "noImplicitAny": true,
    "target": "es2015"
    }
    }
    -
  2. -
  3. -

    编译并在浏览器打开 dist/index.html

    -
  4. -
-
1
2
# 通过gulp编译代码
npx gulp
-
-

显示器中会显示 “Hello from TypeScript” 字样。

-
-

我们看到 main.ts 调用了 greet.ts 的函数, 并生成一个 bundle.js 文件, 在 index.html 中被加载使用.

-

调用JavaScript文件

-

为了使用以前已经存在的JavaScript库文件, 在 src 下新建一个文件夹 libs 用来存放第三方JavaScript.

-
-

projectRoot
-├── src/
-│ ├── libs/
-│ │ ├── lunar.js
-│ ├── main.ts
-│ └── greet.ts
-│
-├── dist/
-└── tsconfig.json

-
-
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
# src/libs/lunar.js

Lunar = {
Name: "Dick",
sayHallo:function(){
return 'i am Lunar';
}
}

function Ab () {
this.a = 1
}

Ab.prototype.seta = function (num) {
this.a = num
}

Ab.prototype.geta = function (num) {
return this.a
}

exports.Ab = Ab
exports.Lunar = Lunar;
-

修改 greet.ts 文件, 调用 src/libs/lunar.js 中的函数和对象

-
1
2
3
4
5
6
7
8
9
declare function require(path: string): any;

var ln = require("./libs/lunar");

export function sayHello(name: string) {
ln.Ab = 10
console.log(ln.Ab)
return `Hallo von ${name}, ${ln.Lunar.Name}`;
}
-

TypeScript使用tsconfig.json文件管理工程配置,例如想包含哪些文件和进行哪些检查。

-
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
{
"compilerOptions": {
"noImplicitAny": true,
//"outDir": "./dist", //不需要. gulpfile.js 已经处理过了
"allowJs": true,
"target": "es2015",
"esModuleInterop": true /* Enables emit interoperability between CommonJS and ES Modules via creation of namespace objects for all imports. Implies 'allowSyntheticDefaultImports'. */
},
"files": [
"src/*.ts"
],
"include": [
"./src/**/*.js"
]
}
-

我们看到网页显示 Hallo von TypeScript, Dick, 打开chrome的开发者工具, 看到console 中写出 10.

-

Unit-Test

-

参考:Unit testing node applications with Typescript – using nocha and chai

-
    -
  1. 安装测试包文件
  2. -
-
1
npm install chai mocha ts-node @types/chai @types/mocha --save-dev
-
    -
  1. 新建一个test目录专门存放测试文件,并新建一个测试文件 test/ganzhi.spec.ts
  2. -
-
1
2
3
4
5
6
7
8
9
10
11
import { expect } from 'chai';
import 'mocha';

describe('干支 function', () => {

it('should return hello world', () => {
const result = 'Hello world!';
expect(result).to.equal('Hello world!');
});

});
-
    -
  1. package.json 文件中配置测试参数和路径
  2. -
-
1
2
3
4
5
{
"scripts": {
"test": "mocha -r ts-node/register test/**/*.spec.ts"
}
}
-
    -
  1. 运行测试
  2. -
-
-

$ npm run test

-

> huahets@1.0.0 test /Users/mai/Projects/huahets

-

> mocha -r ts-node/register test/**/*.spec.ts

-

干支 function

-

​ ✓ should return hello world

-

1 passing (19ms)

-
-

错误处理

-

假设有以下函数调用中LandMaps.FindCity会给出一个异常。

-
1
2
3
var result = LandMaps.FindCity("xx省", "xx市");
expect(LandMaps.FindCity.bind(LandMaps, "err", "")).throw("Error Message") # 或者
expect(LandMaps.FindCity.bind(LandMaps, "err", "")).throw(new Error("Error Message"))
-

打包

-

用 TypeScript 编写函数库

-

require.js 官方文档

-

通过上述方式生成的 bundle.js 文件不能被浏览器直接使用。参考上面两个网页提供的方式,可以生成给浏览器用的单一js文件。

-
    -
  1. 新建一个入口文件,将所有接口都连接起来,并统一导出
  2. -
-
1
2
3
4
5
6
7
8
9
10
11
# yixue.ts
import {TYDate, TYLunar} from "./tylunar";
import {GanZhi} from "./ganzhi";
import {ShenSha} from "./shensha";
import {WuXing, FetchWuXing} from "./wuxing";
import {Gua} from './gua'
import {LandMaps} from "./landmaps"

exports.GanZhi = GanZhi
exports.TYDate = TYDate
exports.Gua = Gua
-
    -
  1. 设置tsconfig.json让编译后的文件导出到dist/cmjs目录
  2. -
-
1
2
3
4
5
6
7
8
9
10
11
12
{
"compilerOptions": {
"target": "es5",
"module": "commonjs",
"moduleResolution": "node",
"outDir": "dist/cmjs",
"rootDir": "./src",
"declaration": true,
"sourceMap": true,
"lib": ["dom", "es6"]
}
}
-
    -
  1. 通过命令 tsc 编译
  2. -
-
1
tsc -P tsconfig.json
-

也可以在 package.json 中设定,然后运行 npm run build:cmjs 编译。编译后的 yixue.js 文件就是统一入口。

-
    -
  1. yi xue.js 实际就是个目录,我需要将其打包成一个单一文件。 安装 browserify ,
  2. -
-
1
browserify dist/cmjs/base/yixue.js --standalone huahejs -o dist/web/yixue.js
-
    -
  1. 下载 require.js, 并放到项目目录中。以下方式将 yixue.js 中的 class GanZhi 设为当前网页的一个全局函数。其它函数就可以调用。
  2. -
-
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8" />
<title>易学包</title>
<script type="text/javascript"
src="libs/require.js"></script>
<body >
<p id="greeting">易学包测试</p>
<script>
var newGanZhi

requirejs(["web/yixue"], function(yixue) {
console.log(yixue)
newGanZhi = function(arg){
return new yixue.GanZhi(arg)
}

init()
});

function init(){
console.log("init will be called")
var ele = document.getElementById("gz1")
var gz = newGanZhi(1)
ele.innerText = gz.Name
}
</script>

<div id="gz1"></div>
<div name="gua">gua</div>
</body>
</html>
-
    -
  1. -

    在 Node.js 中调用更简单

    -
  2. -
  3. -
    1
    const {Gua, GanZhi, TYDate} = require("./web/yixue")
    -
  4. -
-

需要更详细代码请下载项目:

-

演示项目地址

- -
- -
-
-
-
- - - - - - - - - - - -
-
- -
-
- - - - - - - -
-
-
-
- -
-
- - - - - - - - - - - - - - - - - - - - - - - - - - - - -
- - - - \ No newline at end of file diff --git a/docs/about-jianguoyu.html b/docs/about-jianguoyu.html index d4e9f93..e69de29 100644 --- a/docs/about-jianguoyu.html +++ b/docs/about-jianguoyu.html @@ -1,549 +0,0 @@ - - - - - - 坚果云有关 | 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
- - -
- - - - -
-
- - -
- - - - - -

- 坚果云有关 -

- - -
- - -
- - - -
- 文章目录 -
  1. 1. 忽略文件
  2. 2. 安卓系统上同步文件夹
  3. 3. 托管密码
-
- - - -
忽略文件
-

配置文件 customExtRules.conf。在 Window 版可以在软件直接打开,在 Mac App 里面没有这个选项,要自行查找这个配置文件。官方说明

-
-

在 Windows 和 Mac 下面目录可能不一样。

-
- -

Mac 系统或 Linux 系统这个文件通常位于

-
1
2
vim ~/.nutstore/db/customExtRules.conf
fold/to/ignore # 文件夹的绝对路径
-
安卓系统上同步文件夹
-

安卓版的坚果云客户端只会打开临时指定的文件。如果希望跟在PC上一样的操作,将整个文件库都同步到指定的文件夹内,就要用FolderSync软件。

-

登陆坚果云官网,账户信息–>安全选项–>第三方应用管理,生成一个新的第三方应用 androidSync,密码为 xxxxxxxxxxxxxxxx,然后按照上述官网的指南一步一步配置 FolderSync 就可以了。回头还是用 「坚果云 Markdown」这款软件来阅读md文档。

-
托管密码
-

设置为 SafeInClound 的托管云盘。用户名是坚果云的登陆账户,密码为专门为其开通的第三方应用 mypass 的专门密码。Local Pfad 填写云盘内存储数据库文件的文件夹。

-

- -
- -
-
-
-
- - - - - - - - - - - -
-
- -
-
- - - - - - - -
-
-
-
- -
-
- - - - - - - - - - - - - - - - - - - - - - - - - - - - -
- - - - \ No newline at end of file diff --git a/docs/about/index.html b/docs/about/index.html index 7110ecf..e69de29 100644 --- a/docs/about/index.html +++ b/docs/about/index.html @@ -1,473 +0,0 @@ - - - - - - 关于本站 | 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
- - -
- - - - -
-
- - -
- - - -

- 关于本站 -

- - -
- - -
- - - - - -

自从过上了极简生活,家务变得很少。对于一个巨蟹座的中年大叔,整理笔记成了我主要的挥洒精力的地方。我是笔记App的重度用户,用了两年的印象笔记,然后又五年的为知笔记,乃至尝试了新生人类惊为天人的熊掌记、Notion、等等。仍然感觉各种不爽。自从有了Hexo,终于可以定下心来,专心做笔记了。

-

作为不是处女座的强迫症患者,我把自己的这个笔记库部署到了两个不同的站点。内容基本一样,组织方式十分不同。

-

完整个人维基

-

心情版的博客

- -
- -
-
-
-
- - - - - - - - - -
-
- -
-
- - - - - - - -
-
-
-
- -
-
- - - - - - - - - - - - - - - - - - - - - - - - - - - - -
- - - - \ No newline at end of file diff --git a/docs/archives/2019/06/index.html b/docs/archives/2019/06/index.html index 2672925..e69de29 100644 --- a/docs/archives/2019/06/index.html +++ b/docs/archives/2019/06/index.html @@ -1,465 +0,0 @@ - - - - - - 归档: 2019/6 | 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
- - -
- - - - -
- -
- -

2019

-
- -
- -

2019-061

-
- -
- -
- - -

- Hello World -

- - - - - -
-
- -
-
-
-
-
- -
-
- - - - - - - - - - - - - - - - - - - - - - - - - - - - -
- - - - \ No newline at end of file diff --git a/docs/archives/2019/07/index.html b/docs/archives/2019/07/index.html index 24cf5d5..e69de29 100644 --- a/docs/archives/2019/07/index.html +++ b/docs/archives/2019/07/index.html @@ -1,811 +0,0 @@ - - - - - - 归档: 2019/7 | 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
- - -
- - - - -
- -
- -

2019

-
- -
- -

2019-0710

-
- -
- -
- - -

- 有用的Shell命令 -

- - - - - -
-
- -
- -
- - -

- Hexo日常管理 -

- - - - - -
-
- -
- -
- - -

- 佛偈集合 -

- - - - - -
-
- -
- -
- - -

- 简短书摘 -

- - - - - -
-
- -
- -
- - -

- 零散句子 -

- - - - - -
-
- -
- -
- - -

- 典故 -

- - - - - -
-
- -
- -
- - -

- 搞笑段子 -

- - - - - -
-
- -
- -
- - -

- 缠中说禅 -

- - - - - -
-
- -
- -
- - -

- 名人语录 -

- - - - - -
-
- -
- -
- - -

- 如何系统化管理Hexo博客 -

- - - - - -
-
- -
- - -
-
-
-
- -
-
- - - - - - - - - - - - - - - - - - - - - - - - - - - - -
- - - - \ No newline at end of file diff --git a/docs/archives/2019/07/page/2/index.html b/docs/archives/2019/07/page/2/index.html index deddefe..e69de29 100644 --- a/docs/archives/2019/07/page/2/index.html +++ b/docs/archives/2019/07/page/2/index.html @@ -1,811 +0,0 @@ - - - - - - 归档: 2019/7 | 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
- - -
- - - - -
- -
- -

2019

-
- -
- -

2019-0710

-
- -
- -
- - -

- 《驴得水》——影评 -

- - - - - -
-
- -
- -
- - -

- 编辑器工具使用技巧汇总 -

- - - - - -
-
- -
- -
- - -

- Ubuntu重设root用户密码 -

- - - - - -
-
- -
- -
- - -

- 搭建Hexo博客的流水账 -

- - - - - -
-
- -
- -
- - -

- 坚果云有关 -

- - - - - -
-
- -
- -
- - -

- 使用Github维护知识库 -

- - - - - -
-
- -
- -
- - -

- Next以及wikitten主题添加内容折叠 -

- - - - - -
-
- -
- -
- - -

- RZF Organisation -

- - - - - -
-
- -
- -
- - -

- Mac使用标签 -

- - - - - -
-
- -
- -
- - -

- Mac备忘录 -

- - - - - -
-
- -
- - -
-
-
-
- -
-
- - - - - - - - - - - - - - - - - - - - - - - - - - - - -
- - - - \ No newline at end of file diff --git a/docs/archives/2019/07/page/3/index.html b/docs/archives/2019/07/page/3/index.html index 154f1fc..e69de29 100644 --- a/docs/archives/2019/07/page/3/index.html +++ b/docs/archives/2019/07/page/3/index.html @@ -1,545 +0,0 @@ - - - - - - 归档: 2019/7 | 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
- - -
- - - - -
- -
- -

2019

-
- -
- -

2019-073

-
- -
- -
- - -

- 爱乐之城——影评 -

- - - - - -
-
- -
- -
- - -

- 财富自由之路-李笑来 -

- - - - - -
-
- -
- -
- - -

- 《少有人走的路》笔记 -

- - - - - -
-
- -
- - -
-
-
-
- -
-
- - - - - - - - - - - - - - - - - - - - - - - - - - - - -
- - - - \ No newline at end of file diff --git a/docs/archives/2019/08/index.html b/docs/archives/2019/08/index.html index 09303c9..e69de29 100644 --- a/docs/archives/2019/08/index.html +++ b/docs/archives/2019/08/index.html @@ -1,693 +0,0 @@ - - - - - - 归档: 2019/8 | 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
- - -
- - - - -
- -
- -

2019

-
- -
- -

2019-087

-
- -
- -
- - -

- MathJax用于易学领域 -

- - - - - -
-
- -
- -
- - -

- 用TypeScript编写JS函数库 -

- - - - - -
-
- -
- -
- - -

- 还在用七牛? -

- - - - - -
-
- -
- -
- - -

- Gitbook攻略 -

- - - - - -
-
- -
- -
- - -

- 配置服务器端MySQL -

- - - - - -
-
- -
- -
- - -

- 斯多葛主义手册 -

- - - - - -
-
- -
- -
- - -

- 同步Hexo文章与Mac上原笔记的分类和标签 -

- - - - - -
-
- -
-
-
-
-
- -
-
- - - - - - - - - - - - - - - - - - - - - - - - - - - - -
- - - - \ No newline at end of file diff --git a/docs/archives/2019/09/index.html b/docs/archives/2019/09/index.html index eb2fa48..e69de29 100644 --- a/docs/archives/2019/09/index.html +++ b/docs/archives/2019/09/index.html @@ -1,465 +0,0 @@ - - - - - - 归档: 2019/9 | 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
- - -
- - - - -
- -
- -

2019

-
- -
- -

2019-091

-
- -
- -
- - -

- JavaScript & Typescript技术摘要 -

- - - - - -
-
- -
-
-
-
-
- -
-
- - - - - - - - - - - - - - - - - - - - - - - - - - - - -
- - - - \ No newline at end of file diff --git a/docs/archives/2019/index.html b/docs/archives/2019/index.html index 3464a9e..e69de29 100644 --- a/docs/archives/2019/index.html +++ b/docs/archives/2019/index.html @@ -1,581 +0,0 @@ - - - - - - 归档: 2019 | 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
- - -
- - - - -
- -
- -

2019

-
- -
- -

2019-091

-
- -
- - -
- -
- -

2019-087

-
- -
- -
- - -

- MathJax用于易学领域 -

- - - -
-
- -
- -
- - -

- 用TypeScript编写JS函数库 -

- - - -
-
- -
- -
- - -

- 还在用七牛? -

- - - -
-
- -
- -
- - -

- Gitbook攻略 -

- - - -
-
- -
- -
- - -

- 配置服务器端MySQL -

- - - -
-
- -
- -
- - -

- 斯多葛主义手册 -

- - - -
-
- - - -
- -

2019-072

-
- -
- -
- - -

- 有用的Shell命令 -

- - - -
-
- -
- -
- - -

- Hexo日常管理 -

- - - -
-
- -
- - -
-
-
-
- -
-
- - - - - - - - - - - - - - - - - - - - - - - - - - - - -
- - - - \ No newline at end of file diff --git a/docs/archives/2019/page/2/index.html b/docs/archives/2019/page/2/index.html index 6fb113a..e69de29 100644 --- a/docs/archives/2019/page/2/index.html +++ b/docs/archives/2019/page/2/index.html @@ -1,811 +0,0 @@ - - - - - - 归档: 2019 | 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
- - -
- - - - -
- -
- -

2019

-
- -
- -

2019-0710

-
- -
- -
- - -

- 佛偈集合 -

- - - - - -
-
- -
- -
- - -

- 简短书摘 -

- - - - - -
-
- -
- -
- - -

- 零散句子 -

- - - - - -
-
- -
- -
- - -

- 典故 -

- - - - - -
-
- -
- -
- - -

- 搞笑段子 -

- - - - - -
-
- -
- -
- - -

- 缠中说禅 -

- - - - - -
-
- -
- -
- - -

- 名人语录 -

- - - - - -
-
- -
- -
- - -

- 如何系统化管理Hexo博客 -

- - - - - -
-
- -
- -
- - -

- 《驴得水》——影评 -

- - - - - -
-
- -
- -
- - -

- 编辑器工具使用技巧汇总 -

- - - - - -
-
- -
- - -
-
-
-
- -
-
- - - - - - - - - - - - - - - - - - - - - - - - - - - - -
- - - - \ No newline at end of file diff --git a/docs/archives/2019/page/3/index.html b/docs/archives/2019/page/3/index.html index 26c1b13..e69de29 100644 --- a/docs/archives/2019/page/3/index.html +++ b/docs/archives/2019/page/3/index.html @@ -1,811 +0,0 @@ - - - - - - 归档: 2019 | 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
- - -
- - - - -
- -
- -

2019

-
- -
- -

2019-0710

-
- -
- -
- - -

- Ubuntu重设root用户密码 -

- - - - - -
-
- -
- -
- - -

- 搭建Hexo博客的流水账 -

- - - - - -
-
- -
- -
- - -

- 坚果云有关 -

- - - - - -
-
- -
- -
- - -

- 使用Github维护知识库 -

- - - - - -
-
- -
- -
- - -

- Next以及wikitten主题添加内容折叠 -

- - - - - -
-
- -
- -
- - -

- RZF Organisation -

- - - - - -
-
- -
- -
- - -

- Mac使用标签 -

- - - - - -
-
- -
- -
- - -

- Mac备忘录 -

- - - - - -
-
- -
- -
- - -

- 爱乐之城——影评 -

- - - - - -
-
- -
- -
- - -

- 财富自由之路-李笑来 -

- - - - - -
-
- -
- - -
-
-
-
- -
-
- - - - - - - - - - - - - - - - - - - - - - - - - - - - -
- - - - \ No newline at end of file diff --git a/docs/archives/2019/page/4/index.html b/docs/archives/2019/page/4/index.html index 552bfb9..e69de29 100644 --- a/docs/archives/2019/page/4/index.html +++ b/docs/archives/2019/page/4/index.html @@ -1,464 +0,0 @@ - - - - - - 归档: 2019 | 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
- - -
- - - - -
- -
- -

2019

-
- -
- -

2019-071

-
- -
- -
- - -

- 《少有人走的路》笔记 -

- - - -
-
- -
- -

2019-061

-
- -
- -
- - -

- Hello World -

- - - -
-
- -
- - -
-
-
-
- -
-
- - - - - - - - - - - - - - - - - - - - - - - - - - - - -
- - - - \ No newline at end of file diff --git a/docs/archives/2021/07/index.html b/docs/archives/2021/07/index.html new file mode 100644 index 0000000..e69de29 diff --git a/docs/archives/2021/index.html b/docs/archives/2021/index.html new file mode 100644 index 0000000..e69de29 diff --git a/docs/archives/index.html b/docs/archives/index.html index 2886654..e69de29 100644 --- a/docs/archives/index.html +++ b/docs/archives/index.html @@ -1,581 +0,0 @@ - - - - - - 归档 | 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
- - -
- - - - -
- -
- -

2019

-
- -
- -

2019-091

-
- -
- - -
- -
- -

2019-087

-
- -
- -
- - -

- MathJax用于易学领域 -

- - - -
-
- -
- -
- - -

- 用TypeScript编写JS函数库 -

- - - -
-
- -
- -
- - -

- 还在用七牛? -

- - - -
-
- -
- -
- - -

- Gitbook攻略 -

- - - -
-
- -
- -
- - -

- 配置服务器端MySQL -

- - - -
-
- -
- -
- - -

- 斯多葛主义手册 -

- - - -
-
- - - -
- -

2019-072

-
- -
- -
- - -

- 有用的Shell命令 -

- - - -
-
- -
- -
- - -

- Hexo日常管理 -

- - - -
-
- -
- - -
-
-
-
- -
-
- - - - - - - - - - - - - - - - - - - - - - - - - - - - -
- - - - \ No newline at end of file diff --git a/docs/archives/page/2/index.html b/docs/archives/page/2/index.html index 59a9394..e69de29 100644 --- a/docs/archives/page/2/index.html +++ b/docs/archives/page/2/index.html @@ -1,811 +0,0 @@ - - - - - - 归档 | 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
- - -
- - - - -
- -
- -

2019

-
- -
- -

2019-0710

-
- -
- -
- - -

- 佛偈集合 -

- - - - - -
-
- -
- -
- - -

- 简短书摘 -

- - - - - -
-
- -
- -
- - -

- 零散句子 -

- - - - - -
-
- -
- -
- - -

- 典故 -

- - - - - -
-
- -
- -
- - -

- 搞笑段子 -

- - - - - -
-
- -
- -
- - -

- 缠中说禅 -

- - - - - -
-
- -
- -
- - -

- 名人语录 -

- - - - - -
-
- -
- -
- - -

- 如何系统化管理Hexo博客 -

- - - - - -
-
- -
- -
- - -

- 《驴得水》——影评 -

- - - - - -
-
- -
- -
- - -

- 编辑器工具使用技巧汇总 -

- - - - - -
-
- -
- - -
-
-
-
- -
-
- - - - - - - - - - - - - - - - - - - - - - - - - - - - -
- - - - \ No newline at end of file diff --git a/docs/archives/page/3/index.html b/docs/archives/page/3/index.html index 5782f82..e69de29 100644 --- a/docs/archives/page/3/index.html +++ b/docs/archives/page/3/index.html @@ -1,811 +0,0 @@ - - - - - - 归档 | 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
- - -
- - - - -
- -
- -

2019

-
- -
- -

2019-0710

-
- -
- -
- - -

- Ubuntu重设root用户密码 -

- - - - - -
-
- -
- -
- - -

- 搭建Hexo博客的流水账 -

- - - - - -
-
- -
- -
- - -

- 坚果云有关 -

- - - - - -
-
- -
- -
- - -

- 使用Github维护知识库 -

- - - - - -
-
- -
- -
- - -

- Next以及wikitten主题添加内容折叠 -

- - - - - -
-
- -
- -
- - -

- RZF Organisation -

- - - - - -
-
- -
- -
- - -

- Mac使用标签 -

- - - - - -
-
- -
- -
- - -

- Mac备忘录 -

- - - - - -
-
- -
- -
- - -

- 爱乐之城——影评 -

- - - - - -
-
- -
- -
- - -

- 财富自由之路-李笑来 -

- - - - - -
-
- -
- - -
-
-
-
- -
-
- - - - - - - - - - - - - - - - - - - - - - - - - - - - -
- - - - \ No newline at end of file diff --git a/docs/archives/page/4/index.html b/docs/archives/page/4/index.html index 2131318..e69de29 100644 --- a/docs/archives/page/4/index.html +++ b/docs/archives/page/4/index.html @@ -1,464 +0,0 @@ - - - - - - 归档 | 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
- - -
- - - - -
- -
- -

2019

-
- -
- -

2019-071

-
- -
- -
- - -

- 《少有人走的路》笔记 -

- - - -
-
- -
- -

2019-061

-
- -
- -
- - -

- Hello World -

- - - -
-
- -
- - -
-
-
-
- -
-
- - - - - - - - - - - - - - - - - - - - - - - - - - - - -
- - - - \ No newline at end of file diff --git a/docs/atom.xml b/docs/atom.xml index 65f3c8f..e69de29 100644 --- a/docs/atom.xml +++ b/docs/atom.xml @@ -1,560 +0,0 @@ - - - 天涯的维基 - - 竹影扫阶尘不动 雁过寒潭水无痕<br> 达摩九载面孤壁 起行归去影留存 - - - - 2019-09-16T18:53:45.000Z - http://maiernte.github.io/wiki/ - - - 鎏金天涯 - - - - Hexo - - - JavaScript & Typescript技术摘要 - - http://maiernte.github.io/wiki/javascript-typescript-skills.html - 2019-09-14T07:32:15.000Z - 2019-09-16T18:53:45.000Z - - Javasript 和 Typescript 的重要技巧。

零散知识点

Promise

输出链条

文档 Promises chaning

:pencil2: 可以在 then 函数里面跑出 结果 或者 第二个 Promise

等待多个 Promise
1
2
3
4
let p1 = promise1
let p2 = promise2
const promises = Promise.all([p1, p2])
return promises

声明以及定义扩展

*.d.ts 文件中声明类型

1
2
3
4
declare type Book = {
title: string,
comment?: string
}

对 JavaScript 的原型进行扩展, 在一个 TS 文件进行定义和实现

1
2
3
4
5
6
7
8
9
10
11
12
// ...path/common.ts
export {} // this will make it module
declare global {
interface String {
IsNullOrEmpty():boolean;
Latex(color?:string):string;
}
}

String.prototype.IsNullOrEmpty = function(){
return this == undefined || this == null || this == ""
}

在需要的地方引用

1
2
3
4
import '..path/common';

let str = ""
const is_it_empty = str.IsNullOrEmpty()

读取文本

Html5 标准按钮
1
<div type='file' (change)='LoadLocalFile($event)'></div>

Javascript 读取文本内容并转为数据库 (使用 sql.js)

1
2
3
4
5
6
7
8
9
10
11
12
13
14
LoadLocalFile(file) {
const fileurl: File = file.target.files[0];
const reader = new FileReader();
reader.onload = () => {
console.log('read file:', reader.result);
const buffer = reader.result;
const Uints = new Uint8Array(buffer as ArrayBuffer);
const db = new SQL.Database(Uints);
const nodes = db.exec('SELECT * From node');
console.log(nodes);
};

reader.readAsArrayBuffer(fileurl);
}
使用nix-file-helpers 插件

文档地址

演示地址

Html

1
2
3
4
5
<ion-button   ngxFilePicker #filePicker="ngxFilePicker" 
[readMode]="readMode"
(readStart)="onReadStart($event)"
(filePick)="onFilePicked($event)"
(readEnd)="onReadEnd($event)">导入案例</ion-button>

代码,读取文件

1
2
3
4
5
6
onFilePicked(file: ReadFile) {
const Uints = new Uint8Array(file.content as ArrayBuffer);
const db = new SQL.Database(Uints);
const nodes = db.exec('SELECT * From node');
console.log(nodes);
}

测试

引用第三方js文件

angular.json 文件的 test-->scripts 中添加需要引用的文件。

]]>
- - - - <p>Javasript 和 Typescript 的重要技巧。</p> - - - - - - - - - - -
- - - MathJax用于易学领域 - - http://maiernte.github.io/wiki/mathjax-yixue-usage.html - 2019-08-30T08:15:28.000Z - 2020-05-08T09:38:08.489Z - - 关于利用 MathJaxKatex 数学公式解释器,实现易学上排六爻盘和八字盘个功能。今天实现了易学上的核心功能。有望将来能添加更多的函数,以便利各位同门以及广大易友。

效果与演示

无法观看油管的朋友请移步B站:[使用MathJax渲染六爻和八字盘](https://www.bilibili.com/video/av66317810/)

安装和使用

首先,你需要一个支持 Markdown (简称MD) 语言格式的文本编辑器。如果不知道什么是MD的话,请参阅以下介绍:

Markdown 语言简约而优美,可以自由转换成pdf、word、Html 等等各种其它格式的文本。可以推送到博客、微信公众号等等。虽然算卦是一个传统的行业,我们仍然不宜固步自封。MD语言支持MathJax和Katex书写Latex数学公式,可以写出非常漂亮的数学、物理、化学方面的公式。正式的科技刊物都要求用Latex格式。

这个易学解决方案是对 MathJax 进行扩展,加入指定的易学公式,让 MathJax 解释器去完成公式渲染。它并不是一个独立的程序。需要构建在已有的MD文本编辑器之上。我使用一个文件夹存放所有的关于易学方面的MD文件,并将这个文件夹同步到 坚果云,这样就可以实现多台电脑和移动端之间的同步,而不太需要一个独立的易学软件。甚至可以将MD文件导出为HTML文件,放到我的HEXO博客上(您正在阅读的这篇博文即是例子)。

理论上所有支持Markdown语言和MathJax的文本编辑器,都可以改装。改装过程需要两段代码和一个库文件。

文本编辑器

Typora

Typora 是我个人最钟爱的MD编辑器,因此这里着重介绍。如果你喜欢用别的MD编辑器,比如iAWrte等,理论上可以用同样的方式改装。(无法百分百保证) 有需要的朋友可以私下联系我。

最新的安装教程请参考华鹤易学平台文档

VSCode

同样请移步华鹤易学平台文档。那里有详细描述。

Hexo博客

🔔 注意:首先要检查自己的 Hexo 博客使用的渲染器是否默认开启了Katex或者MathJax数学插件。如果有的话需要卸载或者禁用数学插件,如果不能禁用,就必须更换Markdown渲染器。

因为系统使用的数学插件会在网页生成之前就改动数学表达,这样无法使用我提供给的函数库。我提供给博客的方案是在浏览网页的时候,即时渲染易学公式。

比如我之前用了 “hexo-renderer-markdown-it-plus” 渲染器就是强制使用 Katex 数学渲染的。

1
2
npm un hexo-renderer-markdown-it-plus --save // 卸载
npm i hexo-renderer-markdown-it --save // 更换

然后将下列代码添加到文件模版就可以了。使用 swig 模版的是在 <your thems>/layout/_custom/header.swig 或者 <your thems>/layout/index.swig 。而使用 ejs 模版的是文件 <your thems>/layout/layout.ejs

1
2
3
4
5
6
7
8
9
<!--前三行最好添加到 <header></header> 头区块中-->

<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/katex@0.11.0/dist/katex.min.css" >
<script defer src="https://cdn.jsdelivr.net/npm/katex@0.11.0/dist/katex.min.js" ></script>
<script defer src="https://cdn.jsdelivr.net/npm/katex@0.11.0/dist/contrib/auto-render.min.js"></script>


<script src="https://raw.githack.com/maiernte/img/master/libs/katexYixue.js"></script>
<script src="https://raw.githack.com/maiernte/img/master/libs/bundle.js"></script>

注意搜索 _config.yml 文件,“math”, “katex”, “mathjax” 等字样,发现有的话把他们禁用。

Gitbook

最新的安装教程请参考华鹤易学平台文档

API 参数

使用易学函数库非常简单,在经过改装的Markdown编辑器中,输入易学公式,并用两个 $ 符号将公式前后围起来即可。MD语言一般默认两个 $ 符号之间的文本是数学公式,它会调用MathJax对公式进行渲染。否则,它会认为这是普通文本,而不会做任何动作。

易学通用

命令:纳音 \nayin{干支名称}

【干支名称】 :就是甲子、己卯等六十甲子。

例子1:\nayin{戊午} --> $\nayin{戊午}$

命令:干支日历 \timegz{时间参数}{年月日}

【时间参数】 :例如 2020-02-21。

【年月日】 :省略时默认为111,即显示年月日。0表示不显示,1表示显示。

例子1:\timegz{2020-02-21} --> $\timegz{2020-02-21}$

例子2:\timegz{2020-02-21}{011} --> $\timegz{2020-02-21}{011}$

六爻

命令:爻符 \yao{爻名}

【爻名】:laoyin, laoyang,shaoyin,shaoyang, x, o, =, -, 交,重,阴,阳,0,1,2,3

例子2:\yao{x} --> $\yao{x}$

例子3:\yao{shaoyin} --> $\yao{shaoyin}$

例子4:\yao{重} --> $\yao{重}$

命令:六爻排盘 \paigua{时令}{卦辞}{标识}

其中 【时令】、【卦辞】这两个参数是必须的,**【标识】**参数可以省略。

【时令】允许的格式为:“1980-1-3 08:15”、“2019年3月4日”、“申月戊寅日”

【卦辞】允许的格式为:“解之师”、“离为火”、“–==x-”、“0121100”、“阴阳阴交阴阳”

【标识】由三部分组成:ID号、简排、字符大小。格式为:guadi/s/5

  • 「ID号」:随便一串字符,空白则默认为“gua1”。:x:不允许只有数字,因为会与参数「字符大小」混淆。如果一个文本出现多个六爻卦,则每个卦都需要指定一个ID号。否则下面的命令卦爻细节不知道具体指向哪一个卦本。
  • 「简排」:只允许sl两个英文字符的其中一个。s 表示只显示短名,如“妻财”显示为“财”,“青龙”显示为“龙”。l 则显示完整名称。留白则按照用户全局设定来显示。(参阅用户设定
  • 「字符大小」:允许 0 - 9 档。数字越大文字越大。默认大小为5或者用户的全局设定

例子5: $\paigua{1978年7月1日}{101201}{gua1}$ 效果
$$\paigua{1978年7月1日}{101201}{gua1}$$

:pencil2: 如果文章很长,需要在指定位置重新显示一遍卦本,则可以使用重排命令。即让【时令】和【卦辞】两个参数留白,只给出【ID号】。如 \paigua{}{}{gua1} 。留白的参数,仍然需要用大括号括起来,否则解释器会出错。

命令:卦爻细节 \guayao{标识}{位置}

使用前提:当前文本中已经排出至少一支六爻卦。

【标识】:与排盘命令的「标识」参数等同。由ID号、简排、字符大小三个部分组成。其中「ID号」标识已经存在的六爻盘。

【位置】:格式为 “ben1”、“fu3”、“bian5” 等,分别表示「本卦初爻」、「伏卦3爻」、「变卦5爻」

例子6:\guayao{gua1}{ben4} --> $\guayao{gua1}{ben4}$

例子6 中给出的「ID号」为例子5中指定的ID号 “gua1”,并要求显示本卦4爻的具体信息。

八字

命令:八字排盘 \paibazi{时间}{性别}{标识}[细节]

【时间】和【性别】参数必填,【标识】和【细节】参数可选。(如果要第二次显示已有的八字盘,则【时间】和【性别】参数可留白,只给定【标识】参数中的「ID号」)

【时间】:允许格式 “1980-1-3 08:15”、“2019年3月4日 6时3分”

【性别】:允许格式 “m”、“f”、“男”、“女”、“乾”、“坤”、

【标识】:与排盘命令的「标识」参数等同。由ID号、简排、字符大小三个部分组成。

【细节】:允许“藏干”、“长生”、“纳音”这三个中的一个或者多个,也可以留白。格式为 藏干/纳音/长生

例子7:\paibazi{1990年5月1日 6:45}{男}{小明/s/5}

$\paibazi{1990年5月1日 6:45}{男}{小明/5}$

例子8:重排例子7的八字盘 \paibazi{}{}{小明/s/5}[纳音/藏干/长生] ,并要求显示藏干和纳音等信息。

$\paibazi{}{}{小明/s/5}[纳音/藏干/长生]$

命令:八字细节 \bazi{标识}{类别}[细节]

使用前提:当前文本中已经排出至少一个八字盘。

【标识】:与排盘命令的「标识」参数等同。由ID号、简排、字符大小三个部分组成。其中「ID号」标识已经存在的八字命盘。

【类别】:支持 “神煞”、“大运”、“流年”、“小运” 四个选项。

【细节】:具体含义视【类别】而定。

  • 类别为「神煞」时:「细节」为 1~ 9 的数字,表示每行列数。
  • 类别为「大运」时: 1-9 纳音/藏干/长生/神煞 前面的数字表示第几步大运,限定 1 到 10
  • 类别为「流年」和「小运」时: 2015 - 2019 纳音/藏干/长生/神煞 前面的数字表示年份,注意不要超过命盘的生命周期,否则会出错。「纳音/藏干/长生/神煞」可以留白,也可只显示一两项。

例子9: \bazi{小明}{神煞}[6] 显示小明命盘的神煞,每行6列。

$\bazi{小明}{神煞}[6]$

例子10: \bazi{小明}{大运}[2-3 ] 显示小明的第二到第三步大运

$\bazi{小明}{大运}[2-3]$

例子11: \bazi{小明}{流年}[2017-2019 纳音/藏干/长生/神煞] 显示小明的2017到2019年的流年信息。

$\bazi{小明}{流年}[2017-2019 纳音/藏干/长生/神煞]$

未来与展望

我知道这篇文章介绍的工具,并非所有人都能使用。所以在不久的将来,还是要制作一个独立易学软件,以便易友在PC端和移动端都能按照传统的方式使用。但由于时间和精力原因,我无法保证完成时间。

不断完善易学函数,提供更丰富的应用细节。在用户更为广泛的MD编辑器中实现此方式。比如有道云笔记、为知笔记、印象笔记等。并争取介绍移动端(Android & iOS)实现此方式。也希望在Gitbook中实现。

希望能将师父的六爻和八字讲义,『增删卜易』等著作制作成Gitbook,将精彩的卦例和名人八字建成易学数据库。这样就可以通过我的易学函数直接获取, 比如 \paibazi{蒋介石}

附录:

命令列表

纳音

爻符

排卦

卦爻细节

排八字

八字细节

发布

脚本文件的原始路径https://github.com/maiernte/img/raw/master/libs/bundle.js。因为涉及到跨域问题,要通过 Gitkack 重链接,把上述路径输入到 Githack 的地址框,会得到「应用地址」和「开发地址」。

应用地址

https://rawcdn.githack.com/maiernte/img/11a1bb572a6875dbf434a7fc457ea2fdd329f7db/libs/bundle.js

开发地址

https://raw.githack.com/maiernte/img/master/libs/bundle.js

查看当前易学函数库版本

在 chrome 浏览其中打开此博文,Mac 系统中按 ⌘+⌥+I ,Windows 系统 Ctr+⇧+I,或者 Chrome 菜单栏调出 “开发者工具”,选择 Console 页面,即可显示当前易学库版本和时间。

]]>
- - - - <p>关于利用 <code>MathJax</code> 和 <code>Katex</code> 数学公式解释器,实现易学上排六爻盘和八字盘个功能。今天实现了易学上的核心功能。有望将来能添加更多的函数,以便利各位同门以及广大易友。</p> - - - - - - - - - - -
- - - 用TypeScript编写JS函数库 - - http://maiernte.github.io/wiki/TypeScript-build-JS-Package.html - 2019-08-16T20:15:28.000Z - 2019-08-24T11:30:40.000Z - - 本文具体介绍如何用TypeScript编写JavaScript库文件,以及制作npm工具包。主要参考下面两篇文章。我也省却一步步解释,只罗列相关的代码和我遇到的坑。想知道代码含义的请参阅原帖

安装 TypeScript

终端执行 npm install typescript -g

1
2
$ tsc --version
Version 3.5.3

创建工程

  1. 初始化项目
1
2
mkdir typescript_demo && cd typescript_demo
npm init -y # 初始化项目,会生成 package.json 文件
  1. 安装Gulp, 并在项目根目录下新建 gulpfile.js 文件
1
npm install gulp-cli gulp typescript gulp-typescript --save-dev
  1. 在命令行中执行 tsc --init 可以在当前目录中快速创建一个 tsconfig.json 文件。

  2. 安装 Browserify :目的是把所有ts文件打包成一个单一的js文件。

1
npm install browserify tsify vinyl-source-stream --save-dev
  1. Watchify、Babel和Uglify :目的是让编译器保持运行,无需每次修改手动编译。

npm install watchify gulp-util --save-dev

1
npm install watchify gulp-util --save-dev
  1. 安装 Uglify : 将输出文件 bundle.js 压缩
1
npm install gulp-uglify vinyl-buffer gulp-sourcemaps --save-dev
  1. Babel :允许按新标准ES6编写代码,而最终会编译es05标准,兼容低版本浏览器。
1
npm install babelify babel-core babel-preset-env vinyl-buffer gulp-sourcemaps --save-dev

:bangbang: 安装中出现了错误, 显示babelify 版本太低. 将命令改为 npm install babelify@8 就能顺利进行下去了.

  1. 编写主文件 src/main.ts (名字随便起),在 package.json 中改为 $ “main”: “./dist/main.js”, $。创建两文件夹 srcdist,分别放置原文件和编译后的文件。为演示调用,再新建一个 src/greet.ts 文件

    1
    2
    3
    4
    5
    6
    7
    # src/greet.ts
    declare function require(path: string): any;

    export function sayHello(name: string) {
    console.log(ln)
    return `Hallo von ${name}`;
    }
    1
    2
    3
    4
    5
    6
    7
    8
    9
    # src/main.ts
    import { sayHello } from "./greet";

    function showHello(idName: string, name: string) {
    const elt = document.getElementById(idName);
    elt.innerText = sayHello(name);
    }

    showHello("greeting", "TypeScript");
  2. 新建 src/index.html

1
2
3
4
5
6
7
8
9
10
11
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8" />
<title>Hello World!</title>
</head>
<body>
<p id="greeting">Loading ...</p>
<script src="bundle.js"></script>
</body>
</html>
  1. 修改 gulpfile.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
const gulp = require("gulp");
const browserify = require("browserify");
const source = require('vinyl-source-stream');
const tsify = require("tsify");
const watchify = require("watchify");
const gutil = require("gulp-util");
const uglify = require('gulp-uglify');
const sourcemaps = require('gulp-sourcemaps');
const buffer = require('vinyl-buffer');
const paths = {
pages: ['src/*.html']
};

const watchedBrowserify = watchify(browserify({
basedir: '.',
debug: true,
entries: ['src/main.ts'],
cache: {},
packageCache: {}
}).plugin(tsify));

gulp.task("copy-html", function () {
return gulp.src(paths.pages)
.pipe(gulp.dest("dist"));
})

function browserifyBundle() {
return watchedBrowserify
.transform('babelify', {
presets: ['env'],
extensions: ['.ts']
})
.bundle()
.pipe(source('bundle.js'))
.pipe(buffer())
.pipe(sourcemaps.init({
loadMaps: true
}))
.pipe(uglify())
.pipe(sourcemaps.write('./'))
.pipe(gulp.dest("dist"));
}

gulp.task("browserify", function () {
return browserifyBundle();
})

gulp.task("default", gulp.series('copy-html', 'browserify'));
watchedBrowserify.on("update", browserifyBundle);
watchedBrowserify.on("log", gutil.log);
  1. 修改 tsconfig.json

    1
    2
    3
    4
    5
    6
    7
    8
    9
    {
    "files": [
    "src/*.ts"
    ],
    "compilerOptions": {
    "noImplicitAny": true,
    "target": "es2015"
    }
    }
  2. 编译并在浏览器打开 dist/index.html

1
2
# 通过gulp编译代码
npx gulp

显示器中会显示 “Hello from TypeScript” 字样。

我们看到 main.ts 调用了 greet.ts 的函数, 并生成一个 bundle.js 文件, 在 index.html 中被加载使用.

调用JavaScript文件

为了使用以前已经存在的JavaScript库文件, 在 src 下新建一个文件夹 libs 用来存放第三方JavaScript.

projectRoot
├── src/
│ ├── libs/
│ │ ├── lunar.js
│ ├── main.ts
│ └── greet.ts

├── dist/
└── tsconfig.json

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
# src/libs/lunar.js

Lunar = {
Name: "Dick",
sayHallo:function(){
return 'i am Lunar';
}
}

function Ab () {
this.a = 1
}

Ab.prototype.seta = function (num) {
this.a = num
}

Ab.prototype.geta = function (num) {
return this.a
}

exports.Ab = Ab
exports.Lunar = Lunar;

修改 greet.ts 文件, 调用 src/libs/lunar.js 中的函数和对象

1
2
3
4
5
6
7
8
9
declare function require(path: string): any;

var ln = require("./libs/lunar");

export function sayHello(name: string) {
ln.Ab = 10
console.log(ln.Ab)
return `Hallo von ${name}, ${ln.Lunar.Name}`;
}

TypeScript使用tsconfig.json文件管理工程配置,例如想包含哪些文件和进行哪些检查。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
{
"compilerOptions": {
"noImplicitAny": true,
//"outDir": "./dist", //不需要. gulpfile.js 已经处理过了
"allowJs": true,
"target": "es2015",
"esModuleInterop": true /* Enables emit interoperability between CommonJS and ES Modules via creation of namespace objects for all imports. Implies 'allowSyntheticDefaultImports'. */
},
"files": [
"src/*.ts"
],
"include": [
"./src/**/*.js"
]
}

我们看到网页显示 Hallo von TypeScript, Dick, 打开chrome的开发者工具, 看到console 中写出 10.

Unit-Test

参考:Unit testing node applications with Typescript – using nocha and chai

  1. 安装测试包文件
1
npm install chai mocha ts-node @types/chai @types/mocha --save-dev
  1. 新建一个test目录专门存放测试文件,并新建一个测试文件 test/ganzhi.spec.ts
1
2
3
4
5
6
7
8
9
10
11
import { expect } from 'chai';
import 'mocha';

describe('干支 function', () => {

it('should return hello world', () => {
const result = 'Hello world!';
expect(result).to.equal('Hello world!');
});

});
  1. package.json 文件中配置测试参数和路径
1
2
3
4
5
{
"scripts": {
"test": "mocha -r ts-node/register test/**/*.spec.ts"
}
}
  1. 运行测试

$ npm run test

> huahets@1.0.0 test /Users/mai/Projects/huahets

> mocha -r ts-node/register test/**/*.spec.ts

干支 function

​ ✓ should return hello world

1 passing (19ms)

错误处理

假设有以下函数调用中LandMaps.FindCity会给出一个异常。

1
2
3
var result = LandMaps.FindCity("xx省", "xx市");
expect(LandMaps.FindCity.bind(LandMaps, "err", "")).throw("Error Message") # 或者
expect(LandMaps.FindCity.bind(LandMaps, "err", "")).throw(new Error("Error Message"))

打包

用 TypeScript 编写函数库

require.js 官方文档

通过上述方式生成的 bundle.js 文件不能被浏览器直接使用。参考上面两个网页提供的方式,可以生成给浏览器用的单一js文件。

  1. 新建一个入口文件,将所有接口都连接起来,并统一导出
1
2
3
4
5
6
7
8
9
10
11
# yixue.ts
import {TYDate, TYLunar} from "./tylunar";
import {GanZhi} from "./ganzhi";
import {ShenSha} from "./shensha";
import {WuXing, FetchWuXing} from "./wuxing";
import {Gua} from './gua'
import {LandMaps} from "./landmaps"

exports.GanZhi = GanZhi
exports.TYDate = TYDate
exports.Gua = Gua
  1. 设置tsconfig.json让编译后的文件导出到dist/cmjs目录
1
2
3
4
5
6
7
8
9
10
11
12
{
"compilerOptions": {
"target": "es5",
"module": "commonjs",
"moduleResolution": "node",
"outDir": "dist/cmjs",
"rootDir": "./src",
"declaration": true,
"sourceMap": true,
"lib": ["dom", "es6"]
}
}
  1. 通过命令 tsc 编译
1
tsc -P tsconfig.json

也可以在 package.json 中设定,然后运行 npm run build:cmjs 编译。编译后的 yixue.js 文件就是统一入口。

  1. yi xue.js 实际就是个目录,我需要将其打包成一个单一文件。 安装 browserify ,
1
browserify dist/cmjs/base/yixue.js --standalone huahejs -o dist/web/yixue.js
  1. 下载 require.js, 并放到项目目录中。以下方式将 yixue.js 中的 class GanZhi 设为当前网页的一个全局函数。其它函数就可以调用。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8" />
<title>易学包</title>
<script type="text/javascript"
src="libs/require.js"></script>
<body >
<p id="greeting">易学包测试</p>
<script>
var newGanZhi

requirejs(["web/yixue"], function(yixue) {
console.log(yixue)
newGanZhi = function(arg){
return new yixue.GanZhi(arg)
}

init()
});

function init(){
console.log("init will be called")
var ele = document.getElementById("gz1")
var gz = newGanZhi(1)
ele.innerText = gz.Name
}
</script>

<div id="gz1"></div>
<div name="gua">gua</div>
</body>
</html>
  1. 在 Node.js 中调用更简单

  2. 1
    const {Gua, GanZhi, TYDate} = require("./web/yixue")

需要更详细代码请下载项目:

演示项目地址

]]>
- - - - <p>本文具体介绍如何用TypeScript编写JavaScript库文件,以及制作npm工具包。主要参考下面两篇文章。我也省却一步步解释,只罗列相关的代码和我遇到的坑。想知道代码含义的请参阅原帖</p> -<ul> -<li><a href="http://imzc.me/dev/2016/11/22/getting-start-with-typescript/" target="_blank" rel="noopener">TypeScript第一步</a></li> -<li><a href="https://www.gowhich.com/blog/869" target="_blank" rel="noopener">如何使用Gulp构建TypeScript</a></li> -<li><a href="https://zhongsp.gitbooks.io/typescript-handbook/doc/handbook/tutorials/Migrating%20from%20JavaScript.html" target="_blank" rel="noopener">从Javascript迁移到Typescript</a> <em>只看相关的那一章就可以</em></li> -</ul> - - - - - - - - - - -
- - - 还在用七牛? - - http://maiernte.github.io/wiki/still-using-qiniu.html - 2019-08-14T21:41:28.000Z - 2019-08-15T06:54:53.000Z - - 自从七牛换了服务条款,每个空间就只分配测试域名, 30天到期。想省钱的用户,必须每30天倒腾一次。如果忘记了,过了期限,据说图都找不回来。不想费那个劲的用户, 得绑定自己的域名。 这样不但增加费用,还要考虑到域名备案。 十分麻烦。

这是我弃用七牛的主要原因。 第二个原因就是——! 也许我人在国外的原因吧, 每次打开七牛的后台,刷好几遍都打不开对象存储的页面,只能用第三方软件进行上传下载,那样会相对好一些.

第三个原因是七牛的图床不能分目录存储。 当图片越积越多的时候,管理和查找起来非常麻烦。比如我昨天用Typora的Pandoc功能将一个Word技术文档转换成MD文件,一个文件就有100来张图。放在七牛得分好几页显示了。如果再想找别的图, 那得多费劲.

后来还是把心思用在了Github上。 在自己的账号下新开一个仓库, 然后在自己的本地电脑专建立一个文件夹, 用来存放MD文档或者博客中使用到的图片, 把这个专门的文件夹推送到新的仓库就完了! 相比七牛, Github还有不少优势:

  • 可以分多级目录存储
  • 传输速度快 !(可能国内慢吧, 但国内可以同样的思路, 放到 Coding 或者 CSDN 上 )
  • 免费
  • 不限流量

还要我说啥呢?

但引用Github图片, 要做一个小小的改动. 比如Github上一个图片的原始地址是:

https://github.com/maiernte/img/blob/master/books/ng-book2-71/image100.png

需要把其中的 blob 改成 raw, 变成

https://github.com/maiernte/img/raw/master/books/ng-book2-71/image100.png

自打有了Github这个神器, 可以跟七牛说再见! 再也不见!

]]>
- - - - <p>自从七牛换了服务条款,每个空间就只分配测试域名, 30天到期。想省钱的用户,必须每30天倒腾一次。如果忘记了,过了期限,据说图都找不回来。不想费那个劲的用户, 得绑定自己的域名。 这样不但增加费用,还要考虑到域名备案。 十分麻烦。</p> - - - - - - - - - - -
- - - Gitbook攻略 - - http://maiernte.github.io/wiki/gitbook_with_typora_gh-pages.html - 2019-08-14T21:02:14.000Z - 2019-08-15T09:46:18.000Z - - 本文为你介绍如何使用利用 Typora + gitbook-cli + Github Pages 书写Gitbook. 在本地用 Typora 书写 md 文件, 用 gitbook-cli 编译, 最后发布到 Github Pages 上.

安装

前提是已经安装了Node, 直接用npm包管理工具安装:

1
2
sudo npm install -g gitbook-cli
gitbook -V # 注意是大写V

CLI version: 2.3.2
GitBook version: 3.2.3

新建书籍

  1. 为新书建立一个根目录 mkdir pytho_finance

  2. 在该目录下执行(命令行下):gitbook init,之后会在该目录下产生2个文件,分别是README.md(书籍的介绍)和SUMMARY.md(书籍的目录结构)。

gitbook目录的写法

  1. 按照上图格式填写目录和文件, 然后再次执行 gitbook init , GitBook 会查找 SUMMARY.md 文件中描述的目录和文件,如果没有则会将其创建.

  2. 然后就可以预览书籍了 gitbook serve. 执行命令后会对 Markdown 格式的文档进行转换,默认转换为 html 格式,提示Serving book on http://localhost:4000,打开网址即可查看.

  3. 构建书籍

1
gitbook build

默认将生成的静态网站输出到 _book 目录。实际上,这一步也包含在 gitbook serve 里面,因为它们是 HTML,所以 GitBook 通过 Node.js 给你提供服务了。

build 命令可以指定路径, 或者指定端口, 或者生产 pdf , epub, mobi 等格式. 具体参考文章.

发布到Github Pages

1
2
3
4
5
git init
git remote add origin https://github.com/maiernte/gitbook_python_finance.git
git add .
git commit -m "new book"
git push -u origin master # 将源代码推送到master

在GitHub的仓库中新添一个 gh-pages 的Branch.

1
2
3
4
5
6
7
8
9
10
11
12
13
14
mkdir new_fold
cd new_fold
rm -rf . # 删除这个目录下所有文件, 注意那 .git 文件夹不能删除

# 在源代码目录中,也就是md文件的目录
gitbook build

# 将会产生一个 _book 目录
# 添加忽略, 以免下次推送的时候 _book 目录被推送.
echo "*~" > .gitignore
echo "_book" >> .gitignore
echo "/node_modules" >> .gitignore

cp -r _book/* path_to/new_fold

:pen: 忽略文件夹,windows下的测试是 /node_modules, 不加双引号。

进入新目录, 推送编译后的html 和 js 文件到 gh-pages 的分支中去.

1
2
3
4
cd path_to/new_fold
git add .
git commit -m "to gh-pages"
git push -u origin gh-pages

如此实现了将源代码保存到master, 将静态网站推送到gh-pages, 一个仓库搞定! 在浏览器输入仓库地址, 就可以看到自己的Gitbook. 比如我新书地址

https://maiernte.github.io/gitbook_python_finance/

更新和维护

因为master 和 gh-pages 上存放的是不同的文档,所以拉取的时候也有指定 branch

1
2
3
4
5
# 拉取源代码
git clone https://github.com/maiernte/gitbook_python_finance.git --branch master new_fold

# 拉取静态网站
git clone https://github.com/maiernte/gitbook_python_finance.git --branch gh-pages new_fold

个性化配置

在项目的根目录上添加一个 book.json 文件, 用来更全面的配置项目. 比如头文件, 插件等等.

1
2
3
4
5
6
7
8
9
10
11
12
{
"title": "使用Python处理金融数据",
"author": "鎏金天涯 <mai.yongfeng@gmail.com>",
"description": "使用Python处理金融数据的各种技术",
"generator": "site",
"plugins": ["mathjax"],
"links": {
"sidebar": {
"鎏金天涯个人博客": "http://goldentianya.pub"
}
}
}

数学插件

在上述文件添加了 "plugins": ["mathjax"], 并执行命令

1
gitbook install ./ # 会添加一堆 node_modules 包

更详细的配置请参阅官方文档.

目录插件

项目地址和文档

book.json 文件修改为 "plugins": ["mathjax", "page-toc" ], ​ 每一页的目录就会出现在右上角。

编译错误列表

版本

1
2
CLI version: 2.3.2
GitBook version: 3.2.3

sharing 插件出错

添加了 page-toc 插件后,gitbook serve 的时候总是出现错误。就算把文章改回原来的样子也无补于事。

info: 7 plugins are installed
info: loading plugin “livereload”… OK
info: loading plugin “highlight”… OK
info: loading plugin “search”… OK
info: loading plugin “lunr”… OK
info: loading plugin “sharing”… OK
info: loading plugin “fontsettings”… OK
info: loading plugin “theme-default”… OK
info: found 1 pages
info: found 0 asset files

Error: ENOENT: no such file or directory, stat ‘D:\f040371\git_book\plattform_finance_book\gitbook\gitbook-plugin-sharing\buttons.js’

解决方法

修改 C:\Users\f040371\.gitbook\versions\3.2.3\lib\output\website\copyPluginAssets.js 文件中的 112 行

copyPluginAssets.js

confirm: true 改为 confirm: false

参考文章:


使用GitBook和Typora写知识库

gitbook+git+typora 的使用过程

GitBook + Typora + Git 编写电子文档

Gitbook 发布到 Github Pages

]]>
- - - - <p>本文为你介绍如何使用利用 <strong>Typora + gitbook-cli + Github Pages</strong> 书写Gitbook. 在本地用 Typora 书写 md 文件, 用 gitbook-cli 编译, 最后发布到 Github Pages 上.</p> - - - - - - - - - - -
- - - 配置服务器端MySQL - - http://maiernte.github.io/wiki/config-mysql-access-privileges-on-vps.html - 2019-08-06T15:26:28.000Z - 2019-08-14T13:10:45.000Z - - 文章

问题一:端口状态
  1. 查看 3306 端口状态 sudo netstat -an | grep 3306

tcp 0 0 127.0.0.1:3306 0.0.0.0:*

3306端口是默认绑定在本地IP 127.0.0.1上的,所以外网无法访问该主机的3306端口。
打开MySQL的配置文件:sudo vim /etc/mysql/mysql.conf.d/mysqld.cnf

  1. 找到如下内容的一行并注释掉:

bind-address = 127.0.0.1

  1. 重启MySQL服务

sudo systemctl restart mysql

然后使用如下命令查看端口绑定状态

sudo netstat -an | grep 3306


问题二:用户权限

查看用户权限

1
2
3
sudo mysql -uroot -p[你的密码]
use mysql
select user,host from user

当显示如下,表示用户root只允许内网访问

root localhost

给用户授权

1
2
grant all privileges on *.* to 'root'@'[允许的ip]' identified by '[密码]' with grant option;
flush privileges;

其中*[允许的ip]如果设置为*%**的话则表示所有$ip$都可以访问,*[密码]*表示外网访问的密码是什么。比如我设置成所有$ip$都可访问,密码是$root$,则命令如下:

1
2
3
grant all privileges on *.* to 'root'@'%' identified by 'root' with grant option;
flush privileges;
select user,host from user;

重新查看,会显示

root %

root localhost

安装 phpMyAdmin
]]>
- - - - - - <p><a href="https://blog.csdn.net/bird3014/article/details/78481104" target="_blank" rel="noopener">文章</a></p> -<h6 id="问题一:端口状态">问题一:端口状态</h - - - - - - - - - - - -
- - - 斯多葛主义手册 - - http://maiernte.github.io/wiki/storic-summary.html - 2019-08-03T19:16:47.000Z - 2019-08-14T06:31:28.000Z - -
  • 世间的事,有些可控,有些不可控。可控的有:观点,追求,欲望,和喜恶等。这些都是我们自己可以做出选择的。不可控的是身体,财物,名声,指令等。这些我们都无法选择。

    可控范围之内的东西在本质上是自由的,不被束缚、阻碍的。那些不可控的是虚的,是被奴役的,是我们受控于他人。记住,如果你觉得那些不可控的事物是自由的,那些受控于别人的也是你的,那么你就会被控制,被束缚。你会悲痛,你会受扰,你会指责神以及他人。但如果你只专注于你所能控制的,不被他人所拥有的干扰,那么就没有人能够影响你、束缚你。并且,你不会把过错推在他人身上。你不会去做违背你的意志的事。你不会有敌人。你也不会被伤害。

    把这些当做你的目标,不让自己受那些没有意义的事诱惑,哪怕就一点点也不可以。放弃那些不可控的。如果你既想把握住可控的,又想拥有财富和权力,那么你将会什么都得不到,更不用说幸福和自由-因为幸福和自由是依赖于可控事物。

    尽你最大的努力。这样你就可以对看似艰难的每一件事说:“你只不过是看起来艰难而已。” 然后比照你为自己制定的原则:这件事是否可控。如果在你控制范围之外,那么结果就无关乎于你。

  • 欲望要求你去追求你想要的;厌恶则让你尽量避免你所讨厌的。但是,如果你得不到你想要的,你就会十分失望;如果你无法避免你所讨厌的,那你就会被厌恶扭曲。那么,如果你只讨厌那些在你出自本质所做选择的对立事物(即在你控制范围内你不会选择的事物),那么你就永远不需要去为之伤神。但是,如果你厌恶疾病、死亡、贫穷等你无法选择和改变的,那你就会被厌恶扭曲。不厌恶你所不能控制的,把厌恶限制在和你本性对立的事物。但是,就目前来说,压制你的欲望:因为如果你追求任何可控范围之外的事物,那你就必然会失望。不要轻易追求或者厌恶。

  • 对于给你带来乐趣、有用处以及你十分喜欢的东西,从最不重要的事情开始,记得提醒你自己:他们真正的本质是什么。比如说,你很喜欢某个陶瓷杯,提醒你自己那只是因为你喜欢陶瓷杯而已,而不在于具体是哪个杯子。这样,如果杯子碎了,你也不会太伤心。当你亲吻你的家人时,提醒你自己你只是在亲吻和你亲近的人,这样当他们离世时,你就不会太难过。

  • 当你做事情时,提醒你自己事情的本质是什么,你可能遇到哪些情况。比如说洗澡。在你洗澡之前,先想想洗澡时会发生哪些事情。有的人可能会把水溅得哪都是,有人可能会推娜,有人会诅咒,有人会偷东西。这样你在洗澡之前就可以跟自己说:“我现在要去洗澡了,任何这些事都有可能发生,但是这不是我能控制的,所以我会保持好的心态”。如果你以同样的心态去对待任何其他事情,你内心的平和就不会被打扰。因为你可以对自己说:”我希望的不仅仅是洗澡,还有不被任何意外困扰”。

  • 人内心困扰时,通常不是被事物本身困扰,而是被他们自己的原则和概念所困扰。比如说,死亡本身并不可怕,要不然苏格拉底面临死亡时该有多么惊慌。我们对死亡的恐惧是源于我们对死亡的概念:死亡是可怕的。当我们被困扰、阻碍,伤心难过时,我们不要从事物本身或者他人身上找原因,而应该反省我们自己,还有我们的原则。一个还不通明的人,会把自己的糟糕情况怪罪于他人。一个刚刚开始学习处理这些情况的人,会从自己身上找原因。而一个已经通彻的人,既不会怪罪别人,也不会苛求自己。

  • 不要为任何身外之物骄傲。一匹马可以因为自己的英爽豪气自豪,因为这是它本身拥有的。但是如果你因为拥有这样一匹马儿骄傲,事实上,你所自豪的,不过是马所拥有的好。那么,什么才是属于你的呢?你对事物的反应和态度。如果你对任何事物的形态的处之泰然,那么你就可以为你的理性自豪,因为这是属于你的。

  • 想象以下情况:在一次航海旅行中,你的船抛锚靠岸了,你上岸去找水,途中你还捡了些你喜欢的贝壳,或者买个洋葱。但是,你的所有注意力必须一直集中在那艘船上,注意船长什么时候呼叫大家上船继续航行。当船长呼叫时,你必须立刻放下手中所有的东西,否则你就会被手脚捆绑得像只羊一样抛到船上。生活也是这样。生活给你老婆孩子,而不是洋葱贝壳。如果生活的船长呼叫了,你必须离开他们,立马跑到船上,而不是光顾着他们。如果你年纪大了,那你就不能离开船太远,否则你可能来不及回到船上。

  • 不要苛求生活给予你所有你想要的,该发生的就会发生,随遇而安就好。

  • 疾病影响的只是你的身体,而不是你选择的能力,除非那是你的选择。瘸的是腿,而不是你的脑子。不管发生什么事,只要这么跟自己说,你就会明白困难阻碍的是事物,而不是你。

  • 对于每一件发生的事,检视你自己的能力,问你自己能够用哪些能力从每一件事情中获得什么适当的用处。遇到一个十分有吸引力的人时,你就会发现你的自控就是你的能力。当你痛苦时,你会发现自己的坚强。听到坏话时,你会发现自己的耐心。形成了这样的习惯之后,你就不会被事物的表象所影响。

  • 不要说:“我失去了什么”。而应该说:“我归还了什么”。如果你的孩子或者妻子不幸离世了,你不是失去他们了,而是他们回归了。如果你的房子被夺走了,同样的,你是归还它们了。你可能会说:“可是那些夺走我房子的人是坏人!“。可是,给予你的人让谁来夺走你的房子真的那么重要吗?当你拥有时,照顾好它,但不要把它当做永久财物,就当自己是一个在那暂住的旅行者。

  • 如果你想要提高自己,那就要拒绝以下思考方式:“如果我忽视那些琐事,那我就没有收入;如果我不更正我的仆人,那他们就会变坏”。 如果能够免于悲伤和恐惧,即使死于饥饿,那也比富得流油但备受精神困扰好得多。比起坏仆人,难道你的开心不是更重要吗?

    如果你想要让自己变得更好,那就从小事做起。油洒了,酒被偷了,没关系,告诉你自己:“那只不过是平静生活的一点点代价。任何事情都是有代价的”。当你召集你的仆人时,他们可能不会来,也可能来了但是做的事情不合你意。但是他们并没有重要得以至于你必须打破自己的平静。

  • 如果你想要让自己变得更好,那就不要在乎被人认为你是愚蠢的。不要希望别人认为你无所不知。即使你看上去好像对别人来说很重要,也不要被这种虚名欺骗。因为想要既保持内心平和又拥有外在事物是非常困难的。当你专注于二者之一时,你必然会忽略剩下的那个。

  • 如果你希望你的家人、朋友长生不老,那是很愚蠢的想法。因为生死是在你控制范围之外的,是关乎他人的。同样地,如果你希望你的仆人不犯错,那你和傻瓜无异,因为你希望错误不是错误。但是,如果你希望你的欲望不带来失望,那是在你所能控制的范围之内的。练习控制你所能控制的。一个能够控制自己的喜恶的人,是自己生活的主人。这样的人,是真正自由的,不会成为被自己的欲望控制的奴隶,不会喜欢或者厌恶那些受别人控制的事物。

  • 记住生活就像是一个晚餐聚会一样。如果别人递给你一盘食物,你应该伸出手去接,舀起适当份量给自己。如果盘子从你身边递过,不要试图去截取。如果还没轮到你这,不要起身去拿,而是等着别人递到你面前。用相同的态度对待孩子,配偶,财物,公共职位,这样你最终自然就会成为诸神宴会的搭档。如果你不仅能够做到这些,还能够做到不去拿你面前的食物,甚至是有能力拒绝你自己的欲望,这样你不仅仅能够成为诸神宴会的搭档,你还能进入他们的国度,成为为他们的一员。像Diogenes, Heraclitus这些人就是因为他们的尊贵行为而被视为神一般神圣。

  • 当你看到别人因为孩子出国了,或者离世了,或者因为被琐事困扰而哭泣伤心时,不要让这些情感表象误导你。你必须作出自己的判断,明白他的伤心难过不是因为发生的事情本身,因为其他同样身处其中的人并没有受到同样的影响。他之所以受到那么大的困扰,是因为他自己本身对事情的判断。不要让自己和他一样受影响,不要让自己一样受困扰,不管是外在表现还是内心感受上。

  • 记住你只是一出戏里的一个演员,而戏份角色并不是由你决定的。不管角色故事长短,不管你是一个穷人,瘸子,政府官员,或者是一个很私密的人,把你的角色演好演自然了就行。把分配给你的角色演好,那是你的本分;而到底是哪个角色,那不是由你决定的。

  • 如果一只乌鸦向你预示不幸的事即将发生,不要让你内心的平静被这个表象破坏。要即刻告诉自己,“我不知道会发生什么,我不知道我的身体,财物,名声,或者家人会受什么影响,如果我愿意理性地去想,那么所有的这些恶兆就会变成幸运,因为我可以控制我要用什么态度去对待这些事情。不管发生什么,我都可以从中获得对我有利的。

  • 如果你不去参与在你控制范围之外的任何战斗,那你就不会被打败。当你看到那些声名显赫,社会地位高,或者在任何方面做得很好的人,不要着急认为他们是开心的。因为如果我们清楚明白幸福只在于我们所能够控制的范围内,那我们就不会去羡慕或者攀比。不要向往头衔,而是要向往内心自由和平静。而要做到这一点,唯一的途径是要看轻我们控制范围之外的一切事物。

  • 记住,那些对你出言不逊或者动手的人他本身并不是一种羞辱,而是代表那些言行的原则让你感觉到被羞辱。如果有人激怒你了,那是你对这种行为的观点激怒了你。试着不要被事情的表象牵引你的情感。给予适当的时间和稍作休息,你就能够很好地调整控制自己的情感。

  • 把死亡和流放这些看似可怕的事看作是日常,那你就赢了。不用害怕贫穷,也不要刻意贪求任何东西。

  • 如果你真心希望从哲学中获益,那么就要做好被众人嘲笑的准备:“她这是准备要成为一个哲学家呢”,“瞧她那傲慢的样子”……这个时候,你该做的,不是摆起傲慢的样子,而是要以神圣的态度忠诚于你所认定的,这样总有一天嘲笑你的人会开始尊敬你崇拜你。但是如果你被这些嘲笑打败,那你就成了双重的笑话。

  • 如果你为了取悦他人而把你的注意力转移到那些外在的你无法控制的事物上,那么恭喜你,你已经成功地毁了你自己的生活了。

  • 不要让以下这些思考方式困扰你:“我将会颜面丢尽,而且什么都不是。”耻辱是邪恶的,我们不应该被耻辱感所控制。因为获取权力或着被人嘲笑,这些都在你的控制范围之外。我们不用为任何在我们控制范围之外的事而感到耻辱。在我们可控范围之内,我们是自由的,能够左右我们自己的事情,是自我的主人-从这个角度看,我们永远不会什么都不是。“可是我帮不了我的朋友啊”,你可能会这么说。可是,怎么算是帮助朋友呢?你不能给他们钱,或者帮他们成为罗马市民。这些都是你所能控制范围之内的,是他们自己应该处理的事情。而且,如果这些都是你自己所没有的,那你怎么能够给他们呢?你可能会说:“如果我帮助他们获得这些的话,说不定我也能够得到一份呢“。如果我能够在保存我自己的尊严,忠诚和思想得到这些的话,请你帮我指明道路。可是如果你要我损害自己去得到你的利益,那这样的做法不仅不公平,而且愚蠢至极。

  • 如果别人,而不是你,被邀请去宴会,或者被赞美,或者被别人咨询,不要懊恼。如果这些是好事,你应该为他人高兴。如果是坏事,不要难过。记住:这些都是在你的控制范围之外的,这样的对待一般是有对应的代价的。如果你不愿意付出这样的代价而希望得到同样的对待,那是不公平的。比如说别人用50分买了一棵生菜,但是你不想花这50分,那你就不应该认为拥有生菜的人占了便宜。那个人付出50分得到了生菜,而你口袋里还有那没有花出去的50分。同理,宴会邀请,别人的赞美,这些都是有代价的。如果你觉得这些对你是有价值的,那你就要付出同等的价值去拥有。如果你不付出就想要得到这些,那么你就是个贪得无厌的傻瓜。换个角度想,在决定不和别人交换价值的时候,你真的什么都没有得到吗?不是的:你得到了不赞美你不想赞美的人的自由,而且也不需要容忍你不想容忍的行为。

  • 记住:很多事情不应该分自我或者他人。举个例子,如果邻居家的孩子打破了个杯子或者其他什么东西,我们很容易会说:“没事的,打碎东西是正常的”。可是如果打碎的是你自己的杯子呢?你应该作出相同的反应,而不是心生懊恼。同理,当别人的孩子或者妻子去世了,我们知道死亡的悲剧有时候是不可避免的,但是如果发生在我们自己身上的时候,我们却心如刀割。但是,我们应该清醒的认识到类似的悲剧不是我们能够控制的,我们所能够控制的是自己的情绪和反应,因为即使是发生在自己的身上,死亡本身并没有因为我们和死者的关系而变的更糟糕。

  • 立一个靶子的目的,不是为了射失它(靶子的目的都是为了让人射中它)。那么同样的道理,大道创造出一个“恶”的事物(至少看起来如此),不是为了让人绕开它。

  • 如果别人把你的身体交给一个路上遇到的陌生人,你一定会很生气。可是当别人用恶语打击你的时候,你为什么要心甘情愿地让别人控制你的思想,困惑你呢?

  • 做每件事情都要考虑缘由和后果之后才能开始行动。如果你兴高采烈地开始而没有考虑可能发生的后果,当某些不好的后果开始出现时,你就会停止前进。拿参加奥林匹克赛事为例子。如果你把所有前因后果都考虑周全后认为参加比赛对你时有益的,那就全力以赴。其中,应该考虑的事情包括:你要遵守规则,节制饮食;不管风吹日晒雨淋都要雷打不动地坚持按时锻炼;你不能喝凉水活着酒。你必须全身心地、完全忘我地投入训练。而且,要做思想准备准备,比赛中你有可能会摔入沟里,胳膊脱臼,脚踝受伤,吃入尘土,被鞭打,甚至最后以失败告终。当你评估完所有的可能性之后还是一心想比赛,那就以战争的姿态出发。否则,你就会像孩子过家家一样:一会扮摔跤手,一会扮角斗士,一会吹喇叭,一会又想参加戏剧演出。这样,即使你什么都做过,但是什么都不是。就想大猩猩一样,你模仿你所看到的一切,不停地换把戏可能是一件好玩的事,但是你很快就玩腻了。你从来都没有完全投入过任何事,没有深度地从各个角度考虑和研究所有相关的细节,而只是凭一时的兴趣蜻蜓点水般地接触了各种行业。有些人当他们看到一个人说话的方式和Euphrates十分相像(不过事实上,真的有人能和Euphrates一样犀利善辩吗?),他们认为自己也能够拥有和哲学家一样的思想。但是,如果你细想一下,如果你想要成为一个摔跤手,那么你必须具备有摔跤手的宽阔肩膀,强有力的背部和大腿。但是每一个人的身体构造都是不一样的,你必须具有必备的条件才能称为一个好的摔跤手。同理,要想成为一个哲学家,你不能像你现在这样随心所欲地吃喝,不能让愤怒和不满控制你的情绪,你必须细心观察,劳作,控制自己的欲望,你必须能够忍受孤独,仆人的不敬,和外人的嘲笑,你必须能够接受别人在其他方面做得比你好。如果你已经仔细考虑过这些情况,如果你认为如果做到以上这些可以让你享受自由和宁静,那就尽情去追求哲学家的道路。如果你无法做到这些的话,那么就请不要继续,不要像孩子一样,一会试试做哲学,一会又想当政治家,演讲者,或者凯撒的军官。这些追求是互相矛盾的,你只能成为其中一个,不管做得好坏。你必须培养你自己内在的能够掌控行为的能力,或者外在的技术,二者只能取其一。

  • 一个人的责任是由和别人的关系定义和衡量的。如果一个人拥有父亲的角色,那么他就有以下权利:他的孩子要照顾他,遵从他,耐心听他训话和教导。那如果他不是一个好父亲呢?他也应该受到同等的对待,因为我们无法选择我们的父亲是谁。不管他做了什么,你必须做到让自己心安理得。因为只有你能够让别人的行为伤害到你。当你觉得你被伤害了,那你就会被伤害。如果你以同样的逻辑看待邻居,市民,将军这些不同的角色,你就能够清楚地明白与这些角色相对应的社会责任。

  • ]]>
    - - - - <p><img src="https://github.com/maiernte/img/raw/master/collection/%E9%A9%AC%E5%8F%AF%E5%A5%A5%E5%8B%92%E7%95%99.jpg" alt></p> -<p>世间的事,有些可控,有些不可控。可控的有:观点,追求,欲望,和喜恶等。这些都是我们自己可以做出选择的。不可控的是身体,财物,名声,指令等。这些我们都无法选择。</p> - - - - - - - - - - -
    - - - 同步Hexo文章与Mac上原笔记的分类和标签 - - http://maiernte.github.io/wiki/synchron-the-tag-and-categories-btw-pc-hexo.html - 2019-08-01T15:30:00.000Z - 2019-08-03T12:58:26.000Z - - 最近才搞明白,原来Hexo博客的_post文件夹里面的Markdown原文件是可以按照分级嵌套的目录结构摆放的。编译的时候才放到public这个单一目录下。如果能让文章在Hexo的==分类==严格跟md文件的存储目录一一对应,将来需要找原文件的时侯会方便很多。😄

    使用Mac系统的同学也知道,mac有个很风骚的操作,就是给文件分配不同颜色的标签,非常方便文件寻找。我也希望博客上的文章标签,能跟Mac系统里的标签统一起来。:smile:

    实现物理存储目录与Hexo分类统一很简单,将源md文件的相对存储路径写到文件meta元素的categories里面就行了。比如源文件放在我的博客-->IT-->前端,文章的头文件就写成这样:categories:[IT, 前端]

    实现标签的统一稍微麻烦一点,需要先读取文件实际分配到的标签。网上已经有一个公开的项目, tag 。下载并安装,就可以通过 tag 命令读取文件和文件夹的标签。

    1
    2
    3
    4
    5
    6
    # 安装
    brew install tag
    # 查看版本
    tag --version
    # 读取文件标签
    tag --list fileUrl

    我已经写好了相应的脚本文件,下载并执行脚本文件就好了。脚本文件里的dirPath变量是我的统一存放md源文件的文件夹,你需要改成自己的存放路径,那样就不用每次运行的时候输入一遍。

    我在Hexo项目的根目录新添一个文件夹专门存放管理的脚本文件,每次都在终端运行这个脚本,所以默认执行路径是 ./source/_post

    运行脚本的时候可以设定时间参数,过滤掉太久远的文件。默认情况不会更改文件内容,只查看文件的实际分类和标签是否与文内头文件相同。然后按照给出的列表手动更改。如果想让程序自动更改,按照提示输入fix参数就好。

    ]]>
    - - - - - - <p>最近才搞明白,原来<strong>Hexo</strong>博客的<code>_post</code>文件夹里面的Markdown原文件是可以按照分级嵌套的目录结构摆放的。编译的时候才放到<strong>public</strong>这个单一目录下。如果能让文章在Hexo的 - - - - - - - - - - - - - -
    - - - 有用的Shell命令 - - http://maiernte.github.io/wiki/helpfull-shell-command.html - 2019-07-30T15:30:28.000Z - 2019-08-14T13:12:36.000Z - - 在线网站可以找到基本的东西:Linux命令大全 shell 正则表达式

    文件&内容检索

    正则表达式注意的地方

    • 花括号之前要加转义字符 [a-z]\{3\}
    • 空格就是转义加空格\ ,而不是\s 。如 [a-z0-9_\ ]\{3,\}
    • 这几个符号 _ - . #都不需要加转义符。
    • 不要轻易加==行结束符==$,可能回车才是最后符号,所以可能找不到。

    grep

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    # -r 递归搜索子目录
    # -l 只显示文件
    # -n 显示文件和匹配的行
    # 搜索 “markdown” 字符串并输入到文件里
    # Formating the Results...
    grep $begrif $directory $args |awk '{ print "[" $1 "](" $1 ")\n" }' > suchergebnisse.md
    # 将结果转为Windows目录
    sed -i -- 's/\/D\//D:\/\//g' suchergebnisse.md
    echo "Fertig! Ergebnisse siehe Datei 'suchergebnisse.md'"
    read

    更多参数请读此文 示例脚本

    grep 正则表达式的例子

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    #!bin/bash
    # {#part0000_split_050.html#nav_point-99 .calibre13}
    result=$(grep '{#part0000_split_[0-9]\{3\}.html[a-z0-9_\ -.#]\{3,\}calibre13}' 文件名)

    if [ "$result" = "" ];
    then
    echo "Nichts gefunden!"
    fi

    echo $result
    read

    grep或操作

    1
    2
    3
    grep -E '123|abc' filename  // 找出文件(filename)中包含123或者包含abc的行
    egrep '123|abc' filename // 用egrep同样可以实现
    awk '/123|abc/' filename // awk 的实现方式

    grep与操作

    1
    grep pattern1 files | grep pattern2 //显示既匹配 pattern1 又匹配 pattern2 的行。

    其它常用选项

    1
    2
    3
    4
    5
    grep -i pattern files   //不区分大小写地搜索。默认情况区分大小写,
    grep -l pattern files //只列出匹配的文件名,
    grep -L pattern files //列出不匹配的文件名,
    grep -w pattern files //只匹配整个单词,而不是字符串的一部分(如匹配‘magic’,而不是‘magical’),
    grep -C number pattern files //匹配的上下文分别显示[number]行,
    点击显/隐代码

    sed 命令

    参考文献

    文本替代

    以下文本替换通过pandoc导入后的文件,残留很多内部跳转链接:如

    1
    {#part0000_split_003.html#nav_point_1 .not-in-toc}
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    #!bin/bash
    echo running
    #sed 's/^#part0000_split_$/p' -f ../Linux_shell_Anleitung.md ;
    sed -i -- 's/^\[\]{#part0000_split_[0-9]\{3\}.html}$//g' ../Linux_shell_Anleitung.md

    #{#part0000_split_017.html#nav_point_21 .calibre8} {#part0000_split_003.html#nav_point_1 .not-in-toc}
    sed -i -- 's/{#part0000_split_[0-9]\{3\}.html#[a-z0-9_-]\+ .[a-z0-9_-]\+}//g' ../Linux_shell_Anleitung.md

    echo fertig!
    read

    整行替代

    参考文献

    替代以 categories: 开头的整行(允许行开头有空格或制表符)。c 代表整行,以字符串 categories: [IE] 替代整行。

    1
    2
    3
    4
    # Linux 下的写法
    sed -i -- '/^[[:blank:]]*categories:/c categories: [IE]' result.txt
    # Mac 下的写法
    sed -i '' 's/^[[:blank:]]*tags:.*/tags: [心理]/' $1

    错误:如果将参数 c 写在前面,会将整个文本每一行都替换掉。

    1
    2
    # Linux 下的写法
    sed -i -- 'c/^[[:blank:]]*categories:/categories: [IE]/' result.txt

    find

    1
    2
    3
    4
    # 查找所有的 md 文件
    find /root/bibliothek/markdowns/blog_posts/ -type f -name "*.md"
    # 查找一天之前的文件, 一小时前时 -1h,一周 -1w
    find . -type f -mtime -1d

    如果要处理复杂的事情,就要用到函数

    1
    2
    3
    4
    5
    6
    7
    8
    9
    # 定义函数
    showFileInfo(){
    echo $1
    }

    # 声明函数
    export -f showFileInfo
    # 使用函数
    find $dirPath -name "*.md" | xargs -n 1 -P 10 -I {} bash -c 'showFileInfo "$@"' _ {} \;

    查找最新文件

    • 将文件按从新到旧排列,取第一个。

      ls -t *.cpp | head -1

    • 将文件按从旧到新排列,取最后一个。

      ls -rt *.cpp | tail -1

    • 列出文件时间戳

      ls -l simpleNode.js |awk '{print $6 "-" $7 "-" $8 }'

    • 整合以上两个命令,找到最新的文件,读取时间戳

      ls -t *.* | head -1 | xargs ls -l | awk '{print $6 "-" $7 "-" $8 }'

    字符串处理

    字符串处理参考文献 将分隔符的字符串转为数组的几种方法

    配合使用,可以直接用 shell 实现文件内标签和分类的替换。

    数组转字符串

    使用分隔符将数组转字符串:

    1
    2
    3
    4
    ids=(1 2 3 4); 
    lst=$( IFS='/'; echo "${ids[*]}" );
    echo $lst
    # 结果是:1/2/3/4

    字符串转数组

    懒得写,看范例

    字符串替换

    1
    2
    3
    4
    5
    # 原串 [娱乐,经济,重要] => 目标串 [娱乐, 经济, 重要]
    ${tags/,/, } # 只替换了一个,结果变成 [娱乐, 经济,重要]
    ${tags//,/, } # 替换了所有符合的,结果变成 [娱乐, 经济, 重要]
    # 原串 [重要] => 目标串 重要
    ${tags//[\[\] ]/}

    消除回车符、换行符、制表符

    1
    2
    3
    # arg是个字符串变量, 可能带有回车符\r
    # 把它整个作为参数使用会带来很多麻烦。用以下命令将其替换掉
    newvar=${arg//[$'\t\r\n']/}

    详细用法

    参考文献

    1. ${var##*/}
      该命令的作用是去掉变量var从左边算起的最后一个’/‘字符及其左边的内容,返回从左边算起的最后一个’/’(不含该字符)的右边的内容。使用例子及结果如下:
    1
    2
    var=dir1/dir2/file.txt 
    --> file.txt

    从运行结果可以看到,使用该命令,可以提取出我们需要的文件名file.txt

    若使用时在shell程序文件中,可以使用变量来保存这个结果,再加以利用,如file=${var##*/}

    1. ${var##*.}
      该命令的作用是去掉变量var从左边算起的最后一个’.‘字符及其左边的内容,返回从左边算起的最后一个’.’(不含该字符)的右边的内容。使用例子及结果如下:
    1
    2
    var=dir1/dir2/file.txt 
    --> txt

    从运行结果可以看到,使用该命令,可以提取出我们需要的文件后缀。

    如果文件的后缀不仅有一个,例如,file.tar.gz,命令${var##*.}仅能提取最后一个后缀,而我想提取tar.gz时该怎么办?那么就要用下面所说的${var#*.}命令了。

    1. ${var#*.}
      该命令的作用是去掉变量var从左边算起的第一个’.‘字符及其左边的内容,返回从左边算起第一个’.’(不含该字符)的右边部分的内容。使用例子及结果如下:
    1
    2
    var=dir1/dir2/file.tar.gz 
    --> tar.gz

    从运行结果可以看到,使用该命令,可以提取出文件的多个后缀。

    1. ${var%/*}
      该命令的使用是去掉变量var从右边算起的第一个’/‘字符及其右边的内容,返回从右边算起的第一个’/’(不含该字符)的左边的内容。使用例子及结果如下:
    1
    2
    var=dir1/dir2/file.txt 
    --> dir1/dir2

    从运行的结果可以看到,使用该命令,可以提取出我们需要的文件所在的目录

    1. ${var%%.*}
      该命令的使用是去掉变量var从右边算起的最后一个’.‘字符及其右边的内容,返回从右边算起的最后一个’.’(不含该字符)的左边的内容。使用例子及结果如下:
    1
    2
    var=dir1/dir2/file.txt 
    --> dir1/dir2/file

    当我们需要建立一个与文件名相同名字(没有后缀)的目录与对应的文件相对应时,就可以使用该命令来进行操作。例如,解压文件的情况就与此类似,我们压缩文件file.zip时,会在与file.zip同级目录下建立一个名为file的目录。

    1. 总结

    其实${}并不是专门为提取文件名或目录名的,它的使用是变量的提取和替换等等操作,它可以提取非常多的内容,并不一定是上面五个例子中的’/‘或’.’。也就是说,上面的使用方法只是它使用的一个特例。

    看到上面的这些命令,可能会让人感到非常难以理解和记忆,其实不然,它们都是有规律的。

    • #:表示从左边算起第一个

    • %:表示从右边算起第一个

    • ##:表示从左边算起最后一个

    • %%:表示从右边算起最后一个

    换句话来说,#总是表示左边算起,%总是表示右边算起。

    *:表示要删除的内容,对于#和##的情况,它位于指定的字符(例子中的’/‘和’.’)的左边,表于删除指定字符及其左边的内容;对于%和%%的情况,它位于指定的字符(例子中的’/‘和’.’)的右边,表示删除指定字符及其右边的内容。这里的’'的位置不能互换,即不能把号放在#或##的右边,反之亦然。

    例如:${var%%x*}表示找出从右边算起最后一个字符x,并删除字符x及其右边的字符。

    看到这里,就可以知道,其实该命令的用途非常广泛,上面只是指针文件名和目录名的命名特性来进行提取的一些特例而已。

    basename和dirname

    ${}并不是专门为提取文件名和目录名设计的命令,那么basenamedirname命令就是专门为做这一件事而已准备的了。

    1. basename
      该命令的作用是从路径中提取出文件名,使用方法为basename NAME [SUFFIX]。

    1.1 从路径中提出出文件名(带后缀),例子如下:

    1.2 从上面命令的用法中可以看到,后缀(SUFFIX)是一个可选项。所以,若只想提取出文件名file,而不带有后缀,还可以在变量的后面加上后缀名,例子如下:

    1. dirname
      该命令的作用是从路径中提取出目录名,使用方法为 dirname NAME。使用例子如下:

    这样就提取出了file.txt文件所在的目录。

    注:该命令不仅能提取出普通文件所的目录,它能提取出任何文件所在的目录,例如目录所在的目录,如下:

    它提取出了目录dir2所在的目录dir1.


    查看硬盘剩余空间

    1
    2
    3
    4
    5
    # 整个硬盘空间
    df -hl
    # 查看某个文件夹大小
    du -h your_directory # 列出每个子文件夹大小
    du -hcs your_directory # 汇总

    查看 package 版本

    1
    apt-cache show packagename

    Windwos 下的脚本

    windows 下显示环境变量

    echo %http_proxy%

    windows 下设置代理服务器
    $$

    $$

    1
    2
    set http_proxy=http://username:pwd$$$@proxy-rzf:8080
    set https_proxy=http://username:pwd$$$@proxy-rzf:8080
    ]]>
    - - - - <p>在线网站可以找到基本的东西:<a href="https://man.linuxde.net/" target="_blank" rel="noopener">Linux命令大全</a> <a href="https://man.linuxde.net/docs/shell_regex.html" target="_blank" rel="noopener">shell 正则表达式</a></p> -<h1>文件&amp;内容检索</h1> -<h2 id="正则表达式注意的地方">正则表达式注意的地方</h2> -<ul> -<li>花括号之前要加转义字符 <code>[a-z]\{3\}</code></li> -<li>空格就是转义加空格<code>\ </code>,而不是<code>\s</code> 。如 <code>[a-z0-9_\ ]\{3,\}</code></li> -<li>这几个符号 <code>_ - . #</code>都不需要加转义符。</li> -<li>不要轻易加==行结束符==$,可能回车才是最后符号,所以可能找不到。</li> -</ul> - - - - - - - - - - -
    - - - Hexo日常管理 - - http://maiernte.github.io/wiki/hexo-blog-alltag-verwalten.html - 2019-07-30T15:27:28.000Z - 2019-08-02T03:54:52.000Z - - 复制MD文件

    查找最新文件

    1
    2
    3
    4
    ls -t /Users/mai/Projects/hexo/source/_posts/*.md | head -1 | xargs ls -l | awk '{print  $6 "-" $7 "-" $8 }'

    # 最旧的文件就应该是
    ls -t /Users/mai/Projects/hexo/source/_posts/*.md | tail -1 | xargs ls -l | awk '{print $6 "-" $7 "-" $8 }'

    其它

    Hexo 代码折叠

    1
    2
    3
    {% fold 点击显/隐内容 %}
    需要隐藏的内容。。。
    {% endfold %}

    参考文件

    有用的shell命令

    会导致编译奔溃的错误

    大括号和井号连在一起

    1
    2
    3
    {#、 #}、{#} 这三种情况都会导致系统奔溃
    {} 和 # 之间如果有别的字符就不会。如 { # }
    或者放在代码段内也不会。行内代码不能避免这种情形。
    ]]>
    - - - - - - <h1>复制MD文件</h1> -<script src="https://gist.github.com/maiernte/7d23ede58ddd69608bd7ee98b743e155.js"></script> -<h4 id="查找最新文件">查找最新文件</h4> -<fi - - - - - - - - - -
    - - - 佛偈集合 - - http://maiernte.github.io/wiki/budahlisisch-poeim-collection.html - 2019-07-29T07:10:50.000Z - 2019-08-15T21:46:14.000Z - - 佛偈(jì)

    虚云老和尚悟道偈

    杯子扑落地,响声明历历。
    虚空粉碎也,狂心当下息。

    烫着手,打碎杯,家破人亡语难开。
    春到花香处处秀,山河大地是如来。

    布袋和尚

    手把青秧插满田,低头便见水中天。
    心地清净方为道,退步原来是向前。

    赠药山高僧惟俨

    练得身形似鹤形,千株松下两函经。
    我来问道无馀说,云在青天水在瓶。

    ——李翱

    牛头山法融禅师

    恰恰用心时,恰恰无心用。曲谭名相劳,直说无繁重。
    无心恰恰用,常用恰恰无。今说无心处,不与有心殊。

    ——唐永徽年中

    天衣义怀禅师

    雁过长空,影沉寒底,雁无留影之心,影无遗踪之意。

    《菜根谭》中的一句古诗:“风来疏竹,风过而竹不留声;雁渡寒潭,雁过而潭不留影。

    另一版本:竹影扫阶尘不动,雁过寒潭水无痕。

    ]]>
    - - - - <center>佛偈(jì)</center> -<p><img src="https://raw.githubusercontent.com/maiernte/img/master/collection/tempel_3.jpg" alt></p> -<p>虚云老和尚悟道偈</p> -<p>杯子扑落地,响声明历历。<br> -虚空粉碎也,狂心当下息。</p> -<p>烫着手,打碎杯,家破人亡语难开。<br> -春到花香处处秀,山河大地是如来。</p> - - - - - - - - - - -
    - - - 简短书摘 - - http://maiernte.github.io/wiki/brief-notions-collection.html - 2019-07-29T07:00:50.000Z - 2019-07-31T03:51:35.000Z - - 癌症

    “以我个人有限的接触癌症的经历总结,似乎越是传统意义上的“好人”越是容易生癌。这些人往往脾气很好,性格内向,照顾周围,万事替别人考虑,总是在乎别人眼里的自己,总是担心一些可能发生的小概率负面事件。”

    —— 冯唐. “无所畏【冯唐2018全新作品,一部坦露自我的真诚之作!】。”

    暗算

    金风未动蝉先觉,暗算无常死不知。
    青山只会明今古,绿水何曾洗是非?

    五个人生思维
    • 能把问题清楚的写下来,就是解决了问题的一半。发现问题比解决问题更重要。
    • 墨菲定律:如果事情有变坏的可能,那它就一定会发生。
    • 吉伯特法则:真正的危险是没有人告诉你有危险。「人在事中迷,就怕没人提」。
    • 福克兰定律:当你不知道如何行动时,最好的行动就是不要行动,最好的决策就是没有决策。
    • 费斯诺定律:人有两只耳朵,却只有一张嘴巴。就是说,人应该多听少讲。
    ]]>
    - - - - <h6 id="癌症">癌症</h6> -<p>“以我个人有限的接触癌症的经历总结,似乎越是传统意义上的“好人”越是容易生癌。这些人往往脾气很好,性格内向,照顾周围,万事替别人考虑,总是在乎别人眼里的自己,总是担心一些可能发生的小概率负面事件。”</p> -<p>—— 冯唐. “无所畏【冯唐2018全新作品,一部坦露自我的真诚之作!】。”</p> - - - - - - - - - - -
    - - - 零散句子 - - http://maiernte.github.io/wiki/funny-sloga-collection.html - 2019-07-29T06:50:50.000Z - 2019-08-04T18:15:28.000Z - - 幸福的路有两条

    中岛美雪写的歌《幸福》(任贤齐翻唱的伤心太平洋):到幸福的路有两条,一条是所有愿望都成真,另外一条是把愿望这东西扔掉。

    Matrix

    Cypher: You know, I know this steak doesn’t exist. I know that when I put it in my mounth, the Matrix is telling my brain that it is … juicy and delicious. After nine years, you know what I realize? en … Ignorance is bliss

    几个顺口溜
    • 认认真真说假话,扎扎实实走过场。
    • 失败乃成功之母——失败生了100个孩子,其中一个叫「成功」,其它99个还叫「失败」。
    • “人类一思考,上帝就发笑。” —— “你一说要学什么东西,人们就发笑。”
    • 晚上想想千条路,早上起来走原路。(有个共同特点:不困难、不痛苦)
    • 暂时的失败要比暂时的成功要好得多。
    • 别让「半途而废」 成为你唯一坚持下来的事情。
    • 世上没有听一遍就管用的道理。
    • (你的脑袋)不要做别人思想的跑马场。
    • 路是自己走的,脚上的泡也是自己好的。
    • 忍一时越想越气,退一步越想越亏。(总是忍的人,从来都不开心。总是退让的人,却从来没有真的海阔天空)
    • 遇到烂事不纠结,遇到烂人不纠缠。
    • 每个人都想努力做,却总是做不好。
    • 曹操评袁绍:「色厉胆薄,好谋无断,干大事而惜身,见小利而忘命。」
    ]]>
    - - - - <h6 id="幸福的路有两条">幸福的路有两条</h6> -<p>中岛美雪写的歌《幸福》(任贤齐翻唱的伤心太平洋):到幸福的路有两条,一条是所有愿望都成真,另外一条是把愿望这东西扔掉。</p> - - - - - - - - - - -
    - - - 典故 - - http://maiernte.github.io/wiki/old-stories-collection.html - 2019-07-29T06:45:50.000Z - 2019-07-31T03:51:35.000Z - - 豫让刺赵简子

    晋毕阳之孙豫让,始事范、中行氏而不说,去而就知伯,知伯宠之。及三晋分知氏,赵襄子最恐知伯,而将其头以为饮器。豫让遁逃山中曰:“磋乎!士为知己者死,女为悦己者容。吾其报知氏之仇矣。”

    乃变姓名,为刑人,入宫涂厕,欲以刺襄子。 襄子如厕,心动,执问涂者,则豫让也。 刃其曰:“欲为知伯报仇!”左右欲杀之。 赵襄子曰:“彼义士也,吾谨避之耳。且知伯已死,无后,而其臣至为报仇,此天下之贤人也。”卒释之。 豫让又漆身为厉,灭须去眉,自刑以变其容,为乞人而往乞,其妻不识,曰:“状貌不似吾夫,其音何类吾夫之甚也。”又吞炭为哑,变其音。 其友谓之曰:“子之道甚难而无功,谓子有志,则然矣,谓子知,则否。以子之才,而善事襄子,襄子必近幸子;子之得近而行所欲,此甚易而功必成。”豫让乃笑而应之曰:“是为先知报后知,为故君贼新君,大乱君臣之义者无此矣。凡吾所谓为此者,以明君臣之义,非从易也。且夫委质而事人,而求弑之,是怀二心以事君也。吾所为难,亦将以愧天下后世人臣怀二心者。”

    居顷之,襄子当出,豫让伏所当过桥下。 襄子至桥而马惊。 襄子曰:“此必豫让也。”使人问之,果豫让。 于是赵襄子面数豫让曰:“子不尝事范中行氏乎?知伯灭范中行氏,而子不为报仇,反委质事知伯。知伯已死,子独何为报仇之深也?”豫让曰:“臣事范中行氏,范中行氏以众人遇臣,臣故众人报之;知伯以国士遇臣,臣故国士报之。”襄子乃喟然叹泣曰:“嗟乎,豫子!豫子之为知伯,名既成矣,寡人舍子,亦以足矣。子自为计,寡人不舍子。”使兵环之。 豫让曰:“臣闻明主不掩人之义,忠臣不爱死以成名。君前已宽舍臣,天下莫不称君之贤。今日之事,臣故伏诛,然愿请君之衣而击之,虽死不恨。非所望也,敢布腹心。”于是襄子义之,乃使使者持衣与豫让。 豫让拔剑三跃,呼天击之曰:“而可以报知伯矣。”遂伏剑而死。 死之日,赵国之士闻之,皆为涕泣。

    —— 《战国策》

    ]]>
    - - - - <h6 id="豫让刺赵简子">豫让刺赵简子</h6> -<p>晋毕阳之孙豫让,始事范、中行氏而不说,去而就知伯,知伯宠之。及三晋分知氏,赵襄子最恐知伯,而将其头以为饮器。豫让遁逃山中曰:“磋乎!士为知己者死,女为悦己者容。吾其报知氏之仇矣。”</p> - - - - - - - - -
    - - - 搞笑段子 - - http://maiernte.github.io/wiki/funny-things-collection.html - 2019-07-29T06:40:50.000Z - 2019-07-31T03:51:35.000Z - - 慢慢就习惯了

    某人四十多岁了还碌碌无为,于是跑去找算命先生。算命先生掐指一算,然后问:“一个好消息,一个坏消息,你先听哪个?”哥们说:“那就先听坏的吧”。算命先生说:“坏消息是,你四十岁之前穷困潦倒……”那哥们眉头一挑,问:“那好消息呢?”算命先生幽幽的说到:“四十岁以后,你就习惯了。”

    身体就像一辆车子

    身体就像一辆车子,还新的时候,遇到问题花点钱修理一下,就又能风驰电掣。车子越旧,修理费越高。旧到不行了,修理费比换辆新的还贵,还修个啥劲?你「身体」这家企业,当对它的投入远大于产出的时候,上帝都要考虑撤资了,你还拼命追加投资?

    凌凌漆

    外景:深圳某一市场猪肉摊前。
    某女甲:你以为你匿喺度就揾唔到你咩? 冇用架! 你啲咁出色嘅难忍(男人),无论喺边度,都好似漆黑中嘅萤火虫一样,咁鲜明,咁出众。 你忧郁嘅眼神,唏嘘嘅须根,神乎其技嘅刀法,同埋嗰杯Dry Martine,都彻底噉将你出卖咗。 不过,你虽然系咁出色,始终行有行规,无论典(点)你都要找埋寻晚嗰条过夜数,叫鸡唔使畀钱呀?
    凌凌漆:我重估我哋嘅交往系建筑喺感情之上,估唔到,原来都系一盘生意。
    某女甲:讲感情都要畀钱架。
    凌凌漆:明白嘅,有一早畀咗你啦。 但系近排兴食斋,冇乜人帮衬,不如噉啦,攞篘猪肉返去顶住数先啦。 嚟吖,粗粗地,唔该。
    某女甲:你好嘢,山水有山逢。 (某女甲提猪肉转身走。)
    凌凌漆:
    有兴趣嘅不如今天再相逢啦。
    (某女甲把猪肉投向凌凌漆)
    凌凌漆(用刀接住猪肉):悭番。 (顺势将猪肉切成两半,挂喺猪肉钩上)
    某女乙:咩话? 个衰佬唔肯畀钱? 我帮你拖马喐佢!
    某女甲:算啦,话到尾,佢始终都系一个独一无二、风度翩翩嘅猪肉佬。
    (阿漆依着猪肉摊,品着白兰地。)

    情人节广告

    14号晚报名打麻将,只报不打,报名费100元,报完名爱干嘛干嘛,爱去哪去哪,爱跟谁跟谁。本人承诺:保证任何人问你的行踪都可以证明你跟我一起打麻将了,你所有报不了的花费都可以说成是被我赢了,具体时间为2月14日17点至凌晨2点,时间地点任选。额外业务:如支付200元,还提供大牌合照以及朋友圈回复业务,做戏做全套!小本经营,童叟无欺!有意者私聊。

    ]]>
    - - - - <h6 id="慢慢就习惯了">慢慢就习惯了</h6> -<p>某人四十多岁了还碌碌无为,于是跑去找算命先生。算命先生掐指一算,然后问:“一个好消息,一个坏消息,你先听哪个?”哥们说:“那就先听坏的吧”。算命先生说:“坏消息是,你四十岁之前穷困潦倒……”那哥们眉头一挑,问:“那好消息呢?”算命先生幽幽的说到:“四十岁以后,你就习惯了。”</p> - - - - - - - - - - -
    - - - 缠中说禅 - - http://maiernte.github.io/wiki/funny-things-collection.html - 2019-07-29T06:40:50.000Z - 2019-07-31T03:51:35.000Z - - [TOC]

    诗词
    满江红

    万古长空,今犹昔,一朝风月。何处住?
    春花夏雨,秋鸿冬雪。
    百代浮华皆作土,千江吸尽无堪说。
    问世间,多少梦消磨、英雄血。
    星旋轨,天补裂,山崩柱,河倾缺。
    捣神宫鬼府,凤巢龙穴。
    怒剑穿云惊浩宇,狂涛卷日横孤筏。
    纵生死,劫火洗乾坤,齐欢悦。

    临江仙

    浊水倾波三万里,愀然独坐孤峰。
    龙潜狮睡侯飙风。
    无情皆竖子,有泪亦英雄。
    长剑倚天星斗烂,古今过眼成空。
    乾坤俯仰任穷痛。
    半轮沧海上,一苇大江东。

    卜算子

    本是后山人,偶做堂前客。
    醉舞经阁半卷书,坐井说天阔。
    大志戏功名,海斗量祸福。
    论到囊中羞涩时,怒指乾坤错。

    —— 丁元英

    ]]>
    - - - - - - <p>[TOC]</p> -<h5 id="诗词">诗词</h5> -<h6 id="满江红">满江红</h6> -<p>万古长空,今犹昔,一朝风月。何处住?<br> -春花夏雨,秋鸿冬雪。<br> -百代浮华皆作土,千江吸尽无堪说。<br> -问世间,多少梦消磨、英雄血。<br> -星旋轨, - - - - - - - - - - - -
    - - - 名人语录 - - http://maiernte.github.io/wiki/prominaent-slogen-collection.html - 2019-07-29T06:40:50.000Z - 2019-07-31T03:51:35.000Z - - 祈祷文
    • 上帝,请赐予我平静让我可以接受我所不能改变的,赐予我勇气让我可以改变我能够改变的,赐予我智慧以分辨这二者的不同。
    • God grand me the serenity to accept the things I cannot change, Courage to change the things I can, and wisdom to know the difference.
    尼采

    He who has a strong enough why can bear almost any how. – Friedrich Nietzsche

    苏格拉底

    Beware the barrenness of a busy life. – Socrates

    亚里士多德

    We are what we repeatedly do. Excellence, then, is not an act, but a habit. – Aristotle

    维克多 弗兰克

    人所拥有的任何东西都可以被剥夺,唯独人性最后的自由——也就是在任何境遇中选择一己态度和生活方式的自由——不能被剥夺。

    马克吐温

    让你陷入困境的并不是这个世界;真正让你陷入困境的,是这个世界最终并非你所想象。

    赛斯

    每一个心愿都预设了对于一个缺憾的承认,每一个挑战也预设了有一个要征服的阻碍。

    叔本华

    痛苦和无聊是人类幸福的两个死敌。欲望不满足就痛苦,满足就无聊。人生如同钟摆在痛苦和无聊两个极点之间摆动。离开一个极点就意味着正在走向另一个极点。

    谚语

    Don’t shoot the messenger.
    英文有句谚语叫“不要枪毙信使”。枪毙信使并不能改变坏消息。

    曾国藩
    • 既往不恋,当下不染, 未来不迎。天涯:染,不被当下的情绪感染。要跳出情绪来观察当下。
    • 倚天照海花无数, 流水高山心自知。
    • 久利之事勿为,众争之地勿往。
    • 勿以小恶弃人大美, 勿以小怨忘人大恩。
    宗棠

    人生最不幸處,是偶一失言而禍不及,偶一失謀而事倖成,偶一恣行而獲小利, 後乃視為故常,而恬不為意。則莫大之患,由此生矣。

    俞敏洪

    优秀是一种习惯。

    ]]>
    - - - - - - <h6 id="祈祷文">祈祷文</h6> -<ul> -<li>上帝,请赐予我平静让我可以接受我所不能改变的,赐予我勇气让我可以改变我能够改变的,赐予我智慧以分辨这二者的不同。</li> -<li>God grand me the serenity to accept the thi - - - - - - - - - - - -
    - - - 如何系统化管理Hexo博客 - - http://maiernte.github.io/wiki/how-to-manage-big-hexo-blog.html - 2019-07-28T19:30:00.000Z - 2019-08-15T21:51:57.000Z - - 建立博客的初衷

    虽说这篇笔记的题目是「如何管理」,为了更好的回答这个问题,必须要回到最原始问题上来——我为何要建一个博客,而且是费那么大劲。而我的初衷是建立和维护一个属于自己的「知识库」。通常来说,为了达成这个目的,更好的选择是笔记APP,而不是博客。我确实也是这么做的。一开始用印象笔记,因为它死活不支持多级目录,我又转到国内的为知笔记,做了五年的VIP用户。但它五年来似乎从没改进过。随着近年来有道云异军突起,以及IOS生态圈中琳琅满目的APP,如熊掌记、Notion、谷歌的Keep、阿里的语雀。。。。。。各有各的惊艳,各有各的槽点。

    随着国外的Github和国内的Coding等公司,相继开放永久免费、不限流量的静态网页托管平台,如Github Pages。我走上了自建Bolg的不归路。当然不是说,搭博客这条路完全没有槽点。而是——自己造的孽,含着泪也会继续造下去。至少它满足了我以下几点「必不可少」的要求:

    • [x] 多级目录
    • [x] 支持Markdown文本
    • [x] 支持分类、标签、以及站内全文检索
    • [x] 没有IOS、Windows、Android等平台限制

    说白了,我是利用Github提供的免费平台,把Blog当笔记本来用。最后选了Hexo,简单易用、界面绚丽、插件丰富。除开自用的「知识平台」功能以外,偶尔还能发发博文装大尾巴狼,也是蛮不错的感觉。

    网上介绍怎么搭建Hexo以及添加绚丽功能的帖子海了去了,但我基本没有发现分享「如何管理」的。因为绝大多数这些博主,搭建Hexo只是用来玩一阵子。回头有更新更好玩的东西,就跑去玩别的了。极少数有博客,站内文章超过50篇的。所以,对他们来说,根本不存在——管理——这个议题。

    虽然Hexo在逻辑上支持分类标签,但物理上它把所有的Post都放到一个单一的目录下面。而我是打算把它当作知识库,长期、密集使用的。可预见的将来,站内笔记会非常多。不但写新贴,还可能经常更改旧贴。那势必会带来一个问题:如何管理数量少日益膨胀的笔记?

    解决思路

    我能想到的办法很简单,也很传统。就是不但逻辑分类,而且也必须物理上分目录存放。理论上在自己的PC分目录保存就好了。但我有好几台电脑,单位一台、自己Windows一台、Mac一台,还有平板。为了让能在不同的电脑上能随时修改、添加笔记,必须放在托管在云端。

    硬件

    没有必要租用传统的VPS,太贵了,而且连10%的运算能力都用不上。用共享的Web Hosting就完全能解决需求。比如百度云,或者Azure的Web App。而我是租用 1&1 公司的Web Hosting,每个月 1€

    • 1 CPU
    • 500M 内存
    • 20G SSD

    就算那么低的运算能力,平时我的网站也用不到25%的运算能力。应付起啦,绰绰有余。

    软件

    我采用了MM-Wiki 管理平台(以下简称维基平台)。这是一个非常优秀的开源项目,具体请参看作者的文档。部署超级简单,可以说一键部署,然后就可以用起啦了。简单来说这个平台有以下几个特点:

    • [x] 支持空间管理、空间内支持多级目录。
    • [x] 支持Markdown编辑。
    • [x] 支持附件。
    • [x] 有修改记录。
    • [ ] 不支持内容搜索,只支持笔记的题目搜索。
    • [ ] 标签只支持到空间级别,目录和笔记都没有标签。

    但它跟Hexo博客搭配使用,就完全满足我的需求了。其实Hexo博客中,有个仿维基的Wikitten主题,跟MM-Wiki项目非常像。但毕竟不是所有内容,都适合摆在公开的地方。以MM-Wiki 作为私用平台,增加了私隐保护。

    我的做法是,在维基平台中开辟一个独立的空间,用来存放博客上所有的源文件。而在Github Pages上托管的静态网站其实都是HTML文件。所有的改动,都必须在源Markdownn文件上修改,然后再推送到博客网站的。

    在维基平台修改、添加、删除笔记的源文件。然后复制到Hexo的项目目录,编译后推送到Github Pages站点。维基百科内置的在线版Editor.md 编辑器,非常美观实用。基本上我都不太需要在自己的电脑上用Typora等编辑器写MD文本了。思路有了,实现起来还是有一点问题。

    难点的解决办法

    首先,在维基平台内,MD文件是分目录存储的。这个目录不能直接拷贝到Hexo的_post目录。懒得每修改一个,或者添加一个笔记,就立马拷贝到博客中去。解决笔记复制的问题。

    其次,笔记的物理保存目录,必须跟Hexo上的「分类」是一一对应的。否则,管理起来会很麻烦。在维基平台移动了笔记的保存目录后,在一一修改内容,也是很吃力的事情。

    笔记复制的解决办法

    说来也超级简单,一个脚本命令就够了。先用find命令在指定目录找出所有的MD文件,然后通过管道传给复制命令cp,搞定!

    1
    find  /root/bibliothek/markdowns/博客草稿/  -type f -name "*.md" -exec cp {} /home/_post/ \;

    然后hexo d -g编译、发布,结束!

    管理笔记的分类

    这个问题有一点麻烦。因为必须打开每一个文件,读取笔记的头文件描述,然后再比较跟文件的物理位置是否符合。我尝试用shell脚本解决这难题。无奈我的的shell脚本功底是在很差,搞半天未果就放弃了。用Java或者.NET Core啥的,正儿八经写一个Console程序,也不是不行。但有种杀鸡用牛刀的感觉。

    最后想到了用Javascript。因为编译Hexo是需要安装Node.js的,写一段JavaScript,让Node跑起来。通往罗马的道路千万条,选一条自己最熟悉的就完了。

    点击查看代码

    上面这个脚本使用的都是我个人设置,你如果要用的话需要改成自己实际文件目录。

    ]]>
    - - - - <center><h1>管理?</h1></center> -<p><img src="https://github.com/maiernte/img/raw/master/fun/what.jpg" alt></p> - - - - - - - - - - -
    - - - 《驴得水》——影评 - - http://maiernte.github.io/wiki/lvdeshui-film.html - 2019-07-28T13:17:19.000Z - 2019-08-15T21:48:56.000Z - -

    追求自由的人,疯了,死了。
    不愿低头的人,成了听话的牲口。
    宽容大度的人,成了唯利是图的小人。
    淳朴憨厚的人,成了狡诈的恶棍。
    正面积极的人,用谎言掩盖真相。

    你觉得这是电影吗?其实,这是现实。我们先来看一下电影故事讲的是什么:

    一群怀揣伟大梦想的人,却敌不过山区缺水的现实,养了一头驴拉水。上头却不给养驴费,于是就把驴谎报成老师。上头来检查,不能因为一头驴毁了梦想啊。于是为了捍卫梦想的道路,却失去了梦想的意义。《驴得水》的海报上说,“讲个笑话,你可别哭啊”。 就像另一句笑话讲的那样, “小的时候我想拯救世界,长大后却发现世界都拯救不了我”。

    好笑,但却想哭。

    谁TM还没点梦想啊。但有时梦想很脆弱,甚至敌不过一碗炸酱面。你想让自己闪闪发光,但总得先养活自己,饿着肚子的人怎么去谈梦想?这也是很多刚毕业不久的人,所要面对的最为矛盾的情况。“我有很多想法,有很多想做的事。但我现在没钱、没人脉、没背景,甚至还没长相。想要出去闯一片天地, 但还要为一日三餐和落脚地打拼。梦想是高潮,现实却是性冷淡。还能怎么办呢?先养活自己再说吧”。于是,你找了一份莫名其妙的工作,你一日三餐是不愁了,你做着日复一日重复的工作,但是你不敢停,你越来越迷茫,越来越看不清生活的方向。

    你害怕那种怀揣梦想,但却又碌碌无为的日子,但你却不知道从哪里开始改变。于是你只能在焦虑中慢慢对现实妥协,然后你变成了自己曾经最讨厌的那种人。冷漠、没有激情、不思进取、浑浑噩噩,就像影片中的人物一样。曾经那些他们坚信的东西在面对现实时,都变得不堪一击。铁男说,“我没有办法啊,你知道子弹从脸上呼啸而过的感觉吗”?像不像我们经常说的,“我没办法啊,现实就是这样”。

    是啊,现实就是这样!作为芸芸众生,普通屁民,谁TM还没被现实强奸过啊。但想要活得更好,重要的不是治愈,而是带着病痛活下去。而且我们要清醒的认识到一个事实,有时我们之所以像傻逼一样努力,不是为了改变世界,而是为了不让世界改变我们。或许,这才是我们对这个世界最大的善意。

    ]]>
    - - - - <p><img src="https://github.com/maiernte/img/raw/master/collection/%E9%A9%B4%E5%BE%97%E6%B0%B4%E5%89%A7%E7%85%A7.jpg" alt></p> - - - - - - - - -
    - - - 编辑器工具使用技巧汇总 - - http://maiernte.github.io/wiki/Editor-Skills-Summary.html - 2019-07-27T06:24:33.000Z - 2019-09-01T17:11:47.000Z - - VSCode
    1. Wechseln zwischen Text-Editor und Terminal
      1. Command+K+S oder in Menü Code->Pereferenc->Hotky, öffnet Hot-Key Editor Fenster.
      2. Tip terminal in Suchfeld, findet die Binding `^``, löscht diese Einstellung.
      3. Sucht den “workbench.action.terminal.focus”, bindet es mit Key ⌃<.
      4. Sucht den “workbench.action.focusActiveEditorGroup”, bindet es wiederum mit Schlüssel ⌃<, und Wenn-Kondition “terminalFocus”.

    Typora

    更多更详细的内容请参阅 Typora Wiki

    Typora Wiki (wiki-website Project)

    个性化快捷键

    Windows

    文件—>偏好设置—>往高级设置 ,点击看到两个json格式的文件,打开第二个(conf.user.json), 用记事本打开,第17行keyBinding,在大括号中写 代码块:“你要设置的快捷键”,比如我的是代码块:Ctrl+Alt+P,保存文件,重启typora即可生效。更详细介绍

    1
    2
    3
    4
    5
    6
    7
    8
    // Custom key binding, which will override the default ones.
    "keyBinding": {
    // for example:
    // "Always on Top": "Ctrl+Shift+P"
    "注释":"Ctrl+Alt+/",
    "代码块":"Ctrl+Alt+P",
    "打开文件夹…":"Ctrl+Alt+O"
    },

    Mac

    官方说明

    需要到系统偏好设置—>键盘-->快捷键-->应用快捷键那边设置。找到 Typora.App,菜单名称填 代码,然后输入希望的快捷键。我的设置是⌃+⌘+C

    更改风格

    开发好的工具 如何客制化格式

    简单使用:添加 base.user.css 文件,并改变行内代码的颜色,以及公式颜色

    1
    2
    3
    4
    5
    6
    7
    8
    9
    # 行内代码
    code {
    color: red
    }

    # 行内公式
    .MathJax_SVG{
    color: DarkBlue;
    }

    Typora的代码使用 CodeMirror 项目,尝试了一下修改 base.user.css 文件确实可以改变代码段的高度,并带滚动。但同时也限定了进行代码编辑时的整个窗口高度。所以没有用

    1
    2
    3
    4
    5
    6
    7
    8
    9
    # 缺点:打开源代码模式的时候,整个页面也被限制成了只有300px
    .CodeMirror {
    max-height: 300px;
    }
    .CodeMirror-scroll {
    overflow-y: auto;
    overflow-x: auto;
    max-height: 300px;
    }

    注意到书写模式的时候,整个编辑器都被包裹在 <div id="write"> </div> 里面。在源代码模式的时候,没有这个 write 元素的包裹,而整个源代码窗口都被作用为一个 CodeMirror 元素对待。因此,作一些改变就能满足要求

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    #write .CodeMirror {
    max-height: 350px;
    }
    # 设定上下 padding 会让滚动条在小代码区消失
    #write .CodeMirror-scroll {
    overflow-y: auto;
    overflow-x: auto;
    max-height: 330px;
    padding-top: 10px;
    padding-bottom: 10px;
    }
    1
    # 避免只有一行的代码区,因为会显示滚动条,不好看。一行代码就用行内代码好了。

    如果要限制来自 GistHub 的代码高度,只能限定其父元素 iframe

    1
    2
    3
    iframe {
    max-height: 500px;
    }

    Windows版的 Typora 的数学模块保存在 path/resource/app/lib.asar 压缩文件中。需要用asar解压

    如何查看 asar 内部结构

    asar 如何加密解密

    1
    2
    3
    npm install -g asar
    asar extract 压缩文件 解压文件夹
    asar pack 文件夹 压缩文件名

    文本搜索

    打开的单篇文章内搜索:

    Windows Control + F

    Mac ⌘+F

    文件夹内的搜索

    Windows Control + Shift + F

    Mac ⇧+⌘+F

    ]]>
    - - - - <h1>VSCode</h1> -<ol> -<li>Wechseln zwischen Text-Editor und Terminal -<ol> -<li><code>Command+K+S</code> oder in Menü <code>Code-&gt;Pereferenc-&gt;Hotky</code>, öffnet Hot-Key Editor Fenster.</li> -<li>Tip <code>terminal</code> in Suchfeld, findet die Binding `^``, löscht diese Einstellung.</li> -<li>Sucht den “workbench.action.terminal.focus”, bindet es mit Key <code>⌃&lt;</code>.</li> -<li>Sucht den “workbench.action.focusActiveEditorGroup”, bindet es wiederum mit Schlüssel <code>⌃&lt;</code>, und Wenn-Kondition “terminalFocus”.</li> -</ol> -</li> -</ol> - - - - - - - - - - -
    - -
    diff --git a/docs/brief-notions-collection.html b/docs/brief-notions-collection.html index 4d57e35..e69de29 100644 --- a/docs/brief-notions-collection.html +++ b/docs/brief-notions-collection.html @@ -1,548 +0,0 @@ - - - - - - 简短书摘 | 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - -
    - - - - -
    -
    - - -
    - - - - - -

    - 简短书摘 -

    - - -
    - - -
    - - - -
    - 文章目录 -
    1. 1. 癌症
    2. 2. 暗算
    3. 3. 五个人生思维
    -
    - - - -
    癌症
    -

    “以我个人有限的接触癌症的经历总结,似乎越是传统意义上的“好人”越是容易生癌。这些人往往脾气很好,性格内向,照顾周围,万事替别人考虑,总是在乎别人眼里的自己,总是担心一些可能发生的小概率负面事件。”

    -

    —— 冯唐. “无所畏【冯唐2018全新作品,一部坦露自我的真诚之作!】。”

    - -
    暗算
    -

    金风未动蝉先觉,暗算无常死不知。
    -青山只会明今古,绿水何曾洗是非?

    -
    五个人生思维
    -
      -
    • 能把问题清楚的写下来,就是解决了问题的一半。发现问题比解决问题更重要。
    • -
    • 墨菲定律:如果事情有变坏的可能,那它就一定会发生。
    • -
    • 吉伯特法则:真正的危险是没有人告诉你有危险。「人在事中迷,就怕没人提」。
    • -
    • 福克兰定律:当你不知道如何行动时,最好的行动就是不要行动,最好的决策就是没有决策。
    • -
    • 费斯诺定律:人有两只耳朵,却只有一张嘴巴。就是说,人应该多听少讲。
    • -
    - -
    - -
    -
    -
    -
    - - - - - - - - - - - -
    -
    - -
    -
    - - - - - - - -
    -
    -
    -
    - -
    -
    - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - - - \ No newline at end of file diff --git a/docs/budahlisisch-poeim-collection.html b/docs/budahlisisch-poeim-collection.html index f2bd698..e69de29 100644 --- a/docs/budahlisisch-poeim-collection.html +++ b/docs/budahlisisch-poeim-collection.html @@ -1,560 +0,0 @@ - - - - - - 佛偈集合 | 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - -
    - - - - -
    -
    - - -
    - - - - - -

    - 佛偈集合 -

    - - -
    - - -
    - - - -
    - 文章目录 -
    1. 1. 布袋和尚
    2. 2. 赠药山高僧惟俨
    3. 3. 牛头山法融禅师
    4. 4. 天衣义怀禅师
    -
    - - - -
    佛偈(jì)
    -

    -

    虚云老和尚悟道偈

    -

    杯子扑落地,响声明历历。
    -虚空粉碎也,狂心当下息。

    -

    烫着手,打碎杯,家破人亡语难开。
    -春到花香处处秀,山河大地是如来。

    - -
    布袋和尚
    -

    手把青秧插满田,低头便见水中天。
    -心地清净方为道,退步原来是向前。

    -
    赠药山高僧惟俨
    -

    练得身形似鹤形,千株松下两函经。
    -我来问道无馀说,云在青天水在瓶。

    -

    ——李翱

    -
    牛头山法融禅师
    -

    恰恰用心时,恰恰无心用。曲谭名相劳,直说无繁重。
    -无心恰恰用,常用恰恰无。今说无心处,不与有心殊。

    -

    ——唐永徽年中

    -
    天衣义怀禅师
    -

    雁过长空,影沉寒底,雁无留影之心,影无遗踪之意。

    -
    -

    《菜根谭》中的一句古诗:“风来疏竹,风过而竹不留声;雁渡寒潭,雁过而潭不留影。

    -

    另一版本:竹影扫阶尘不动,雁过寒潭水无痕。

    -
    - -
    - -
    -
    -
    -
    - - - - - - - - - - - -
    -
    - -
    -
    - - - - - - - -
    -
    -
    -
    - -
    -
    - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - - - \ No newline at end of file diff --git a/docs/categories/IT/Blog/index.html b/docs/categories/IT/Blog/index.html new file mode 100644 index 0000000..e69de29 diff --git a/docs/categories/IT/Code/index.html b/docs/categories/IT/Code/index.html index 45384f0..e69de29 100644 --- a/docs/categories/IT/Code/index.html +++ b/docs/categories/IT/Code/index.html @@ -1,458 +0,0 @@ - - - - - - 分类: Code | 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - -
    - - - - -
    -
    -
    - -

    Code

    -
    - -
    - -
    - - -

    - JavaScript & Typescript技术摘要 -

    - - - -
    -
    - -
    -
    -
    -
    -
    - -
    -
    - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - - - \ No newline at end of file diff --git a/docs/categories/IT/Mac/index.html b/docs/categories/IT/Mac/index.html index df67127..e69de29 100644 --- a/docs/categories/IT/Mac/index.html +++ b/docs/categories/IT/Mac/index.html @@ -1,494 +0,0 @@ - - - - - - 分类: Mac | 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - -
    - - - - -
    -
    -
    - -

    Mac

    -
    - -
    - -
    - - -

    - Mac使用标签 -

    - - - -
    -
    - -
    - -
    - - -

    - Mac备忘录 -

    - - - -
    -
    - -
    -
    -
    -
    -
    - -
    -
    - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - - - \ No newline at end of file diff --git a/docs/categories/IT/Tools/index.html b/docs/categories/IT/Tools/index.html index 743e753..e69de29 100644 --- a/docs/categories/IT/Tools/index.html +++ b/docs/categories/IT/Tools/index.html @@ -1,674 +0,0 @@ - - - - - - 分类: Tools | 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - -
    - - - - -
    -
    -
    - -

    Tools

    -
    - -
    - -
    - - -

    - Gitbook攻略 -

    - - - -
    -
    - -
    - -
    - - -

    - 配置服务器端MySQL -

    - - - -
    -
    - -
    - -
    - - -

    - 有用的Shell命令 -

    - - - -
    -
    - -
    - -
    - - -

    - 编辑器工具使用技巧汇总 -

    - - - -
    -
    - -
    - -
    - - -

    - Ubuntu重设root用户密码 -

    - - - -
    -
    - -
    - -
    - - -

    - 坚果云有关 -

    - - - -
    -
    - -
    - -
    - - -

    - 使用Github维护知识库 -

    - - - -
    -
    - -
    -
    -
    -
    -
    - -
    -
    - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - - - \ No newline at end of file diff --git a/docs/categories/IT/Web/index.html b/docs/categories/IT/Web/index.html index 2f60fc1..e69de29 100644 --- a/docs/categories/IT/Web/index.html +++ b/docs/categories/IT/Web/index.html @@ -1,566 +0,0 @@ - - - - - - 分类: Web | 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - -
    - - - - -
    -
    -
    - -

    Web

    -
    - -
    - -
    - - -

    - 同步Hexo文章与Mac上原笔记的分类和标签 -

    - - - -
    -
    - -
    - -
    - - -

    - 如何系统化管理Hexo博客 -

    - - - -
    -
    - -
    - -
    - - -

    - 搭建Hexo博客的流水账 -

    - - - -
    -
    - -
    - -
    - - -

    - Next以及wikitten主题添加内容折叠 -

    - - - -
    -
    - -
    -
    -
    -
    -
    - -
    -
    - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - - - \ No newline at end of file diff --git a/docs/categories/IT/index.html b/docs/categories/IT/index.html index 6a32a60..e69de29 100644 --- a/docs/categories/IT/index.html +++ b/docs/categories/IT/index.html @@ -1,786 +0,0 @@ - - - - - - 分类: IT | 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - -
    - - - - -
    -
    -
    - -

    IT

    -
    - -
    - -
    - - -

    - JavaScript & Typescript技术摘要 -

    - - - -
    -
    - -
    - -
    - - -

    - MathJax用于易学领域 -

    - - - -
    -
    - -
    - -
    - - -

    - 用TypeScript编写JS函数库 -

    - - - -
    -
    - -
    - -
    - - -

    - 还在用七牛? -

    - - - -
    -
    - -
    - -
    - - -

    - Gitbook攻略 -

    - - - -
    -
    - -
    - -
    - - -

    - 配置服务器端MySQL -

    - - - -
    -
    - -
    - -
    - - -

    - 同步Hexo文章与Mac上原笔记的分类和标签 -

    - - - -
    -
    - -
    - -
    - - -

    - 有用的Shell命令 -

    - - - -
    -
    - -
    - -
    - - -

    - 如何系统化管理Hexo博客 -

    - - - -
    -
    - -
    - -
    - - -

    - 编辑器工具使用技巧汇总 -

    - - - -
    -
    - -
    - - -
    -
    -
    -
    - -
    -
    - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - - - \ No newline at end of file diff --git a/docs/categories/IT/page/2/index.html b/docs/categories/IT/page/2/index.html index 3b77192..e69de29 100644 --- a/docs/categories/IT/page/2/index.html +++ b/docs/categories/IT/page/2/index.html @@ -1,678 +0,0 @@ - - - - - - 分类: IT | 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - -
    - - - - -
    -
    -
    - -

    IT

    -
    - -
    - -
    - - -

    - Ubuntu重设root用户密码 -

    - - - -
    -
    - -
    - -
    - - -

    - 搭建Hexo博客的流水账 -

    - - - -
    -
    - -
    - -
    - - -

    - 坚果云有关 -

    - - - -
    -
    - -
    - -
    - - -

    - 使用Github维护知识库 -

    - - - -
    -
    - -
    - -
    - - -

    - Next以及wikitten主题添加内容折叠 -

    - - - -
    -
    - -
    - -
    - - -

    - Mac使用标签 -

    - - - -
    -
    - -
    - -
    - - -

    - Mac备忘录 -

    - - - -
    -
    - -
    - - -
    -
    -
    -
    - -
    -
    - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - - - \ No newline at end of file diff --git a/docs/categories/IT/skill/index.html b/docs/categories/IT/skill/index.html index 38bbc98..e69de29 100644 --- a/docs/categories/IT/skill/index.html +++ b/docs/categories/IT/skill/index.html @@ -1,530 +0,0 @@ - - - - - - 分类: skill | 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - -
    - - - - -
    -
    -
    - -

    skill

    -
    - -
    - -
    - - -

    - MathJax用于易学领域 -

    - - - -
    -
    - -
    - -
    - - -

    - 用TypeScript编写JS函数库 -

    - - - -
    -
    - -
    - -
    - - -

    - 还在用七牛? -

    - - - -
    -
    - -
    -
    -
    -
    -
    - -
    -
    - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - - - \ No newline at end of file diff --git a/docs/categories/index.html b/docs/categories/index.html index 45ee329..e69de29 100644 --- a/docs/categories/index.html +++ b/docs/categories/index.html @@ -1,426 +0,0 @@ - - - - - - 分类 | 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - -
    - - - - -
    -
    - 分类 -
    - -
    -
    -
    -
    - -
    -
    - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - - - \ No newline at end of file diff --git "a/docs/categories/\345\270\270\347\224\250\346\226\207\344\273\266/index.html" "b/docs/categories/\345\270\270\347\224\250\346\226\207\344\273\266/index.html" index 7d46131..e69de29 100644 --- "a/docs/categories/\345\270\270\347\224\250\346\226\207\344\273\266/index.html" +++ "b/docs/categories/\345\270\270\347\224\250\346\226\207\344\273\266/index.html" @@ -1,458 +0,0 @@ - - - - - - 分类: 常用文件 | 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - -
    - - - - -
    -
    -
    - -

    常用文件

    -
    - -
    - -
    - - -

    - Hexo日常管理 -

    - - - -
    -
    - -
    -
    -
    -
    -
    - -
    -
    - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - - - \ No newline at end of file diff --git "a/docs/categories/\346\221\230\345\275\225/index.html" "b/docs/categories/\346\221\230\345\275\225/index.html" index 0fc7e81..e69de29 100644 --- "a/docs/categories/\346\221\230\345\275\225/index.html" +++ "b/docs/categories/\346\221\230\345\275\225/index.html" @@ -1,746 +0,0 @@ - - - - - - 分类: 摘录 | 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - -
    - - - - -
    -
    -
    - -

    摘录

    -
    - -
    - -
    - - -

    - 佛偈集合 -

    - - - -
    -
    - -
    - -
    - - -

    - 简短书摘 -

    - - - -
    -
    - -
    - -
    - - -

    - 零散句子 -

    - - - -
    -
    - -
    - -
    - - -

    - 典故 -

    - - - -
    -
    - -
    - -
    - - -

    - 搞笑段子 -

    - - - -
    -
    - -
    - -
    - - -

    - 名人语录 -

    - - - -
    -
    - -
    - -
    - - -

    - 缠中说禅 -

    - - - -
    -
    - -
    - -
    - - -

    - 《驴得水》——影评 -

    - - - -
    -
    - -
    - -
    - - -

    - 爱乐之城——影评 -

    - - - -
    -
    - -
    -
    -
    -
    -
    - -
    -
    - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - - - \ No newline at end of file diff --git "a/docs/categories/\346\221\230\345\275\225/\345\250\261\344\271\220/index.html" "b/docs/categories/\346\221\230\345\275\225/\345\250\261\344\271\220/index.html" index 827481d..e69de29 100644 --- "a/docs/categories/\346\221\230\345\275\225/\345\250\261\344\271\220/index.html" +++ "b/docs/categories/\346\221\230\345\275\225/\345\250\261\344\271\220/index.html" @@ -1,458 +0,0 @@ - - - - - - 分类: 娱乐 | 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - -
    - - - - -
    -
    -
    - -

    娱乐

    -
    - -
    - -
    - - -

    - 搞笑段子 -

    - - - -
    -
    - -
    -
    -
    -
    -
    - -
    -
    - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - - - \ No newline at end of file diff --git "a/docs/categories/\346\221\230\345\275\225/\347\211\207\346\256\265/index.html" "b/docs/categories/\346\221\230\345\275\225/\347\211\207\346\256\265/index.html" index ee3d02f..e69de29 100644 --- "a/docs/categories/\346\221\230\345\275\225/\347\211\207\346\256\265/index.html" +++ "b/docs/categories/\346\221\230\345\275\225/\347\211\207\346\256\265/index.html" @@ -1,602 +0,0 @@ - - - - - - 分类: 片段 | 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - -
    - - - - -
    -
    -
    - -

    片段

    -
    - -
    - -
    - - -

    - 佛偈集合 -

    - - - -
    -
    - -
    - -
    - - -

    - 简短书摘 -

    - - - -
    -
    - -
    - -
    - - -

    - 零散句子 -

    - - - -
    -
    - -
    - -
    - - -

    - 名人语录 -

    - - - -
    -
    - -
    - -
    - - -

    - 缠中说禅 -

    - - - -
    -
    - -
    -
    -
    -
    -
    - -
    -
    - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - - - \ No newline at end of file diff --git "a/docs/categories/\346\226\207\346\241\243/index.html" "b/docs/categories/\346\226\207\346\241\243/index.html" index b0244b5..e69de29 100644 --- "a/docs/categories/\346\226\207\346\241\243/index.html" +++ "b/docs/categories/\346\226\207\346\241\243/index.html" @@ -1,458 +0,0 @@ - - - - - - 分类: 文档 | 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - -
    - - - - -
    -
    -
    - -

    文档

    -
    - -
    - -
    - - -

    - RZF Organisation -

    - - - -
    -
    - -
    -
    -
    -
    -
    - -
    -
    - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - - - \ No newline at end of file diff --git "a/docs/categories/\350\257\273\344\271\246\347\254\224\350\256\260/index.html" "b/docs/categories/\350\257\273\344\271\246\347\254\224\350\256\260/index.html" index 7891cc1..e69de29 100644 --- "a/docs/categories/\350\257\273\344\271\246\347\254\224\350\256\260/index.html" +++ "b/docs/categories/\350\257\273\344\271\246\347\254\224\350\256\260/index.html" @@ -1,530 +0,0 @@ - - - - - - 分类: 读书笔记 | 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - -
    - - - - -
    -
    -
    - -

    读书笔记

    -
    - -
    - -
    - - -

    - 斯多葛主义手册 -

    - - - -
    -
    - -
    - -
    - - -

    - 财富自由之路-李笑来 -

    - - - -
    -
    - -
    - -
    - - -

    - 《少有人走的路》笔记 -

    - - - -
    -
    - -
    -
    -
    -
    -
    - -
    -
    - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - - - \ No newline at end of file diff --git "a/docs/categories/\351\232\217\347\254\224/index.html" "b/docs/categories/\351\232\217\347\254\224/index.html" index 62d010e..e69de29 100644 --- "a/docs/categories/\351\232\217\347\254\224/index.html" +++ "b/docs/categories/\351\232\217\347\254\224/index.html" @@ -1,458 +0,0 @@ - - - - - - 分类: 随笔 | 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - -
    - - - - -
    -
    -
    - -

    随笔

    -
    - -
    - -
    - - -

    - Hello World -

    - - - -
    -
    - -
    -
    -
    -
    -
    - -
    -
    - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - - - \ No newline at end of file diff --git a/docs/config-mysql-access-privileges-on-vps.html b/docs/config-mysql-access-privileges-on-vps.html index d456246..e69de29 100644 --- a/docs/config-mysql-access-privileges-on-vps.html +++ b/docs/config-mysql-access-privileges-on-vps.html @@ -1,577 +0,0 @@ - - - - - - 配置服务器端MySQL | 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - -
    - - - - -
    -
    - - -
    - - - - - -

    - 配置服务器端MySQL -

    - - -
    - - -
    - - - -
    - 文章目录 -
    1. 1. 问题一:端口状态
    2. 2. 问题二:用户权限
    3. 3. 安装 phpMyAdmin
    -
    - - - -

    文章

    -
    问题一:端口状态
    -
      -
    1. 查看 3306 端口状态 sudo netstat -an | grep 3306
    2. -
    -
    -

    tcp 0 0 127.0.0.1:3306 0.0.0.0:*

    -
    -

    3306端口是默认绑定在本地IP 127.0.0.1上的,所以外网无法访问该主机的3306端口。
    -打开MySQL的配置文件:sudo vim /etc/mysql/mysql.conf.d/mysqld.cnf

    -
      -
    1. 找到如下内容的一行并注释掉:
    2. -
    -
    -

    bind-address = 127.0.0.1

    -
    -
      -
    1. 重启MySQL服务
    2. -
    -
    -

    sudo systemctl restart mysql

    -
    -

    然后使用如下命令查看端口绑定状态

    -
    -

    sudo netstat -an | grep 3306

    -
    -
    -
    问题二:用户权限
    -

    查看用户权限

    -
    1
    2
    3
    sudo mysql -uroot -p[你的密码]
    use mysql
    select user,host from user
    -

    当显示如下,表示用户root只允许内网访问

    -
    -

    root localhost

    -
    -

    给用户授权

    -
    1
    2
    grant all privileges on *.* to 'root'@'[允许的ip]' identified by '[密码]' with grant option;
    flush privileges;
    -

    其中*[允许的ip]如果设置为*%**的话则表示所有$ip$都可以访问,*[密码]*表示外网访问的密码是什么。比如我设置成所有$ip$都可访问,密码是$root$,则命令如下:

    -
    1
    2
    3
    grant all privileges on *.* to 'root'@'%' identified by 'root' with grant option;
    flush privileges;
    select user,host from user;
    -

    重新查看,会显示

    -
    -

    root %

    -

    root localhost

    -
    -
    安装 phpMyAdmin
    - -
    - -
    -
    -
    -
    - - - - - - - - - - - -
    -
    - -
    -
    - - - - - - - -
    -
    -
    -
    - -
    -
    - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - - - \ No newline at end of file diff --git a/docs/content.json b/docs/content.json index 4d0f483..e69de29 100644 --- a/docs/content.json +++ b/docs/content.json @@ -1 +0,0 @@ -{"meta":{"title":"天涯的维基","subtitle":"竹影扫阶尘不动 雁过寒潭水无痕
    达摩九载面孤壁 起行归去影留存","description":"鎏金天涯的私房笔记。
    看,或者不看,它都在这里。","author":"鎏金天涯","url":"http://maiernte.github.io/wiki","root":"/wiki/"},"pages":[{"title":"关于本站","date":"2019-07-20T20:03:56.000Z","updated":"2019-07-22T17:31:07.000Z","comments":true,"path":"about/index.html","permalink":"http://maiernte.github.io/wiki/about/index.html","excerpt":"","text":"自从过上了极简生活,家务变得很少。对于一个巨蟹座的中年大叔,整理笔记成了我主要的挥洒精力的地方。我是笔记App的重度用户,用了两年的印象笔记,然后又五年的为知笔记,乃至尝试了新生人类惊为天人的熊掌记、Notion、等等。仍然感觉各种不爽。自从有了Hexo,终于可以定下心来,专心做笔记了。 作为不是处女座的强迫症患者,我把自己的这个笔记库部署到了两个不同的站点。内容基本一样,组织方式十分不同。 完整个人维基 心情版的博客"},{"title":"分类","date":"2019-07-20T19:59:23.000Z","updated":"2019-07-22T03:39:06.000Z","comments":false,"path":"categories/index.html","permalink":"http://maiernte.github.io/wiki/categories/index.html","excerpt":"","text":""},{"title":"标签","date":"2019-07-20T19:49:33.000Z","updated":"2019-07-22T03:37:51.000Z","comments":false,"path":"tags/index.html","permalink":"http://maiernte.github.io/wiki/tags/index.html","excerpt":"","text":""}],"posts":[{"title":"JavaScript & Typescript技术摘要","slug":"IT/Code/Javascript技术摘要","date":"2019-09-14T07:32:15.000Z","updated":"2019-09-16T18:53:45.000Z","comments":true,"path":"javascript-typescript-skills.html","link":"","permalink":"http://maiernte.github.io/wiki/javascript-typescript-skills.html","excerpt":"Javasript 和 Typescript 的重要技巧。","text":"Javasript 和 Typescript 的重要技巧。 零散知识点 列举 Enum Promise 输出链条 文档 Promises chaning :pencil2: 可以在 then 函数里面跑出 结果 或者 第二个 Promise 等待多个 Promise 1234let p1 = promise1let p2 = promise2const promises = Promise.all([p1, p2])return promises 声明以及定义扩展 在 *.d.ts 文件中声明类型 1234declare type Book = { title: string, comment?: string} 对 JavaScript 的原型进行扩展, 在一个 TS 文件进行定义和实现 123456789101112// ...path/common.tsexport {} // this will make it moduledeclare global { interface String { IsNullOrEmpty():boolean; Latex(color?:string):string; }}String.prototype.IsNullOrEmpty = function(){ return this == undefined || this == null || this == \"\"} 在需要的地方引用 1234import '..path/common';let str = \"\"const is_it_empty = str.IsNullOrEmpty() 读取文本 Html5 标准按钮 1<div type='file' (change)='LoadLocalFile($event)'></div> Javascript 读取文本内容并转为数据库 (使用 sql.js) 1234567891011121314LoadLocalFile(file) { const fileurl: File = file.target.files[0]; const reader = new FileReader(); reader.onload = () => { console.log('read file:', reader.result); const buffer = reader.result; const Uints = new Uint8Array(buffer as ArrayBuffer); const db = new SQL.Database(Uints); const nodes = db.exec('SELECT * From node'); console.log(nodes); }; reader.readAsArrayBuffer(fileurl); } 使用nix-file-helpers 插件 文档地址 演示地址 Html 12345<ion-button ngxFilePicker #filePicker=\"ngxFilePicker\" [readMode]=\"readMode\" (readStart)=\"onReadStart($event)\" (filePick)=\"onFilePicked($event)\" (readEnd)=\"onReadEnd($event)\">导入案例</ion-button> 代码,读取文件 123456onFilePicked(file: ReadFile) { const Uints = new Uint8Array(file.content as ArrayBuffer); const db = new SQL.Database(Uints); const nodes = db.exec('SELECT * From node'); console.log(nodes); } 测试 引用第三方js文件 在 angular.json 文件的 test-->scripts 中添加需要引用的文件。","categories":[{"name":"IT","slug":"IT","permalink":"http://maiernte.github.io/wiki/categories/IT/"},{"name":"Code","slug":"IT/Code","permalink":"http://maiernte.github.io/wiki/categories/IT/Code/"}],"tags":[{"name":"Hexo","slug":"Hexo","permalink":"http://maiernte.github.io/wiki/tags/Hexo/"}]},{"title":"MathJax用于易学领域","slug":"IT/skill/MathJax用于易学领域","date":"2019-08-30T08:15:28.000Z","updated":"2020-05-08T09:38:08.489Z","comments":true,"path":"mathjax-yixue-usage.html","link":"","permalink":"http://maiernte.github.io/wiki/mathjax-yixue-usage.html","excerpt":"关于利用 MathJax 和 Katex 数学公式解释器,实现易学上排六爻盘和八字盘个功能。今天实现了易学上的核心功能。有望将来能添加更多的函数,以便利各位同门以及广大易友。","text":"关于利用 MathJax 和 Katex 数学公式解释器,实现易学上排六爻盘和八字盘个功能。今天实现了易学上的核心功能。有望将来能添加更多的函数,以便利各位同门以及广大易友。 效果与演示 无法观看油管的朋友请移步B站:[使用MathJax渲染六爻和八字盘](https://www.bilibili.com/video/av66317810/) 安装和使用 首先,你需要一个支持 Markdown (简称MD) 语言格式的文本编辑器。如果不知道什么是MD的话,请参阅以下介绍: Markdown介绍及使用教程 Markdown - 简单的世界 认识与入门 Markdown Markdown 语言简约而优美,可以自由转换成pdf、word、Html 等等各种其它格式的文本。可以推送到博客、微信公众号等等。虽然算卦是一个传统的行业,我们仍然不宜固步自封。MD语言支持MathJax和Katex书写Latex数学公式,可以写出非常漂亮的数学、物理、化学方面的公式。正式的科技刊物都要求用Latex格式。 这个易学解决方案是对 MathJax 进行扩展,加入指定的易学公式,让 MathJax 解释器去完成公式渲染。它并不是一个独立的程序。需要构建在已有的MD文本编辑器之上。我使用一个文件夹存放所有的关于易学方面的MD文件,并将这个文件夹同步到 坚果云,这样就可以实现多台电脑和移动端之间的同步,而不太需要一个独立的易学软件。甚至可以将MD文件导出为HTML文件,放到我的HEXO博客上(您正在阅读的这篇博文即是例子)。 理论上所有支持Markdown语言和MathJax的文本编辑器,都可以改装。改装过程需要两段代码和一个库文件。 文本编辑器 Typora Typora 是我个人最钟爱的MD编辑器,因此这里着重介绍。如果你喜欢用别的MD编辑器,比如iAWrte等,理论上可以用同样的方式改装。(无法百分百保证) 有需要的朋友可以私下联系我。 最新的安装教程请参考华鹤易学平台文档 VSCode 同样请移步华鹤易学平台文档。那里有详细描述。 Hexo博客 🔔 注意:首先要检查自己的 Hexo 博客使用的渲染器是否默认开启了Katex或者MathJax数学插件。如果有的话需要卸载或者禁用数学插件,如果不能禁用,就必须更换Markdown渲染器。 因为系统使用的数学插件会在网页生成之前就改动数学表达,这样无法使用我提供给的函数库。我提供给博客的方案是在浏览网页的时候,即时渲染易学公式。 比如我之前用了 “hexo-renderer-markdown-it-plus” 渲染器就是强制使用 Katex 数学渲染的。 12npm un hexo-renderer-markdown-it-plus --save // 卸载npm i hexo-renderer-markdown-it --save // 更换 然后将下列代码添加到文件模版就可以了。使用 swig 模版的是在 <your thems>/layout/_custom/header.swig 或者 <your thems>/layout/index.swig 。而使用 ejs 模版的是文件 <your thems>/layout/layout.ejs 123456789<!--前三行最好添加到 <header></header> 头区块中--><link rel=\"stylesheet\" href=\"https://cdn.jsdelivr.net/npm/katex@0.11.0/dist/katex.min.css\" ><script defer src=\"https://cdn.jsdelivr.net/npm/katex@0.11.0/dist/katex.min.js\" ></script><script defer src=\"https://cdn.jsdelivr.net/npm/katex@0.11.0/dist/contrib/auto-render.min.js\"></script><script src=\"https://raw.githack.com/maiernte/img/master/libs/katexYixue.js\"></script><script src=\"https://raw.githack.com/maiernte/img/master/libs/bundle.js\"></script> 注意搜索 _config.yml 文件,“math”, “katex”, “mathjax” 等字样,发现有的话把他们禁用。 Gitbook 最新的安装教程请参考华鹤易学平台文档 API 参数 使用易学函数库非常简单,在经过改装的Markdown编辑器中,输入易学公式,并用两个 $ 符号将公式前后围起来即可。MD语言一般默认两个 $ 符号之间的文本是数学公式,它会调用MathJax对公式进行渲染。否则,它会认为这是普通文本,而不会做任何动作。 易学通用 命令:纳音 \\nayin{干支名称} 【干支名称】 :就是甲子、己卯等六十甲子。 例子1:\\nayin{戊午} --> $\\nayin{戊午}$ 命令:干支日历 \\timegz{时间参数}{年月日} 【时间参数】 :例如 2020-02-21。 【年月日】 :省略时默认为111,即显示年月日。0表示不显示,1表示显示。 例子1:\\timegz{2020-02-21} --> $\\timegz{2020-02-21}$ 例子2:\\timegz{2020-02-21}{011} --> $\\timegz{2020-02-21}{011}$ 六爻 命令:爻符 \\yao{爻名} 【爻名】:laoyin, laoyang,shaoyin,shaoyang, x, o, =, -, 交,重,阴,阳,0,1,2,3 例子2:\\yao{x} --> $\\yao{x}$ 例子3:\\yao{shaoyin} --> $\\yao{shaoyin}$ 例子4:\\yao{重} --> $\\yao{重}$ 命令:六爻排盘 \\paigua{时令}{卦辞}{标识} 其中 【时令】、【卦辞】这两个参数是必须的,**【标识】**参数可以省略。 【时令】允许的格式为:“1980-1-3 08:15”、“2019年3月4日”、“申月戊寅日” 【卦辞】允许的格式为:“解之师”、“离为火”、“–==x-”、“0121100”、“阴阳阴交阴阳” 【标识】由三部分组成:ID号、简排、字符大小。格式为:guadi/s/5 「ID号」:随便一串字符,空白则默认为“gua1”。:x:不允许只有数字,因为会与参数「字符大小」混淆。如果一个文本出现多个六爻卦,则每个卦都需要指定一个ID号。否则下面的命令卦爻细节不知道具体指向哪一个卦本。 「简排」:只允许s 和 l两个英文字符的其中一个。s 表示只显示短名,如“妻财”显示为“财”,“青龙”显示为“龙”。l 则显示完整名称。留白则按照用户全局设定来显示。(参阅用户设定) 「字符大小」:允许 0 - 9 档。数字越大文字越大。默认大小为5或者用户的全局设定。 例子5: $\\paigua{1978年7月1日}{101201}{gua1}$ 效果 $$\\paigua{1978年7月1日}{101201}{gua1}$$ :pencil2: 如果文章很长,需要在指定位置重新显示一遍卦本,则可以使用重排命令。即让【时令】和【卦辞】两个参数留白,只给出【ID号】。如 \\paigua{}{}{gua1} 。留白的参数,仍然需要用大括号括起来,否则解释器会出错。 命令:卦爻细节 \\guayao{标识}{位置} 使用前提:当前文本中已经排出至少一支六爻卦。 【标识】:与排盘命令的「标识」参数等同。由ID号、简排、字符大小三个部分组成。其中「ID号」标识已经存在的六爻盘。 【位置】:格式为 “ben1”、“fu3”、“bian5” 等,分别表示「本卦初爻」、「伏卦3爻」、「变卦5爻」 例子6:\\guayao{gua1}{ben4} --> $\\guayao{gua1}{ben4}$ 例子6 中给出的「ID号」为例子5中指定的ID号 “gua1”,并要求显示本卦4爻的具体信息。 八字 命令:八字排盘 \\paibazi{时间}{性别}{标识}[细节] 【时间】和【性别】参数必填,【标识】和【细节】参数可选。(如果要第二次显示已有的八字盘,则【时间】和【性别】参数可留白,只给定【标识】参数中的「ID号」) 【时间】:允许格式 “1980-1-3 08:15”、“2019年3月4日 6时3分” 【性别】:允许格式 “m”、“f”、“男”、“女”、“乾”、“坤”、 【标识】:与排盘命令的「标识」参数等同。由ID号、简排、字符大小三个部分组成。 【细节】:允许“藏干”、“长生”、“纳音”这三个中的一个或者多个,也可以留白。格式为 藏干/纳音/长生 例子7:\\paibazi{1990年5月1日 6:45}{男}{小明/s/5} $\\paibazi{1990年5月1日 6:45}{男}{小明/5}$ 例子8:重排例子7的八字盘 \\paibazi{}{}{小明/s/5}[纳音/藏干/长生] ,并要求显示藏干和纳音等信息。 $\\paibazi{}{}{小明/s/5}[纳音/藏干/长生]$ 命令:八字细节 \\bazi{标识}{类别}[细节] 使用前提:当前文本中已经排出至少一个八字盘。 【标识】:与排盘命令的「标识」参数等同。由ID号、简排、字符大小三个部分组成。其中「ID号」标识已经存在的八字命盘。 【类别】:支持 “神煞”、“大运”、“流年”、“小运” 四个选项。 【细节】:具体含义视【类别】而定。 类别为「神煞」时:「细节」为 1~ 9 的数字,表示每行列数。 类别为「大运」时: 1-9 纳音/藏干/长生/神煞 前面的数字表示第几步大运,限定 1 到 10 类别为「流年」和「小运」时: 2015 - 2019 纳音/藏干/长生/神煞 前面的数字表示年份,注意不要超过命盘的生命周期,否则会出错。「纳音/藏干/长生/神煞」可以留白,也可只显示一两项。 例子9: \\bazi{小明}{神煞}[6] 显示小明命盘的神煞,每行6列。 $\\bazi{小明}{神煞}[6]$ 例子10: \\bazi{小明}{大运}[2-3 ] 显示小明的第二到第三步大运 $\\bazi{小明}{大运}[2-3]$ 例子11: \\bazi{小明}{流年}[2017-2019 纳音/藏干/长生/神煞] 显示小明的2017到2019年的流年信息。 $\\bazi{小明}{流年}[2017-2019 纳音/藏干/长生/神煞]$ 未来与展望 我知道这篇文章介绍的工具,并非所有人都能使用。所以在不久的将来,还是要制作一个独立易学软件,以便易友在PC端和移动端都能按照传统的方式使用。但由于时间和精力原因,我无法保证完成时间。 不断完善易学函数,提供更丰富的应用细节。在用户更为广泛的MD编辑器中实现此方式。比如有道云笔记、为知笔记、印象笔记等。并争取介绍移动端(Android & iOS)实现此方式。也希望在Gitbook中实现。 希望能将师父的六爻和八字讲义,『增删卜易』等著作制作成Gitbook,将精彩的卦例和名人八字建成易学数据库。这样就可以通过我的易学函数直接获取, 比如 \\paibazi{蒋介石}。 附录: 命令列表 纳音 爻符 排卦 卦爻细节 排八字 八字细节 发布 脚本文件的原始路径是https://github.com/maiernte/img/raw/master/libs/bundle.js。因为涉及到跨域问题,要通过 Gitkack 重链接,把上述路径输入到 Githack 的地址框,会得到「应用地址」和「开发地址」。 应用地址: https://rawcdn.githack.com/maiernte/img/11a1bb572a6875dbf434a7fc457ea2fdd329f7db/libs/bundle.js 开发地址: https://raw.githack.com/maiernte/img/master/libs/bundle.js 查看当前易学函数库版本 在 chrome 浏览其中打开此博文,Mac 系统中按 ⌘+⌥+I ,Windows 系统 Ctr+⇧+I,或者 Chrome 菜单栏调出 “开发者工具”,选择 Console 页面,即可显示当前易学库版本和时间。","categories":[{"name":"IT","slug":"IT","permalink":"http://maiernte.github.io/wiki/categories/IT/"},{"name":"skill","slug":"IT/skill","permalink":"http://maiernte.github.io/wiki/categories/IT/skill/"}],"tags":[{"name":"工具","slug":"工具","permalink":"http://maiernte.github.io/wiki/tags/工具/"}]},{"title":"用TypeScript编写JS函数库","slug":"IT/skill/用Typescript编写JS函数库","date":"2019-08-16T20:15:28.000Z","updated":"2019-08-24T11:30:40.000Z","comments":true,"path":"TypeScript-build-JS-Package.html","link":"","permalink":"http://maiernte.github.io/wiki/TypeScript-build-JS-Package.html","excerpt":"本文具体介绍如何用TypeScript编写JavaScript库文件,以及制作npm工具包。主要参考下面两篇文章。我也省却一步步解释,只罗列相关的代码和我遇到的坑。想知道代码含义的请参阅原帖 TypeScript第一步 如何使用Gulp构建TypeScript 从Javascript迁移到Typescript 只看相关的那一章就可以","text":"本文具体介绍如何用TypeScript编写JavaScript库文件,以及制作npm工具包。主要参考下面两篇文章。我也省却一步步解释,只罗列相关的代码和我遇到的坑。想知道代码含义的请参阅原帖 TypeScript第一步 如何使用Gulp构建TypeScript 从Javascript迁移到Typescript 只看相关的那一章就可以 安装 TypeScript 终端执行 npm install typescript -g 12$ tsc --versionVersion 3.5.3 创建工程 初始化项目 12mkdir typescript_demo && cd typescript_demonpm init -y # 初始化项目,会生成 package.json 文件 安装Gulp, 并在项目根目录下新建 gulpfile.js 文件 1npm install gulp-cli gulp typescript gulp-typescript --save-dev 在命令行中执行 tsc --init 可以在当前目录中快速创建一个 tsconfig.json 文件。 安装 Browserify :目的是把所有ts文件打包成一个单一的js文件。 1npm install browserify tsify vinyl-source-stream --save-dev Watchify、Babel和Uglify :目的是让编译器保持运行,无需每次修改手动编译。 npm install watchify gulp-util --save-dev 1npm install watchify gulp-util --save-dev 安装 Uglify : 将输出文件 bundle.js 压缩 1npm install gulp-uglify vinyl-buffer gulp-sourcemaps --save-dev Babel :允许按新标准ES6编写代码,而最终会编译es05标准,兼容低版本浏览器。 1npm install babelify babel-core babel-preset-env vinyl-buffer gulp-sourcemaps --save-dev :bangbang: 安装中出现了错误, 显示babelify 版本太低. 将命令改为 npm install babelify@8 就能顺利进行下去了. 编写主文件 src/main.ts (名字随便起),在 package.json 中改为 $ “main”: “./dist/main.js”, $。创建两文件夹 src 和 dist,分别放置原文件和编译后的文件。为演示调用,再新建一个 src/greet.ts 文件 1234567# src/greet.tsdeclare function require(path: string): any;export function sayHello(name: string) { console.log(ln) return `Hallo von ${name}`;} 123456789# src/main.tsimport { sayHello } from \"./greet\";function showHello(idName: string, name: string) { const elt = document.getElementById(idName); elt.innerText = sayHello(name);}showHello(\"greeting\", \"TypeScript\"); 新建 src/index.html 1234567891011<!DOCTYPE html><html> <head> <meta charset=\"UTF-8\" /> <title>Hello World!</title> </head> <body> <p id=\"greeting\">Loading ...</p> <script src=\"bundle.js\"></script> </body></html> 修改 gulpfile.js 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950const gulp = require(\"gulp\");const browserify = require(\"browserify\");const source = require('vinyl-source-stream');const tsify = require(\"tsify\");const watchify = require(\"watchify\");const gutil = require(\"gulp-util\");const uglify = require('gulp-uglify');const sourcemaps = require('gulp-sourcemaps');const buffer = require('vinyl-buffer');const paths = { pages: ['src/*.html']};const watchedBrowserify = watchify(browserify({ basedir: '.', debug: true, entries: ['src/main.ts'], cache: {}, packageCache: {}}).plugin(tsify));gulp.task(\"copy-html\", function () { return gulp.src(paths.pages) .pipe(gulp.dest(\"dist\"));})function browserifyBundle() { return watchedBrowserify .transform('babelify', { presets: ['env'], extensions: ['.ts'] }) .bundle() .pipe(source('bundle.js')) .pipe(buffer()) .pipe(sourcemaps.init({ loadMaps: true })) .pipe(uglify()) .pipe(sourcemaps.write('./')) .pipe(gulp.dest(\"dist\"));}gulp.task(\"browserify\", function () { return browserifyBundle();})gulp.task(\"default\", gulp.series('copy-html', 'browserify'));watchedBrowserify.on(\"update\", browserifyBundle);watchedBrowserify.on(\"log\", gutil.log); 修改 tsconfig.json 123456789{ \"files\": [ \"src/*.ts\" ], \"compilerOptions\": { \"noImplicitAny\": true, \"target\": \"es2015\" }} 编译并在浏览器打开 dist/index.html 12# 通过gulp编译代码npx gulp 显示器中会显示 “Hello from TypeScript” 字样。 我们看到 main.ts 调用了 greet.ts 的函数, 并生成一个 bundle.js 文件, 在 index.html 中被加载使用. 调用JavaScript文件 为了使用以前已经存在的JavaScript库文件, 在 src 下新建一个文件夹 libs 用来存放第三方JavaScript. projectRoot ├── src/ │ ├── libs/ │ │ ├── lunar.js │ ├── main.ts │ └── greet.ts │ ├── dist/ └── tsconfig.json 1234567891011121314151617181920212223# src/libs/lunar.jsLunar = { Name: \"Dick\", sayHallo:function(){ return 'i am Lunar'; }} function Ab () { this.a = 1 } Ab.prototype.seta = function (num) { this.a = num } Ab.prototype.geta = function (num) { return this.a } exports.Ab = Abexports.Lunar = Lunar; 修改 greet.ts 文件, 调用 src/libs/lunar.js 中的函数和对象 123456789declare function require(path: string): any;var ln = require(\"./libs/lunar\");export function sayHello(name: string) { ln.Ab = 10 console.log(ln.Ab) return `Hallo von ${name}, ${ln.Lunar.Name}`;} TypeScript使用tsconfig.json文件管理工程配置,例如想包含哪些文件和进行哪些检查。 123456789101112131415{ \"compilerOptions\": { \"noImplicitAny\": true, //\"outDir\": \"./dist\", //不需要. gulpfile.js 已经处理过了 \"allowJs\": true, \"target\": \"es2015\", \"esModuleInterop\": true /* Enables emit interoperability between CommonJS and ES Modules via creation of namespace objects for all imports. Implies 'allowSyntheticDefaultImports'. */ }, \"files\": [ \"src/*.ts\" ], \"include\": [ \"./src/**/*.js\" ]} 我们看到网页显示 Hallo von TypeScript, Dick, 打开chrome的开发者工具, 看到console 中写出 10. Unit-Test 参考:Unit testing node applications with Typescript – using nocha and chai 安装测试包文件 1npm install chai mocha ts-node @types/chai @types/mocha --save-dev 新建一个test目录专门存放测试文件,并新建一个测试文件 test/ganzhi.spec.ts 1234567891011import { expect } from 'chai';import 'mocha';describe('干支 function', () => { it('should return hello world', () => { const result = 'Hello world!'; expect(result).to.equal('Hello world!'); }); }); 在 package.json 文件中配置测试参数和路径 12345{ \"scripts\": { \"test\": \"mocha -r ts-node/register test/**/*.spec.ts\" }} 运行测试 $ npm run test > huahets@1.0.0 test /Users/mai/Projects/huahets > mocha -r ts-node/register test/**/*.spec.ts 干支 function ​ ✓ should return hello world 1 passing (19ms) 错误处理 假设有以下函数调用中LandMaps.FindCity会给出一个异常。 123var result = LandMaps.FindCity(\"xx省\", \"xx市\");expect(LandMaps.FindCity.bind(LandMaps, \"err\", \"\")).throw(\"Error Message\") # 或者expect(LandMaps.FindCity.bind(LandMaps, \"err\", \"\")).throw(new Error(\"Error Message\")) 打包 用 TypeScript 编写函数库 require.js 官方文档 通过上述方式生成的 bundle.js 文件不能被浏览器直接使用。参考上面两个网页提供的方式,可以生成给浏览器用的单一js文件。 新建一个入口文件,将所有接口都连接起来,并统一导出 1234567891011# yixue.tsimport {TYDate, TYLunar} from \"./tylunar\";import {GanZhi} from \"./ganzhi\";import {ShenSha} from \"./shensha\";import {WuXing, FetchWuXing} from \"./wuxing\";import {Gua} from './gua'import {LandMaps} from \"./landmaps\"exports.GanZhi = GanZhiexports.TYDate = TYDateexports.Gua = Gua 设置tsconfig.json让编译后的文件导出到dist/cmjs目录 123456789101112{ \"compilerOptions\": { \"target\": \"es5\", \"module\": \"commonjs\", \"moduleResolution\": \"node\", \"outDir\": \"dist/cmjs\", \"rootDir\": \"./src\", \"declaration\": true, \"sourceMap\": true, \"lib\": [\"dom\", \"es6\"] }} 通过命令 tsc 编译 1tsc -P tsconfig.json 也可以在 package.json 中设定,然后运行 npm run build:cmjs 编译。编译后的 yixue.js 文件就是统一入口。 yi xue.js 实际就是个目录,我需要将其打包成一个单一文件。 安装 browserify , 1browserify dist/cmjs/base/yixue.js --standalone huahejs -o dist/web/yixue.js 下载 require.js, 并放到项目目录中。以下方式将 yixue.js 中的 class GanZhi 设为当前网页的一个全局函数。其它函数就可以调用。 123456789101112131415161718192021222324252627282930313233<!DOCTYPE html><html> <head> <meta charset=\"UTF-8\" /> <title>易学包</title> <script type=\"text/javascript\" src=\"libs/require.js\"></script> <body > <p id=\"greeting\">易学包测试</p> <script> var newGanZhi requirejs([\"web/yixue\"], function(yixue) { console.log(yixue) newGanZhi = function(arg){ return new yixue.GanZhi(arg) } init() }); function init(){ console.log(\"init will be called\") var ele = document.getElementById(\"gz1\") var gz = newGanZhi(1) ele.innerText = gz.Name } </script> <div id=\"gz1\"></div> <div name=\"gua\">gua</div> </body></html> 在 Node.js 中调用更简单 1const {Gua, GanZhi, TYDate} = require(\"./web/yixue\") 需要更详细代码请下载项目: 演示项目地址","categories":[{"name":"IT","slug":"IT","permalink":"http://maiernte.github.io/wiki/categories/IT/"},{"name":"skill","slug":"IT/skill","permalink":"http://maiernte.github.io/wiki/categories/IT/skill/"}],"tags":[{"name":"工具","slug":"工具","permalink":"http://maiernte.github.io/wiki/tags/工具/"}]},{"title":"还在用七牛?","slug":"IT/skill/还在用七牛","date":"2019-08-14T21:41:28.000Z","updated":"2019-08-15T06:54:53.000Z","comments":true,"path":"still-using-qiniu.html","link":"","permalink":"http://maiernte.github.io/wiki/still-using-qiniu.html","excerpt":"自从七牛换了服务条款,每个空间就只分配测试域名, 30天到期。想省钱的用户,必须每30天倒腾一次。如果忘记了,过了期限,据说图都找不回来。不想费那个劲的用户, 得绑定自己的域名。 这样不但增加费用,还要考虑到域名备案。 十分麻烦。","text":"自从七牛换了服务条款,每个空间就只分配测试域名, 30天到期。想省钱的用户,必须每30天倒腾一次。如果忘记了,过了期限,据说图都找不回来。不想费那个劲的用户, 得绑定自己的域名。 这样不但增加费用,还要考虑到域名备案。 十分麻烦。 这是我弃用七牛的主要原因。 第二个原因就是——慢! 也许我人在国外的原因吧, 每次打开七牛的后台,刷好几遍都打不开对象存储的页面,只能用第三方软件进行上传下载,那样会相对好一些. 第三个原因是七牛的图床不能分目录存储。 当图片越积越多的时候,管理和查找起来非常麻烦。比如我昨天用Typora的Pandoc功能将一个Word技术文档转换成MD文件,一个文件就有100来张图。放在七牛得分好几页显示了。如果再想找别的图, 那得多费劲. 后来还是把心思用在了Github上。 在自己的账号下新开一个仓库, 然后在自己的本地电脑专建立一个文件夹, 用来存放MD文档或者博客中使用到的图片, 把这个专门的文件夹推送到新的仓库就完了! 相比七牛, Github还有不少优势: 可以分多级目录存储 传输速度快 !(可能国内慢吧, 但国内可以同样的思路, 放到 Coding 或者 CSDN 上 ) 免费 不限流量 还要我说啥呢? 但引用Github图片, 要做一个小小的改动. 比如Github上一个图片的原始地址是: https://github.com/maiernte/img/blob/master/books/ng-book2-71/image100.png 需要把其中的 blob 改成 raw, 变成 https://github.com/maiernte/img/raw/master/books/ng-book2-71/image100.png 自打有了Github这个神器, 可以跟七牛说再见! 再也不见!","categories":[{"name":"IT","slug":"IT","permalink":"http://maiernte.github.io/wiki/categories/IT/"},{"name":"skill","slug":"IT/skill","permalink":"http://maiernte.github.io/wiki/categories/IT/skill/"}],"tags":[{"name":"工具","slug":"工具","permalink":"http://maiernte.github.io/wiki/tags/工具/"}]},{"title":"Gitbook攻略","slug":"IT/Tools/Gitbook攻略","date":"2019-08-14T21:02:14.000Z","updated":"2019-08-15T09:46:18.000Z","comments":true,"path":"gitbook_with_typora_gh-pages.html","link":"","permalink":"http://maiernte.github.io/wiki/gitbook_with_typora_gh-pages.html","excerpt":"本文为你介绍如何使用利用 Typora + gitbook-cli + Github Pages 书写Gitbook. 在本地用 Typora 书写 md 文件, 用 gitbook-cli 编译, 最后发布到 Github Pages 上.","text":"本文为你介绍如何使用利用 Typora + gitbook-cli + Github Pages 书写Gitbook. 在本地用 Typora 书写 md 文件, 用 gitbook-cli 编译, 最后发布到 Github Pages 上. 安装 前提是已经安装了Node, 直接用npm包管理工具安装: 12sudo npm install -g gitbook-cligitbook -V # 注意是大写V CLI version: 2.3.2 GitBook version: 3.2.3 新建书籍 为新书建立一个根目录 mkdir pytho_finance 在该目录下执行(命令行下):gitbook init,之后会在该目录下产生2个文件,分别是README.md(书籍的介绍)和SUMMARY.md(书籍的目录结构)。 按照上图格式填写目录和文件, 然后再次执行 gitbook init , GitBook 会查找 SUMMARY.md 文件中描述的目录和文件,如果没有则会将其创建. 然后就可以预览书籍了 gitbook serve. 执行命令后会对 Markdown 格式的文档进行转换,默认转换为 html 格式,提示Serving book on http://localhost:4000,打开网址即可查看. 构建书籍 1gitbook build 默认将生成的静态网站输出到 _book 目录。实际上,这一步也包含在 gitbook serve 里面,因为它们是 HTML,所以 GitBook 通过 Node.js 给你提供服务了。 build 命令可以指定路径, 或者指定端口, 或者生产 pdf , epub, mobi 等格式. 具体参考文章. 发布到Github Pages 12345git initgit remote add origin https://github.com/maiernte/gitbook_python_finance.gitgit add .git commit -m \"new book\"git push -u origin master # 将源代码推送到master 在GitHub的仓库中新添一个 gh-pages 的Branch. 1234567891011121314mkdir new_foldcd new_foldrm -rf . # 删除这个目录下所有文件, 注意那 .git 文件夹不能删除# 在源代码目录中,也就是md文件的目录gitbook build # 将会产生一个 _book 目录# 添加忽略, 以免下次推送的时候 _book 目录被推送.echo \"*~\" > .gitignoreecho \"_book\" >> .gitignoreecho \"/node_modules\" >> .gitignorecp -r _book/* path_to/new_fold :pen: 忽略文件夹,windows下的测试是 /node_modules, 不加双引号。 进入新目录, 推送编译后的html 和 js 文件到 gh-pages 的分支中去. 1234cd path_to/new_foldgit add .git commit -m \"to gh-pages\"git push -u origin gh-pages 如此实现了将源代码保存到master, 将静态网站推送到gh-pages, 一个仓库搞定! 在浏览器输入仓库地址, 就可以看到自己的Gitbook. 比如我新书地址 https://maiernte.github.io/gitbook_python_finance/ 更新和维护 因为master 和 gh-pages 上存放的是不同的文档,所以拉取的时候也有指定 branch 12345# 拉取源代码git clone https://github.com/maiernte/gitbook_python_finance.git --branch master new_fold# 拉取静态网站git clone https://github.com/maiernte/gitbook_python_finance.git --branch gh-pages new_fold 个性化配置 在项目的根目录上添加一个 book.json 文件, 用来更全面的配置项目. 比如头文件, 插件等等. 123456789101112{ \"title\": \"使用Python处理金融数据\", \"author\": \"鎏金天涯 <mai.yongfeng@gmail.com>\", \"description\": \"使用Python处理金融数据的各种技术\", \"generator\": \"site\", \"plugins\": [\"mathjax\"], \"links\": { \"sidebar\": { \"鎏金天涯个人博客\": \"http://goldentianya.pub\" } }} 数学插件 在上述文件添加了 "plugins": ["mathjax"], 并执行命令 1gitbook install ./ # 会添加一堆 node_modules 包 更详细的配置请参阅官方文档. 目录插件 项目地址和文档 将 book.json 文件修改为 "plugins": ["mathjax", "page-toc" ], ​ 每一页的目录就会出现在右上角。 编译错误列表 版本 12CLI version: 2.3.2GitBook version: 3.2.3 sharing 插件出错 添加了 page-toc 插件后,gitbook serve 的时候总是出现错误。就算把文章改回原来的样子也无补于事。 info: 7 plugins are installed info: loading plugin “livereload”… OK info: loading plugin “highlight”… OK info: loading plugin “search”… OK info: loading plugin “lunr”… OK info: loading plugin “sharing”… OK info: loading plugin “fontsettings”… OK info: loading plugin “theme-default”… OK info: found 1 pages info: found 0 asset files Error: ENOENT: no such file or directory, stat ‘D:\\f040371\\git_book\\plattform_finance_book\\gitbook\\gitbook-plugin-sharing\\buttons.js’ 解决方法 修改 C:\\Users\\f040371\\.gitbook\\versions\\3.2.3\\lib\\output\\website\\copyPluginAssets.js 文件中的 112 行 将 confirm: true 改为 confirm: false 参考文章: 使用GitBook和Typora写知识库 gitbook+git+typora 的使用过程 GitBook + Typora + Git 编写电子文档 Gitbook 发布到 Github Pages","categories":[{"name":"IT","slug":"IT","permalink":"http://maiernte.github.io/wiki/categories/IT/"},{"name":"Tools","slug":"IT/Tools","permalink":"http://maiernte.github.io/wiki/categories/IT/Tools/"}],"tags":[{"name":"工具","slug":"工具","permalink":"http://maiernte.github.io/wiki/tags/工具/"}]},{"title":"配置服务器端MySQL","slug":"IT/Tools/配置服务器端MySQL","date":"2019-08-06T15:26:28.000Z","updated":"2019-08-14T13:10:45.000Z","comments":true,"path":"config-mysql-access-privileges-on-vps.html","link":"","permalink":"http://maiernte.github.io/wiki/config-mysql-access-privileges-on-vps.html","excerpt":"","text":"文章 问题一:端口状态 查看 3306 端口状态 sudo netstat -an | grep 3306 tcp 0 0 127.0.0.1:3306 0.0.0.0:* 3306端口是默认绑定在本地IP 127.0.0.1上的,所以外网无法访问该主机的3306端口。 打开MySQL的配置文件:sudo vim /etc/mysql/mysql.conf.d/mysqld.cnf 找到如下内容的一行并注释掉: bind-address = 127.0.0.1 重启MySQL服务 sudo systemctl restart mysql 然后使用如下命令查看端口绑定状态 sudo netstat -an | grep 3306 问题二:用户权限 查看用户权限 123sudo mysql -uroot -p[你的密码]use mysqlselect user,host from user 当显示如下,表示用户root只允许内网访问 root localhost 给用户授权 12grant all privileges on *.* to 'root'@'[允许的ip]' identified by '[密码]' with grant option;flush privileges; 其中*[允许的ip]如果设置为*%**的话则表示所有$ip$都可以访问,*[密码]*表示外网访问的密码是什么。比如我设置成所有$ip$都可访问,密码是$root$,则命令如下: 123grant all privileges on *.* to 'root'@'%' identified by 'root' with grant option;flush privileges;select user,host from user; 重新查看,会显示 root % root localhost 安装 phpMyAdmin","categories":[{"name":"IT","slug":"IT","permalink":"http://maiernte.github.io/wiki/categories/IT/"},{"name":"Tools","slug":"IT/Tools","permalink":"http://maiernte.github.io/wiki/categories/IT/Tools/"}],"tags":[{"name":"工具","slug":"工具","permalink":"http://maiernte.github.io/wiki/tags/工具/"}]},{"title":"斯多葛主义手册","slug":"读书笔记/斯多葛主义手册","date":"2019-08-03T19:16:47.000Z","updated":"2019-08-14T06:31:28.000Z","comments":true,"path":"storic-summary.html","link":"","permalink":"http://maiernte.github.io/wiki/storic-summary.html","excerpt":"世间的事,有些可控,有些不可控。可控的有:观点,追求,欲望,和喜恶等。这些都是我们自己可以做出选择的。不可控的是身体,财物,名声,指令等。这些我们都无法选择。","text":"世间的事,有些可控,有些不可控。可控的有:观点,追求,欲望,和喜恶等。这些都是我们自己可以做出选择的。不可控的是身体,财物,名声,指令等。这些我们都无法选择。 可控范围之内的东西在本质上是自由的,不被束缚、阻碍的。那些不可控的是虚的,是被奴役的,是我们受控于他人。记住,如果你觉得那些不可控的事物是自由的,那些受控于别人的也是你的,那么你就会被控制,被束缚。你会悲痛,你会受扰,你会指责神以及他人。但如果你只专注于你所能控制的,不被他人所拥有的干扰,那么就没有人能够影响你、束缚你。并且,你不会把过错推在他人身上。你不会去做违背你的意志的事。你不会有敌人。你也不会被伤害。 把这些当做你的目标,不让自己受那些没有意义的事诱惑,哪怕就一点点也不可以。放弃那些不可控的。如果你既想把握住可控的,又想拥有财富和权力,那么你将会什么都得不到,更不用说幸福和自由-因为幸福和自由是依赖于可控事物。 尽你最大的努力。这样你就可以对看似艰难的每一件事说:“你只不过是看起来艰难而已。” 然后比照你为自己制定的原则:这件事是否可控。如果在你控制范围之外,那么结果就无关乎于你。 欲望要求你去追求你想要的;厌恶则让你尽量避免你所讨厌的。但是,如果你得不到你想要的,你就会十分失望;如果你无法避免你所讨厌的,那你就会被厌恶扭曲。那么,如果你只讨厌那些在你出自本质所做选择的对立事物(即在你控制范围内你不会选择的事物),那么你就永远不需要去为之伤神。但是,如果你厌恶疾病、死亡、贫穷等你无法选择和改变的,那你就会被厌恶扭曲。不厌恶你所不能控制的,把厌恶限制在和你本性对立的事物。但是,就目前来说,压制你的欲望:因为如果你追求任何可控范围之外的事物,那你就必然会失望。不要轻易追求或者厌恶。 对于给你带来乐趣、有用处以及你十分喜欢的东西,从最不重要的事情开始,记得提醒你自己:他们真正的本质是什么。比如说,你很喜欢某个陶瓷杯,提醒你自己那只是因为你喜欢陶瓷杯而已,而不在于具体是哪个杯子。这样,如果杯子碎了,你也不会太伤心。当你亲吻你的家人时,提醒你自己你只是在亲吻和你亲近的人,这样当他们离世时,你就不会太难过。 当你做事情时,提醒你自己事情的本质是什么,你可能遇到哪些情况。比如说洗澡。在你洗澡之前,先想想洗澡时会发生哪些事情。有的人可能会把水溅得哪都是,有人可能会推娜,有人会诅咒,有人会偷东西。这样你在洗澡之前就可以跟自己说:“我现在要去洗澡了,任何这些事都有可能发生,但是这不是我能控制的,所以我会保持好的心态”。如果你以同样的心态去对待任何其他事情,你内心的平和就不会被打扰。因为你可以对自己说:”我希望的不仅仅是洗澡,还有不被任何意外困扰”。 人内心困扰时,通常不是被事物本身困扰,而是被他们自己的原则和概念所困扰。比如说,死亡本身并不可怕,要不然苏格拉底面临死亡时该有多么惊慌。我们对死亡的恐惧是源于我们对死亡的概念:死亡是可怕的。当我们被困扰、阻碍,伤心难过时,我们不要从事物本身或者他人身上找原因,而应该反省我们自己,还有我们的原则。一个还不通明的人,会把自己的糟糕情况怪罪于他人。一个刚刚开始学习处理这些情况的人,会从自己身上找原因。而一个已经通彻的人,既不会怪罪别人,也不会苛求自己。 不要为任何身外之物骄傲。一匹马可以因为自己的英爽豪气自豪,因为这是它本身拥有的。但是如果你因为拥有这样一匹马儿骄傲,事实上,你所自豪的,不过是马所拥有的好。那么,什么才是属于你的呢?你对事物的反应和态度。如果你对任何事物的形态的处之泰然,那么你就可以为你的理性自豪,因为这是属于你的。 想象以下情况:在一次航海旅行中,你的船抛锚靠岸了,你上岸去找水,途中你还捡了些你喜欢的贝壳,或者买个洋葱。但是,你的所有注意力必须一直集中在那艘船上,注意船长什么时候呼叫大家上船继续航行。当船长呼叫时,你必须立刻放下手中所有的东西,否则你就会被手脚捆绑得像只羊一样抛到船上。生活也是这样。生活给你老婆孩子,而不是洋葱贝壳。如果生活的船长呼叫了,你必须离开他们,立马跑到船上,而不是光顾着他们。如果你年纪大了,那你就不能离开船太远,否则你可能来不及回到船上。 不要苛求生活给予你所有你想要的,该发生的就会发生,随遇而安就好。 疾病影响的只是你的身体,而不是你选择的能力,除非那是你的选择。瘸的是腿,而不是你的脑子。不管发生什么事,只要这么跟自己说,你就会明白困难阻碍的是事物,而不是你。 对于每一件发生的事,检视你自己的能力,问你自己能够用哪些能力从每一件事情中获得什么适当的用处。遇到一个十分有吸引力的人时,你就会发现你的自控就是你的能力。当你痛苦时,你会发现自己的坚强。听到坏话时,你会发现自己的耐心。形成了这样的习惯之后,你就不会被事物的表象所影响。 不要说:“我失去了什么”。而应该说:“我归还了什么”。如果你的孩子或者妻子不幸离世了,你不是失去他们了,而是他们回归了。如果你的房子被夺走了,同样的,你是归还它们了。你可能会说:“可是那些夺走我房子的人是坏人!“。可是,给予你的人让谁来夺走你的房子真的那么重要吗?当你拥有时,照顾好它,但不要把它当做永久财物,就当自己是一个在那暂住的旅行者。 如果你想要提高自己,那就要拒绝以下思考方式:“如果我忽视那些琐事,那我就没有收入;如果我不更正我的仆人,那他们就会变坏”。 如果能够免于悲伤和恐惧,即使死于饥饿,那也比富得流油但备受精神困扰好得多。比起坏仆人,难道你的开心不是更重要吗? 如果你想要让自己变得更好,那就从小事做起。油洒了,酒被偷了,没关系,告诉你自己:“那只不过是平静生活的一点点代价。任何事情都是有代价的”。当你召集你的仆人时,他们可能不会来,也可能来了但是做的事情不合你意。但是他们并没有重要得以至于你必须打破自己的平静。 如果你想要让自己变得更好,那就不要在乎被人认为你是愚蠢的。不要希望别人认为你无所不知。即使你看上去好像对别人来说很重要,也不要被这种虚名欺骗。因为想要既保持内心平和又拥有外在事物是非常困难的。当你专注于二者之一时,你必然会忽略剩下的那个。 如果你希望你的家人、朋友长生不老,那是很愚蠢的想法。因为生死是在你控制范围之外的,是关乎他人的。同样地,如果你希望你的仆人不犯错,那你和傻瓜无异,因为你希望错误不是错误。但是,如果你希望你的欲望不带来失望,那是在你所能控制的范围之内的。练习控制你所能控制的。一个能够控制自己的喜恶的人,是自己生活的主人。这样的人,是真正自由的,不会成为被自己的欲望控制的奴隶,不会喜欢或者厌恶那些受别人控制的事物。 记住生活就像是一个晚餐聚会一样。如果别人递给你一盘食物,你应该伸出手去接,舀起适当份量给自己。如果盘子从你身边递过,不要试图去截取。如果还没轮到你这,不要起身去拿,而是等着别人递到你面前。用相同的态度对待孩子,配偶,财物,公共职位,这样你最终自然就会成为诸神宴会的搭档。如果你不仅能够做到这些,还能够做到不去拿你面前的食物,甚至是有能力拒绝你自己的欲望,这样你不仅仅能够成为诸神宴会的搭档,你还能进入他们的国度,成为为他们的一员。像Diogenes, Heraclitus这些人就是因为他们的尊贵行为而被视为神一般神圣。 当你看到别人因为孩子出国了,或者离世了,或者因为被琐事困扰而哭泣伤心时,不要让这些情感表象误导你。你必须作出自己的判断,明白他的伤心难过不是因为发生的事情本身,因为其他同样身处其中的人并没有受到同样的影响。他之所以受到那么大的困扰,是因为他自己本身对事情的判断。不要让自己和他一样受影响,不要让自己一样受困扰,不管是外在表现还是内心感受上。 记住你只是一出戏里的一个演员,而戏份角色并不是由你决定的。不管角色故事长短,不管你是一个穷人,瘸子,政府官员,或者是一个很私密的人,把你的角色演好演自然了就行。把分配给你的角色演好,那是你的本分;而到底是哪个角色,那不是由你决定的。 如果一只乌鸦向你预示不幸的事即将发生,不要让你内心的平静被这个表象破坏。要即刻告诉自己,“我不知道会发生什么,我不知道我的身体,财物,名声,或者家人会受什么影响,如果我愿意理性地去想,那么所有的这些恶兆就会变成幸运,因为我可以控制我要用什么态度去对待这些事情。不管发生什么,我都可以从中获得对我有利的。 如果你不去参与在你控制范围之外的任何战斗,那你就不会被打败。当你看到那些声名显赫,社会地位高,或者在任何方面做得很好的人,不要着急认为他们是开心的。因为如果我们清楚明白幸福只在于我们所能够控制的范围内,那我们就不会去羡慕或者攀比。不要向往头衔,而是要向往内心自由和平静。而要做到这一点,唯一的途径是要看轻我们控制范围之外的一切事物。 记住,那些对你出言不逊或者动手的人他本身并不是一种羞辱,而是代表那些言行的原则让你感觉到被羞辱。如果有人激怒你了,那是你对这种行为的观点激怒了你。试着不要被事情的表象牵引你的情感。给予适当的时间和稍作休息,你就能够很好地调整控制自己的情感。 把死亡和流放这些看似可怕的事看作是日常,那你就赢了。不用害怕贫穷,也不要刻意贪求任何东西。 如果你真心希望从哲学中获益,那么就要做好被众人嘲笑的准备:“她这是准备要成为一个哲学家呢”,“瞧她那傲慢的样子”……这个时候,你该做的,不是摆起傲慢的样子,而是要以神圣的态度忠诚于你所认定的,这样总有一天嘲笑你的人会开始尊敬你崇拜你。但是如果你被这些嘲笑打败,那你就成了双重的笑话。 如果你为了取悦他人而把你的注意力转移到那些外在的你无法控制的事物上,那么恭喜你,你已经成功地毁了你自己的生活了。 不要让以下这些思考方式困扰你:“我将会颜面丢尽,而且什么都不是。”耻辱是邪恶的,我们不应该被耻辱感所控制。因为获取权力或着被人嘲笑,这些都在你的控制范围之外。我们不用为任何在我们控制范围之外的事而感到耻辱。在我们可控范围之内,我们是自由的,能够左右我们自己的事情,是自我的主人-从这个角度看,我们永远不会什么都不是。“可是我帮不了我的朋友啊”,你可能会这么说。可是,怎么算是帮助朋友呢?你不能给他们钱,或者帮他们成为罗马市民。这些都是你所能控制范围之内的,是他们自己应该处理的事情。而且,如果这些都是你自己所没有的,那你怎么能够给他们呢?你可能会说:“如果我帮助他们获得这些的话,说不定我也能够得到一份呢“。如果我能够在保存我自己的尊严,忠诚和思想得到这些的话,请你帮我指明道路。可是如果你要我损害自己去得到你的利益,那这样的做法不仅不公平,而且愚蠢至极。 如果别人,而不是你,被邀请去宴会,或者被赞美,或者被别人咨询,不要懊恼。如果这些是好事,你应该为他人高兴。如果是坏事,不要难过。记住:这些都是在你的控制范围之外的,这样的对待一般是有对应的代价的。如果你不愿意付出这样的代价而希望得到同样的对待,那是不公平的。比如说别人用50分买了一棵生菜,但是你不想花这50分,那你就不应该认为拥有生菜的人占了便宜。那个人付出50分得到了生菜,而你口袋里还有那没有花出去的50分。同理,宴会邀请,别人的赞美,这些都是有代价的。如果你觉得这些对你是有价值的,那你就要付出同等的价值去拥有。如果你不付出就想要得到这些,那么你就是个贪得无厌的傻瓜。换个角度想,在决定不和别人交换价值的时候,你真的什么都没有得到吗?不是的:你得到了不赞美你不想赞美的人的自由,而且也不需要容忍你不想容忍的行为。 记住:很多事情不应该分自我或者他人。举个例子,如果邻居家的孩子打破了个杯子或者其他什么东西,我们很容易会说:“没事的,打碎东西是正常的”。可是如果打碎的是你自己的杯子呢?你应该作出相同的反应,而不是心生懊恼。同理,当别人的孩子或者妻子去世了,我们知道死亡的悲剧有时候是不可避免的,但是如果发生在我们自己身上的时候,我们却心如刀割。但是,我们应该清醒的认识到类似的悲剧不是我们能够控制的,我们所能够控制的是自己的情绪和反应,因为即使是发生在自己的身上,死亡本身并没有因为我们和死者的关系而变的更糟糕。 立一个靶子的目的,不是为了射失它(靶子的目的都是为了让人射中它)。那么同样的道理,大道创造出一个“恶”的事物(至少看起来如此),不是为了让人绕开它。 如果别人把你的身体交给一个路上遇到的陌生人,你一定会很生气。可是当别人用恶语打击你的时候,你为什么要心甘情愿地让别人控制你的思想,困惑你呢? 做每件事情都要考虑缘由和后果之后才能开始行动。如果你兴高采烈地开始而没有考虑可能发生的后果,当某些不好的后果开始出现时,你就会停止前进。拿参加奥林匹克赛事为例子。如果你把所有前因后果都考虑周全后认为参加比赛对你时有益的,那就全力以赴。其中,应该考虑的事情包括:你要遵守规则,节制饮食;不管风吹日晒雨淋都要雷打不动地坚持按时锻炼;你不能喝凉水活着酒。你必须全身心地、完全忘我地投入训练。而且,要做思想准备准备,比赛中你有可能会摔入沟里,胳膊脱臼,脚踝受伤,吃入尘土,被鞭打,甚至最后以失败告终。当你评估完所有的可能性之后还是一心想比赛,那就以战争的姿态出发。否则,你就会像孩子过家家一样:一会扮摔跤手,一会扮角斗士,一会吹喇叭,一会又想参加戏剧演出。这样,即使你什么都做过,但是什么都不是。就想大猩猩一样,你模仿你所看到的一切,不停地换把戏可能是一件好玩的事,但是你很快就玩腻了。你从来都没有完全投入过任何事,没有深度地从各个角度考虑和研究所有相关的细节,而只是凭一时的兴趣蜻蜓点水般地接触了各种行业。有些人当他们看到一个人说话的方式和Euphrates十分相像(不过事实上,真的有人能和Euphrates一样犀利善辩吗?),他们认为自己也能够拥有和哲学家一样的思想。但是,如果你细想一下,如果你想要成为一个摔跤手,那么你必须具备有摔跤手的宽阔肩膀,强有力的背部和大腿。但是每一个人的身体构造都是不一样的,你必须具有必备的条件才能称为一个好的摔跤手。同理,要想成为一个哲学家,你不能像你现在这样随心所欲地吃喝,不能让愤怒和不满控制你的情绪,你必须细心观察,劳作,控制自己的欲望,你必须能够忍受孤独,仆人的不敬,和外人的嘲笑,你必须能够接受别人在其他方面做得比你好。如果你已经仔细考虑过这些情况,如果你认为如果做到以上这些可以让你享受自由和宁静,那就尽情去追求哲学家的道路。如果你无法做到这些的话,那么就请不要继续,不要像孩子一样,一会试试做哲学,一会又想当政治家,演讲者,或者凯撒的军官。这些追求是互相矛盾的,你只能成为其中一个,不管做得好坏。你必须培养你自己内在的能够掌控行为的能力,或者外在的技术,二者只能取其一。 一个人的责任是由和别人的关系定义和衡量的。如果一个人拥有父亲的角色,那么他就有以下权利:他的孩子要照顾他,遵从他,耐心听他训话和教导。那如果他不是一个好父亲呢?他也应该受到同等的对待,因为我们无法选择我们的父亲是谁。不管他做了什么,你必须做到让自己心安理得。因为只有你能够让别人的行为伤害到你。当你觉得你被伤害了,那你就会被伤害。如果你以同样的逻辑看待邻居,市民,将军这些不同的角色,你就能够清楚地明白与这些角色相对应的社会责任。","categories":[{"name":"读书笔记","slug":"读书笔记","permalink":"http://maiernte.github.io/wiki/categories/读书笔记/"}],"tags":[{"name":"哲理","slug":"哲理","permalink":"http://maiernte.github.io/wiki/tags/哲理/"},{"name":"书籍","slug":"书籍","permalink":"http://maiernte.github.io/wiki/tags/书籍/"}]},{"title":"同步Hexo文章与Mac上原笔记的分类和标签","slug":"IT/Web/同步Hexo文章与Mac上原笔记的分类和标签","date":"2019-08-01T15:30:00.000Z","updated":"2019-08-03T12:58:26.000Z","comments":true,"path":"synchron-the-tag-and-categories-btw-pc-hexo.html","link":"","permalink":"http://maiernte.github.io/wiki/synchron-the-tag-and-categories-btw-pc-hexo.html","excerpt":"","text":"最近才搞明白,原来Hexo博客的_post文件夹里面的Markdown原文件是可以按照分级嵌套的目录结构摆放的。编译的时候才放到public这个单一目录下。如果能让文章在Hexo的==分类==严格跟md文件的存储目录一一对应,将来需要找原文件的时侯会方便很多。😄 使用Mac系统的同学也知道,mac有个很风骚的操作,就是给文件分配不同颜色的标签,非常方便文件寻找。我也希望博客上的文章标签,能跟Mac系统里的标签统一起来。:smile: 实现物理存储目录与Hexo分类统一很简单,将源md文件的相对存储路径写到文件meta元素的categories里面就行了。比如源文件放在我的博客-->IT-->前端,文章的头文件就写成这样:categories:[IT, 前端]。 实现标签的统一稍微麻烦一点,需要先读取文件实际分配到的标签。网上已经有一个公开的项目, tag 。下载并安装,就可以通过 tag 命令读取文件和文件夹的标签。 123456# 安装brew install tag# 查看版本tag --version# 读取文件标签tag --list fileUrl 我已经写好了相应的脚本文件,下载并执行脚本文件就好了。脚本文件里的dirPath变量是我的统一存放md源文件的文件夹,你需要改成自己的存放路径,那样就不用每次运行的时候输入一遍。 我在Hexo项目的根目录新添一个文件夹专门存放管理的脚本文件,每次都在终端运行这个脚本,所以默认执行路径是 ./source/_post。 运行脚本的时候可以设定时间参数,过滤掉太久远的文件。默认情况不会更改文件内容,只查看文件的实际分类和标签是否与文内头文件相同。然后按照给出的列表手动更改。如果想让程序自动更改,按照提示输入fix参数就好。","categories":[{"name":"IT","slug":"IT","permalink":"http://maiernte.github.io/wiki/categories/IT/"},{"name":"Web","slug":"IT/Web","permalink":"http://maiernte.github.io/wiki/categories/IT/Web/"}],"tags":[{"name":"Hexo","slug":"Hexo","permalink":"http://maiernte.github.io/wiki/tags/Hexo/"},{"name":"Mac","slug":"Mac","permalink":"http://maiernte.github.io/wiki/tags/Mac/"}]},{"title":"有用的Shell命令","slug":"IT/Tools/有用的shell命令","date":"2019-07-30T15:30:28.000Z","updated":"2019-08-14T13:12:36.000Z","comments":true,"path":"helpfull-shell-command.html","link":"","permalink":"http://maiernte.github.io/wiki/helpfull-shell-command.html","excerpt":"在线网站可以找到基本的东西:Linux命令大全 shell 正则表达式 文件&内容检索 正则表达式注意的地方 花括号之前要加转义字符 [a-z]\\{3\\} 空格就是转义加空格\\ ,而不是\\s 。如 [a-z0-9_\\ ]\\{3,\\} 这几个符号 _ - . #都不需要加转义符。 不要轻易加==行结束符==$,可能回车才是最后符号,所以可能找不到。","text":"在线网站可以找到基本的东西:Linux命令大全 shell 正则表达式 文件&内容检索 正则表达式注意的地方 花括号之前要加转义字符 [a-z]\\{3\\} 空格就是转义加空格\\ ,而不是\\s 。如 [a-z0-9_\\ ]\\{3,\\} 这几个符号 _ - . #都不需要加转义符。 不要轻易加==行结束符==$,可能回车才是最后符号,所以可能找不到。 grep 12345678910# -r 递归搜索子目录# -l 只显示文件# -n 显示文件和匹配的行# 搜索 “markdown” 字符串并输入到文件里# Formating the Results...grep $begrif $directory $args |awk '{ print \"[\" $1 \"](\" $1 \")\\n\" }' > suchergebnisse.md# 将结果转为Windows目录sed -i -- 's/\\/D\\//D:\\/\\//g' suchergebnisse.mdecho \"Fertig! Ergebnisse siehe Datei 'suchergebnisse.md'\"read 更多参数请读此文 示例脚本 grep 正则表达式的例子 1234567891011#!bin/bash# {#part0000_split_050.html#nav_point-99 .calibre13}result=$(grep '{#part0000_split_[0-9]\\{3\\}.html[a-z0-9_\\ -.#]\\{3,\\}calibre13}' 文件名)if [ \"$result\" = \"\" ];then echo \"Nichts gefunden!\"fiecho $resultread grep或操作 123grep -E '123|abc' filename // 找出文件(filename)中包含123或者包含abc的行egrep '123|abc' filename // 用egrep同样可以实现awk '/123|abc/' filename // awk 的实现方式 grep与操作 1grep pattern1 files | grep pattern2 //显示既匹配 pattern1 又匹配 pattern2 的行。 其它常用选项 12345grep -i pattern files //不区分大小写地搜索。默认情况区分大小写,grep -l pattern files //只列出匹配的文件名,grep -L pattern files //列出不匹配的文件名,grep -w pattern files //只匹配整个单词,而不是字符串的一部分(如匹配‘magic’,而不是‘magical’),grep -C number pattern files //匹配的上下文分别显示[number]行, 点击显/隐代码 sed 命令 参考文献 文本替代 以下文本替换通过pandoc导入后的文件,残留很多内部跳转链接:如 1{#part0000_split_003.html#nav_point_1 .not-in-toc} 12345678910#!bin/bashecho running#sed 's/^#part0000_split_$/p' -f ../Linux_shell_Anleitung.md ;sed -i -- 's/^\\[\\]{#part0000_split_[0-9]\\{3\\}.html}$//g' ../Linux_shell_Anleitung.md #{#part0000_split_017.html#nav_point_21 .calibre8} {#part0000_split_003.html#nav_point_1 .not-in-toc}sed -i -- 's/{#part0000_split_[0-9]\\{3\\}.html#[a-z0-9_-]\\+ .[a-z0-9_-]\\+}//g' ../Linux_shell_Anleitung.md echo fertig!read 整行替代 参考文献 替代以 categories: 开头的整行(允许行开头有空格或制表符)。c 代表整行,以字符串 categories: [IE] 替代整行。 1234# Linux 下的写法sed -i -- '/^[[:blank:]]*categories:/c categories: [IE]' result.txt # Mac 下的写法sed -i '' 's/^[[:blank:]]*tags:.*/tags: [心理]/' $1 错误:如果将参数 c 写在前面,会将整个文本每一行都替换掉。 12# Linux 下的写法sed -i -- 'c/^[[:blank:]]*categories:/categories: [IE]/' result.txt find 1234# 查找所有的 md 文件find /root/bibliothek/markdowns/blog_posts/ -type f -name \"*.md\" # 查找一天之前的文件, 一小时前时 -1h,一周 -1wfind . -type f -mtime -1d 如果要处理复杂的事情,就要用到函数 123456789# 定义函数showFileInfo(){ echo $1}# 声明函数export -f showFileInfo# 使用函数find $dirPath -name \"*.md\" | xargs -n 1 -P 10 -I {} bash -c 'showFileInfo \"$@\"' _ {} \\; 查找最新文件 将文件按从新到旧排列,取第一个。 ls -t *.cpp | head -1 将文件按从旧到新排列,取最后一个。 ls -rt *.cpp | tail -1 列出文件时间戳 ls -l simpleNode.js |awk '{print $6 "-" $7 "-" $8 }' 整合以上两个命令,找到最新的文件,读取时间戳 ls -t *.* | head -1 | xargs ls -l | awk '{print $6 "-" $7 "-" $8 }' 字符串处理 字符串处理参考文献 将分隔符的字符串转为数组的几种方法 配合使用,可以直接用 shell 实现文件内标签和分类的替换。 数组转字符串 使用分隔符将数组转字符串: 1234ids=(1 2 3 4); lst=$( IFS='/'; echo \"${ids[*]}\" ); echo $lst# 结果是:1/2/3/4 字符串转数组 懒得写,看范例 字符串替换 12345# 原串 [娱乐,经济,重要] => 目标串 [娱乐, 经济, 重要]${tags/,/, } # 只替换了一个,结果变成 [娱乐, 经济,重要]${tags//,/, } # 替换了所有符合的,结果变成 [娱乐, 经济, 重要]# 原串 [重要] => 目标串 重要${tags//[\\[\\] ]/} 消除回车符、换行符、制表符 123# arg是个字符串变量, 可能带有回车符\\r# 把它整个作为参数使用会带来很多麻烦。用以下命令将其替换掉newvar=${arg//[$'\\t\\r\\n']/} 详细用法 参考文献 ${var##*/} 该命令的作用是去掉变量var从左边算起的最后一个’/‘字符及其左边的内容,返回从左边算起的最后一个’/’(不含该字符)的右边的内容。使用例子及结果如下: 12var=dir1/dir2/file.txt --> file.txt 从运行结果可以看到,使用该命令,可以提取出我们需要的文件名file.txt。 若使用时在shell程序文件中,可以使用变量来保存这个结果,再加以利用,如file=${var##*/} ${var##*.} 该命令的作用是去掉变量var从左边算起的最后一个’.‘字符及其左边的内容,返回从左边算起的最后一个’.’(不含该字符)的右边的内容。使用例子及结果如下: 12var=dir1/dir2/file.txt --> txt 从运行结果可以看到,使用该命令,可以提取出我们需要的文件后缀。 如果文件的后缀不仅有一个,例如,file.tar.gz,命令${var##*.}仅能提取最后一个后缀,而我想提取tar.gz时该怎么办?那么就要用下面所说的${var#*.}命令了。 ${var#*.} 该命令的作用是去掉变量var从左边算起的第一个’.‘字符及其左边的内容,返回从左边算起第一个’.’(不含该字符)的右边部分的内容。使用例子及结果如下: 12var=dir1/dir2/file.tar.gz --> tar.gz 从运行结果可以看到,使用该命令,可以提取出文件的多个后缀。 ${var%/*} 该命令的使用是去掉变量var从右边算起的第一个’/‘字符及其右边的内容,返回从右边算起的第一个’/’(不含该字符)的左边的内容。使用例子及结果如下: 12var=dir1/dir2/file.txt --> dir1/dir2 从运行的结果可以看到,使用该命令,可以提取出我们需要的文件所在的目录 ${var%%.*} 该命令的使用是去掉变量var从右边算起的最后一个’.‘字符及其右边的内容,返回从右边算起的最后一个’.’(不含该字符)的左边的内容。使用例子及结果如下: 12var=dir1/dir2/file.txt --> dir1/dir2/file 当我们需要建立一个与文件名相同名字(没有后缀)的目录与对应的文件相对应时,就可以使用该命令来进行操作。例如,解压文件的情况就与此类似,我们压缩文件file.zip时,会在与file.zip同级目录下建立一个名为file的目录。 总结 其实${}并不是专门为提取文件名或目录名的,它的使用是变量的提取和替换等等操作,它可以提取非常多的内容,并不一定是上面五个例子中的’/‘或’.’。也就是说,上面的使用方法只是它使用的一个特例。 看到上面的这些命令,可能会让人感到非常难以理解和记忆,其实不然,它们都是有规律的。 #:表示从左边算起第一个 %:表示从右边算起第一个 ##:表示从左边算起最后一个 %%:表示从右边算起最后一个 换句话来说,#总是表示左边算起,%总是表示右边算起。 *:表示要删除的内容,对于#和##的情况,它位于指定的字符(例子中的’/‘和’.’)的左边,表于删除指定字符及其左边的内容;对于%和%%的情况,它位于指定的字符(例子中的’/‘和’.’)的右边,表示删除指定字符及其右边的内容。这里的’'的位置不能互换,即不能把号放在#或##的右边,反之亦然。 例如:${var%%x*}表示找出从右边算起最后一个字符x,并删除字符x及其右边的字符。 看到这里,就可以知道,其实该命令的用途非常广泛,上面只是指针文件名和目录名的命名特性来进行提取的一些特例而已。 basename和dirname ${}并不是专门为提取文件名和目录名设计的命令,那么basename和dirname命令就是专门为做这一件事而已准备的了。 basename 该命令的作用是从路径中提取出文件名,使用方法为basename NAME [SUFFIX]。 1.1 从路径中提出出文件名(带后缀),例子如下: 1.2 从上面命令的用法中可以看到,后缀(SUFFIX)是一个可选项。所以,若只想提取出文件名file,而不带有后缀,还可以在变量的后面加上后缀名,例子如下: dirname 该命令的作用是从路径中提取出目录名,使用方法为 dirname NAME。使用例子如下: 这样就提取出了file.txt文件所在的目录。 注:该命令不仅能提取出普通文件所的目录,它能提取出任何文件所在的目录,例如目录所在的目录,如下: 它提取出了目录dir2所在的目录dir1. 查看硬盘剩余空间 12345# 整个硬盘空间df -hl# 查看某个文件夹大小du -h your_directory # 列出每个子文件夹大小du -hcs your_directory # 汇总 查看 package 版本 1apt-cache show packagename Windwos 下的脚本 windows 下显示环境变量 echo %http_proxy% windows 下设置代理服务器 $$ $$ 12set http_proxy=http://username:pwd$$$@proxy-rzf:8080set https_proxy=http://username:pwd$$$@proxy-rzf:8080","categories":[{"name":"IT","slug":"IT","permalink":"http://maiernte.github.io/wiki/categories/IT/"},{"name":"Tools","slug":"IT/Tools","permalink":"http://maiernte.github.io/wiki/categories/IT/Tools/"}],"tags":[{"name":"工具","slug":"工具","permalink":"http://maiernte.github.io/wiki/tags/工具/"}]},{"title":"Hexo日常管理","slug":"常用文件/Hexo日常管理","date":"2019-07-30T15:27:28.000Z","updated":"2019-08-02T03:54:52.000Z","comments":true,"path":"hexo-blog-alltag-verwalten.html","link":"","permalink":"http://maiernte.github.io/wiki/hexo-blog-alltag-verwalten.html","excerpt":"","text":"复制MD文件 查找最新文件 1234ls -t /Users/mai/Projects/hexo/source/_posts/*.md | head -1 | xargs ls -l | awk '{print $6 \"-\" $7 \"-\" $8 }'# 最旧的文件就应该是ls -t /Users/mai/Projects/hexo/source/_posts/*.md | tail -1 | xargs ls -l | awk '{print $6 \"-\" $7 \"-\" $8 }' 其它 Hexo 代码折叠 123{% fold 点击显/隐内容 %}需要隐藏的内容。。。{% endfold %} 参考文件 有用的shell命令 会导致编译奔溃的错误 大括号和井号连在一起 123{#、 #}、{#} 这三种情况都会导致系统奔溃{} 和 # 之间如果有别的字符就不会。如 { # }或者放在代码段内也不会。行内代码不能避免这种情形。","categories":[{"name":"常用文件","slug":"常用文件","permalink":"http://maiernte.github.io/wiki/categories/常用文件/"}],"tags":[{"name":"Hexo","slug":"Hexo","permalink":"http://maiernte.github.io/wiki/tags/Hexo/"}]},{"title":"佛偈集合","slug":"摘录/片段/佛偈集合","date":"2019-07-29T07:10:50.000Z","updated":"2019-08-15T21:46:14.000Z","comments":true,"path":"budahlisisch-poeim-collection.html","link":"","permalink":"http://maiernte.github.io/wiki/budahlisisch-poeim-collection.html","excerpt":"佛偈(jì) 虚云老和尚悟道偈 杯子扑落地,响声明历历。 虚空粉碎也,狂心当下息。 烫着手,打碎杯,家破人亡语难开。 春到花香处处秀,山河大地是如来。","text":"佛偈(jì) 虚云老和尚悟道偈 杯子扑落地,响声明历历。 虚空粉碎也,狂心当下息。 烫着手,打碎杯,家破人亡语难开。 春到花香处处秀,山河大地是如来。 布袋和尚 手把青秧插满田,低头便见水中天。 心地清净方为道,退步原来是向前。 赠药山高僧惟俨 练得身形似鹤形,千株松下两函经。 我来问道无馀说,云在青天水在瓶。 ——李翱 牛头山法融禅师 恰恰用心时,恰恰无心用。曲谭名相劳,直说无繁重。 无心恰恰用,常用恰恰无。今说无心处,不与有心殊。 ——唐永徽年中 天衣义怀禅师 雁过长空,影沉寒底,雁无留影之心,影无遗踪之意。 《菜根谭》中的一句古诗:“风来疏竹,风过而竹不留声;雁渡寒潭,雁过而潭不留影。 另一版本:竹影扫阶尘不动,雁过寒潭水无痕。","categories":[{"name":"摘录","slug":"摘录","permalink":"http://maiernte.github.io/wiki/categories/摘录/"},{"name":"片段","slug":"摘录/片段","permalink":"http://maiernte.github.io/wiki/categories/摘录/片段/"}],"tags":[{"name":"文学","slug":"文学","permalink":"http://maiernte.github.io/wiki/tags/文学/"}]},{"title":"简短书摘","slug":"摘录/片段/简短书摘","date":"2019-07-29T07:00:50.000Z","updated":"2019-07-31T03:51:35.000Z","comments":true,"path":"brief-notions-collection.html","link":"","permalink":"http://maiernte.github.io/wiki/brief-notions-collection.html","excerpt":"癌症 “以我个人有限的接触癌症的经历总结,似乎越是传统意义上的“好人”越是容易生癌。这些人往往脾气很好,性格内向,照顾周围,万事替别人考虑,总是在乎别人眼里的自己,总是担心一些可能发生的小概率负面事件。” —— 冯唐. “无所畏【冯唐2018全新作品,一部坦露自我的真诚之作!】。”","text":"癌症 “以我个人有限的接触癌症的经历总结,似乎越是传统意义上的“好人”越是容易生癌。这些人往往脾气很好,性格内向,照顾周围,万事替别人考虑,总是在乎别人眼里的自己,总是担心一些可能发生的小概率负面事件。” —— 冯唐. “无所畏【冯唐2018全新作品,一部坦露自我的真诚之作!】。” 暗算 金风未动蝉先觉,暗算无常死不知。 青山只会明今古,绿水何曾洗是非? 五个人生思维 能把问题清楚的写下来,就是解决了问题的一半。发现问题比解决问题更重要。 墨菲定律:如果事情有变坏的可能,那它就一定会发生。 吉伯特法则:真正的危险是没有人告诉你有危险。「人在事中迷,就怕没人提」。 福克兰定律:当你不知道如何行动时,最好的行动就是不要行动,最好的决策就是没有决策。 费斯诺定律:人有两只耳朵,却只有一张嘴巴。就是说,人应该多听少讲。","categories":[{"name":"摘录","slug":"摘录","permalink":"http://maiernte.github.io/wiki/categories/摘录/"},{"name":"片段","slug":"摘录/片段","permalink":"http://maiernte.github.io/wiki/categories/摘录/片段/"}],"tags":[{"name":"文学","slug":"文学","permalink":"http://maiernte.github.io/wiki/tags/文学/"}]},{"title":"零散句子","slug":"摘录/片段/零散句子","date":"2019-07-29T06:50:50.000Z","updated":"2019-08-04T18:15:28.000Z","comments":true,"path":"funny-sloga-collection.html","link":"","permalink":"http://maiernte.github.io/wiki/funny-sloga-collection.html","excerpt":"幸福的路有两条 中岛美雪写的歌《幸福》(任贤齐翻唱的伤心太平洋):到幸福的路有两条,一条是所有愿望都成真,另外一条是把愿望这东西扔掉。","text":"幸福的路有两条 中岛美雪写的歌《幸福》(任贤齐翻唱的伤心太平洋):到幸福的路有两条,一条是所有愿望都成真,另外一条是把愿望这东西扔掉。 Matrix Cypher: You know, I know this steak doesn’t exist. I know that when I put it in my mounth, the Matrix is telling my brain that it is … juicy and delicious. After nine years, you know what I realize? en … Ignorance is bliss 几个顺口溜 认认真真说假话,扎扎实实走过场。 失败乃成功之母——失败生了100个孩子,其中一个叫「成功」,其它99个还叫「失败」。 “人类一思考,上帝就发笑。” —— “你一说要学什么东西,人们就发笑。” 晚上想想千条路,早上起来走原路。(有个共同特点:不困难、不痛苦) 暂时的失败要比暂时的成功要好得多。 别让「半途而废」 成为你唯一坚持下来的事情。 世上没有听一遍就管用的道理。 (你的脑袋)不要做别人思想的跑马场。 路是自己走的,脚上的泡也是自己好的。 忍一时越想越气,退一步越想越亏。(总是忍的人,从来都不开心。总是退让的人,却从来没有真的海阔天空) 遇到烂事不纠结,遇到烂人不纠缠。 每个人都想努力做,却总是做不好。 曹操评袁绍:「色厉胆薄,好谋无断,干大事而惜身,见小利而忘命。」","categories":[{"name":"摘录","slug":"摘录","permalink":"http://maiernte.github.io/wiki/categories/摘录/"},{"name":"片段","slug":"摘录/片段","permalink":"http://maiernte.github.io/wiki/categories/摘录/片段/"}],"tags":[{"name":"文学","slug":"文学","permalink":"http://maiernte.github.io/wiki/tags/文学/"}]},{"title":"典故","slug":"摘录/典故","date":"2019-07-29T06:45:50.000Z","updated":"2019-07-31T03:51:35.000Z","comments":true,"path":"old-stories-collection.html","link":"","permalink":"http://maiernte.github.io/wiki/old-stories-collection.html","excerpt":"豫让刺赵简子 晋毕阳之孙豫让,始事范、中行氏而不说,去而就知伯,知伯宠之。及三晋分知氏,赵襄子最恐知伯,而将其头以为饮器。豫让遁逃山中曰:“磋乎!士为知己者死,女为悦己者容。吾其报知氏之仇矣。”","text":"豫让刺赵简子 晋毕阳之孙豫让,始事范、中行氏而不说,去而就知伯,知伯宠之。及三晋分知氏,赵襄子最恐知伯,而将其头以为饮器。豫让遁逃山中曰:“磋乎!士为知己者死,女为悦己者容。吾其报知氏之仇矣。” 乃变姓名,为刑人,入宫涂厕,欲以刺襄子。 襄子如厕,心动,执问涂者,则豫让也。 刃其曰:“欲为知伯报仇!”左右欲杀之。 赵襄子曰:“彼义士也,吾谨避之耳。且知伯已死,无后,而其臣至为报仇,此天下之贤人也。”卒释之。 豫让又漆身为厉,灭须去眉,自刑以变其容,为乞人而往乞,其妻不识,曰:“状貌不似吾夫,其音何类吾夫之甚也。”又吞炭为哑,变其音。 其友谓之曰:“子之道甚难而无功,谓子有志,则然矣,谓子知,则否。以子之才,而善事襄子,襄子必近幸子;子之得近而行所欲,此甚易而功必成。”豫让乃笑而应之曰:“是为先知报后知,为故君贼新君,大乱君臣之义者无此矣。凡吾所谓为此者,以明君臣之义,非从易也。且夫委质而事人,而求弑之,是怀二心以事君也。吾所为难,亦将以愧天下后世人臣怀二心者。” 居顷之,襄子当出,豫让伏所当过桥下。 襄子至桥而马惊。 襄子曰:“此必豫让也。”使人问之,果豫让。 于是赵襄子面数豫让曰:“子不尝事范中行氏乎?知伯灭范中行氏,而子不为报仇,反委质事知伯。知伯已死,子独何为报仇之深也?”豫让曰:“臣事范中行氏,范中行氏以众人遇臣,臣故众人报之;知伯以国士遇臣,臣故国士报之。”襄子乃喟然叹泣曰:“嗟乎,豫子!豫子之为知伯,名既成矣,寡人舍子,亦以足矣。子自为计,寡人不舍子。”使兵环之。 豫让曰:“臣闻明主不掩人之义,忠臣不爱死以成名。君前已宽舍臣,天下莫不称君之贤。今日之事,臣故伏诛,然愿请君之衣而击之,虽死不恨。非所望也,敢布腹心。”于是襄子义之,乃使使者持衣与豫让。 豫让拔剑三跃,呼天击之曰:“而可以报知伯矣。”遂伏剑而死。 死之日,赵国之士闻之,皆为涕泣。 —— 《战国策》","categories":[{"name":"摘录","slug":"摘录","permalink":"http://maiernte.github.io/wiki/categories/摘录/"}],"tags":[{"name":"历史政治","slug":"历史政治","permalink":"http://maiernte.github.io/wiki/tags/历史政治/"}]},{"title":"搞笑段子","slug":"摘录/娱乐/搞笑段子","date":"2019-07-29T06:40:50.000Z","updated":"2019-07-31T03:51:35.000Z","comments":true,"path":"funny-things-collection.html","link":"","permalink":"http://maiernte.github.io/wiki/funny-things-collection.html","excerpt":"慢慢就习惯了 某人四十多岁了还碌碌无为,于是跑去找算命先生。算命先生掐指一算,然后问:“一个好消息,一个坏消息,你先听哪个?”哥们说:“那就先听坏的吧”。算命先生说:“坏消息是,你四十岁之前穷困潦倒……”那哥们眉头一挑,问:“那好消息呢?”算命先生幽幽的说到:“四十岁以后,你就习惯了。”","text":"慢慢就习惯了 某人四十多岁了还碌碌无为,于是跑去找算命先生。算命先生掐指一算,然后问:“一个好消息,一个坏消息,你先听哪个?”哥们说:“那就先听坏的吧”。算命先生说:“坏消息是,你四十岁之前穷困潦倒……”那哥们眉头一挑,问:“那好消息呢?”算命先生幽幽的说到:“四十岁以后,你就习惯了。” 身体就像一辆车子 身体就像一辆车子,还新的时候,遇到问题花点钱修理一下,就又能风驰电掣。车子越旧,修理费越高。旧到不行了,修理费比换辆新的还贵,还修个啥劲?你「身体」这家企业,当对它的投入远大于产出的时候,上帝都要考虑撤资了,你还拼命追加投资? 凌凌漆 外景:深圳某一市场猪肉摊前。 某女甲:你以为你匿喺度就揾唔到你咩? 冇用架! 你啲咁出色嘅难忍(男人),无论喺边度,都好似漆黑中嘅萤火虫一样,咁鲜明,咁出众。 你忧郁嘅眼神,唏嘘嘅须根,神乎其技嘅刀法,同埋嗰杯Dry Martine,都彻底噉将你出卖咗。 不过,你虽然系咁出色,始终行有行规,无论典(点)你都要找埋寻晚嗰条过夜数,叫鸡唔使畀钱呀? 凌凌漆:我重估我哋嘅交往系建筑喺感情之上,估唔到,原来都系一盘生意。 某女甲:讲感情都要畀钱架。 凌凌漆:明白嘅,有一早畀咗你啦。 但系近排兴食斋,冇乜人帮衬,不如噉啦,攞篘猪肉返去顶住数先啦。 嚟吖,粗粗地,唔该。 某女甲:你好嘢,山水有山逢。 (某女甲提猪肉转身走。) 凌凌漆: 有兴趣嘅不如今天再相逢啦。 (某女甲把猪肉投向凌凌漆) 凌凌漆(用刀接住猪肉):悭番。 (顺势将猪肉切成两半,挂喺猪肉钩上) 某女乙:咩话? 个衰佬唔肯畀钱? 我帮你拖马喐佢! 某女甲:算啦,话到尾,佢始终都系一个独一无二、风度翩翩嘅猪肉佬。 (阿漆依着猪肉摊,品着白兰地。) 情人节广告 14号晚报名打麻将,只报不打,报名费100元,报完名爱干嘛干嘛,爱去哪去哪,爱跟谁跟谁。本人承诺:保证任何人问你的行踪都可以证明你跟我一起打麻将了,你所有报不了的花费都可以说成是被我赢了,具体时间为2月14日17点至凌晨2点,时间地点任选。额外业务:如支付200元,还提供大牌合照以及朋友圈回复业务,做戏做全套!小本经营,童叟无欺!有意者私聊。","categories":[{"name":"摘录","slug":"摘录","permalink":"http://maiernte.github.io/wiki/categories/摘录/"},{"name":"娱乐","slug":"摘录/娱乐","permalink":"http://maiernte.github.io/wiki/categories/摘录/娱乐/"}],"tags":[{"name":"娱乐","slug":"娱乐","permalink":"http://maiernte.github.io/wiki/tags/娱乐/"}]},{"title":"缠中说禅","slug":"摘录/片段/缠中说禅","date":"2019-07-29T06:40:50.000Z","updated":"2019-07-31T03:51:35.000Z","comments":true,"path":"funny-things-collection.html","link":"","permalink":"http://maiernte.github.io/wiki/funny-things-collection.html","excerpt":"","text":"[TOC] 诗词 满江红 万古长空,今犹昔,一朝风月。何处住? 春花夏雨,秋鸿冬雪。 百代浮华皆作土,千江吸尽无堪说。 问世间,多少梦消磨、英雄血。 星旋轨,天补裂,山崩柱,河倾缺。 捣神宫鬼府,凤巢龙穴。 怒剑穿云惊浩宇,狂涛卷日横孤筏。 纵生死,劫火洗乾坤,齐欢悦。 临江仙 浊水倾波三万里,愀然独坐孤峰。 龙潜狮睡侯飙风。 无情皆竖子,有泪亦英雄。 长剑倚天星斗烂,古今过眼成空。 乾坤俯仰任穷痛。 半轮沧海上,一苇大江东。 卜算子 本是后山人,偶做堂前客。 醉舞经阁半卷书,坐井说天阔。 大志戏功名,海斗量祸福。 论到囊中羞涩时,怒指乾坤错。 —— 丁元英","categories":[{"name":"摘录","slug":"摘录","permalink":"http://maiernte.github.io/wiki/categories/摘录/"},{"name":"片段","slug":"摘录/片段","permalink":"http://maiernte.github.io/wiki/categories/摘录/片段/"}],"tags":[{"name":"文学","slug":"文学","permalink":"http://maiernte.github.io/wiki/tags/文学/"}]},{"title":"名人语录","slug":"摘录/片段/名人语录","date":"2019-07-29T06:40:50.000Z","updated":"2019-07-31T03:51:35.000Z","comments":true,"path":"prominaent-slogen-collection.html","link":"","permalink":"http://maiernte.github.io/wiki/prominaent-slogen-collection.html","excerpt":"","text":"祈祷文 上帝,请赐予我平静让我可以接受我所不能改变的,赐予我勇气让我可以改变我能够改变的,赐予我智慧以分辨这二者的不同。 God grand me the serenity to accept the things I cannot change, Courage to change the things I can, and wisdom to know the difference. 尼采 He who has a strong enough why can bear almost any how. – Friedrich Nietzsche 苏格拉底 Beware the barrenness of a busy life. – Socrates 亚里士多德 We are what we repeatedly do. Excellence, then, is not an act, but a habit. – Aristotle 维克多 弗兰克 人所拥有的任何东西都可以被剥夺,唯独人性最后的自由——也就是在任何境遇中选择一己态度和生活方式的自由——不能被剥夺。 马克吐温 让你陷入困境的并不是这个世界;真正让你陷入困境的,是这个世界最终并非你所想象。 赛斯 每一个心愿都预设了对于一个缺憾的承认,每一个挑战也预设了有一个要征服的阻碍。 叔本华 痛苦和无聊是人类幸福的两个死敌。欲望不满足就痛苦,满足就无聊。人生如同钟摆在痛苦和无聊两个极点之间摆动。离开一个极点就意味着正在走向另一个极点。 谚语 Don’t shoot the messenger. 英文有句谚语叫“不要枪毙信使”。枪毙信使并不能改变坏消息。 曾国藩 既往不恋,当下不染, 未来不迎。天涯:染,不被当下的情绪感染。要跳出情绪来观察当下。 倚天照海花无数, 流水高山心自知。 久利之事勿为,众争之地勿往。 勿以小恶弃人大美, 勿以小怨忘人大恩。 宗棠 人生最不幸處,是偶一失言而禍不及,偶一失謀而事倖成,偶一恣行而獲小利, 後乃視為故常,而恬不為意。則莫大之患,由此生矣。 俞敏洪 优秀是一种习惯。","categories":[{"name":"摘录","slug":"摘录","permalink":"http://maiernte.github.io/wiki/categories/摘录/"},{"name":"片段","slug":"摘录/片段","permalink":"http://maiernte.github.io/wiki/categories/摘录/片段/"}],"tags":[{"name":"文学","slug":"文学","permalink":"http://maiernte.github.io/wiki/tags/文学/"}]},{"title":"如何系统化管理Hexo博客","slug":"IT/Web/如何系统化管理Hexo博客","date":"2019-07-28T19:30:00.000Z","updated":"2019-08-15T21:51:57.000Z","comments":true,"path":"how-to-manage-big-hexo-blog.html","link":"","permalink":"http://maiernte.github.io/wiki/how-to-manage-big-hexo-blog.html","excerpt":"管理?","text":"建立博客的初衷 虽说这篇笔记的题目是「如何管理」,为了更好的回答这个问题,必须要回到最原始问题上来——我为何要建一个博客,而且是费那么大劲。而我的初衷是建立和维护一个属于自己的「知识库」。通常来说,为了达成这个目的,更好的选择是笔记APP,而不是博客。我确实也是这么做的。一开始用印象笔记,因为它死活不支持多级目录,我又转到国内的为知笔记,做了五年的VIP用户。但它五年来似乎从没改进过。随着近年来有道云异军突起,以及IOS生态圈中琳琅满目的APP,如熊掌记、Notion、谷歌的Keep、阿里的语雀。。。。。。各有各的惊艳,各有各的槽点。 随着国外的Github和国内的Coding等公司,相继开放永久免费、不限流量的静态网页托管平台,如Github Pages。我走上了自建Bolg的不归路。当然不是说,搭博客这条路完全没有槽点。而是——自己造的孽,含着泪也会继续造下去。至少它满足了我以下几点「必不可少」的要求: [x] 多级目录 [x] 支持Markdown文本 [x] 支持分类、标签、以及站内全文检索 [x] 没有IOS、Windows、Android等平台限制 说白了,我是利用Github提供的免费平台,把Blog当笔记本来用。最后选了Hexo,简单易用、界面绚丽、插件丰富。除开自用的「知识平台」功能以外,偶尔还能发发博文装大尾巴狼,也是蛮不错的感觉。 网上介绍怎么搭建Hexo以及添加绚丽功能的帖子海了去了,但我基本没有发现分享「如何管理」的。因为绝大多数这些博主,搭建Hexo只是用来玩一阵子。回头有更新更好玩的东西,就跑去玩别的了。极少数有博客,站内文章超过50篇的。所以,对他们来说,根本不存在——管理——这个议题。 虽然Hexo在逻辑上支持分类和标签,但物理上它把所有的Post都放到一个单一的目录下面。而我是打算把它当作知识库,长期、密集使用的。可预见的将来,站内笔记会非常多。不但写新贴,还可能经常更改旧贴。那势必会带来一个问题:如何管理数量少日益膨胀的笔记? 解决思路 我能想到的办法很简单,也很传统。就是不但逻辑分类,而且也必须物理上分目录存放。理论上在自己的PC分目录保存就好了。但我有好几台电脑,单位一台、自己Windows一台、Mac一台,还有平板。为了让能在不同的电脑上能随时修改、添加笔记,必须放在托管在云端。 硬件 没有必要租用传统的VPS,太贵了,而且连10%的运算能力都用不上。用共享的Web Hosting就完全能解决需求。比如百度云,或者Azure的Web App。而我是租用 1&1 公司的Web Hosting,每个月 1€ 1 CPU 500M 内存 20G SSD 就算那么低的运算能力,平时我的网站也用不到25%的运算能力。应付起啦,绰绰有余。 软件 我采用了MM-Wiki 管理平台(以下简称维基平台)。这是一个非常优秀的开源项目,具体请参看作者的文档。部署超级简单,可以说一键部署,然后就可以用起啦了。简单来说这个平台有以下几个特点: [x] 支持空间管理、空间内支持多级目录。 [x] 支持Markdown编辑。 [x] 支持附件。 [x] 有修改记录。 [ ] 不支持内容搜索,只支持笔记的题目搜索。 [ ] 标签只支持到空间级别,目录和笔记都没有标签。 但它跟Hexo博客搭配使用,就完全满足我的需求了。其实Hexo博客中,有个仿维基的Wikitten主题,跟MM-Wiki项目非常像。但毕竟不是所有内容,都适合摆在公开的地方。以MM-Wiki 作为私用平台,增加了私隐保护。 我的做法是,在维基平台中开辟一个独立的空间,用来存放博客上所有的源文件。而在Github Pages上托管的静态网站其实都是HTML文件。所有的改动,都必须在源Markdownn文件上修改,然后再推送到博客网站的。 在维基平台修改、添加、删除笔记的源文件。然后复制到Hexo的项目目录,编译后推送到Github Pages站点。维基百科内置的在线版Editor.md 编辑器,非常美观实用。基本上我都不太需要在自己的电脑上用Typora等编辑器写MD文本了。思路有了,实现起来还是有一点问题。 难点的解决办法 首先,在维基平台内,MD文件是分目录存储的。这个目录不能直接拷贝到Hexo的_post目录。懒得每修改一个,或者添加一个笔记,就立马拷贝到博客中去。解决笔记复制的问题。 其次,笔记的物理保存目录,必须跟Hexo上的「分类」是一一对应的。否则,管理起来会很麻烦。在维基平台移动了笔记的保存目录后,在一一修改内容,也是很吃力的事情。 笔记复制的解决办法 说来也超级简单,一个脚本命令就够了。先用find命令在指定目录找出所有的MD文件,然后通过管道传给复制命令cp,搞定! 1find /root/bibliothek/markdowns/博客草稿/ -type f -name \"*.md\" -exec cp {} /home/_post/ \\; 然后hexo d -g编译、发布,结束! 管理笔记的分类 这个问题有一点麻烦。因为必须打开每一个文件,读取笔记的头文件描述,然后再比较跟文件的物理位置是否符合。我尝试用shell脚本解决这难题。无奈我的的shell脚本功底是在很差,搞半天未果就放弃了。用Java或者.NET Core啥的,正儿八经写一个Console程序,也不是不行。但有种杀鸡用牛刀的感觉。 最后想到了用Javascript。因为编译Hexo是需要安装Node.js的,写一段JavaScript,让Node跑起来。通往罗马的道路千万条,选一条自己最熟悉的就完了。 点击查看代码 上面这个脚本使用的都是我个人设置,你如果要用的话需要改成自己实际文件目录。","categories":[{"name":"IT","slug":"IT","permalink":"http://maiernte.github.io/wiki/categories/IT/"},{"name":"Web","slug":"IT/Web","permalink":"http://maiernte.github.io/wiki/categories/IT/Web/"}],"tags":[{"name":"Hexo","slug":"Hexo","permalink":"http://maiernte.github.io/wiki/tags/Hexo/"}]},{"title":"《驴得水》——影评","slug":"摘录/《驴得水》影评","date":"2019-07-28T13:17:19.000Z","updated":"2019-08-15T21:48:56.000Z","comments":true,"path":"lvdeshui-film.html","link":"","permalink":"http://maiernte.github.io/wiki/lvdeshui-film.html","excerpt":"","text":"追求自由的人,疯了,死了。 不愿低头的人,成了听话的牲口。 宽容大度的人,成了唯利是图的小人。 淳朴憨厚的人,成了狡诈的恶棍。 正面积极的人,用谎言掩盖真相。 你觉得这是电影吗?其实,这是现实。我们先来看一下电影故事讲的是什么: 一群怀揣伟大梦想的人,却敌不过山区缺水的现实,养了一头驴拉水。上头却不给养驴费,于是就把驴谎报成老师。上头来检查,不能因为一头驴毁了梦想啊。于是为了捍卫梦想的道路,却失去了梦想的意义。《驴得水》的海报上说,“讲个笑话,你可别哭啊”。 就像另一句笑话讲的那样, “小的时候我想拯救世界,长大后却发现世界都拯救不了我”。 好笑,但却想哭。 谁TM还没点梦想啊。但有时梦想很脆弱,甚至敌不过一碗炸酱面。你想让自己闪闪发光,但总得先养活自己,饿着肚子的人怎么去谈梦想?这也是很多刚毕业不久的人,所要面对的最为矛盾的情况。“我有很多想法,有很多想做的事。但我现在没钱、没人脉、没背景,甚至还没长相。想要出去闯一片天地, 但还要为一日三餐和落脚地打拼。梦想是高潮,现实却是性冷淡。还能怎么办呢?先养活自己再说吧”。于是,你找了一份莫名其妙的工作,你一日三餐是不愁了,你做着日复一日重复的工作,但是你不敢停,你越来越迷茫,越来越看不清生活的方向。 你害怕那种怀揣梦想,但却又碌碌无为的日子,但你却不知道从哪里开始改变。于是你只能在焦虑中慢慢对现实妥协,然后你变成了自己曾经最讨厌的那种人。冷漠、没有激情、不思进取、浑浑噩噩,就像影片中的人物一样。曾经那些他们坚信的东西在面对现实时,都变得不堪一击。铁男说,“我没有办法啊,你知道子弹从脸上呼啸而过的感觉吗”?像不像我们经常说的,“我没办法啊,现实就是这样”。 是啊,现实就是这样!作为芸芸众生,普通屁民,谁TM还没被现实强奸过啊。但想要活得更好,重要的不是治愈,而是带着病痛活下去。而且我们要清醒的认识到一个事实,有时我们之所以像傻逼一样努力,不是为了改变世界,而是为了不让世界改变我们。或许,这才是我们对这个世界最大的善意。","categories":[{"name":"摘录","slug":"摘录","permalink":"http://maiernte.github.io/wiki/categories/摘录/"}],"tags":[{"name":"影视","slug":"影视","permalink":"http://maiernte.github.io/wiki/tags/影视/"}]},{"title":"编辑器工具使用技巧汇总","slug":"IT/Tools/编辑器工具使用技巧汇总","date":"2019-07-27T06:24:33.000Z","updated":"2019-09-01T17:11:47.000Z","comments":true,"path":"Editor-Skills-Summary.html","link":"","permalink":"http://maiernte.github.io/wiki/Editor-Skills-Summary.html","excerpt":"VSCode Wechseln zwischen Text-Editor und Terminal Command+K+S oder in Menü Code->Pereferenc->Hotky, öffnet Hot-Key Editor Fenster. Tip terminal in Suchfeld, findet die Binding `^``, löscht diese Einstellung. Sucht den “workbench.action.terminal.focus”, bindet es mit Key ⌃<. Sucht den “workbench.action.focusActiveEditorGroup”, bindet es wiederum mit Schlüssel ⌃<, und Wenn-Kondition “terminalFocus”.","text":"VSCode Wechseln zwischen Text-Editor und Terminal Command+K+S oder in Menü Code->Pereferenc->Hotky, öffnet Hot-Key Editor Fenster. Tip terminal in Suchfeld, findet die Binding `^``, löscht diese Einstellung. Sucht den “workbench.action.terminal.focus”, bindet es mit Key ⌃<. Sucht den “workbench.action.focusActiveEditorGroup”, bindet es wiederum mit Schlüssel ⌃<, und Wenn-Kondition “terminalFocus”. Typora 更多更详细的内容请参阅 Typora Wiki Typora Wiki (wiki-website Project) 个性化快捷键 Windows 文件—>偏好设置—>往高级设置 ,点击看到两个json格式的文件,打开第二个(conf.user.json), 用记事本打开,第17行keyBinding,在大括号中写 代码块:“你要设置的快捷键”,比如我的是代码块:Ctrl+Alt+P,保存文件,重启typora即可生效。更详细介绍 12345678// Custom key binding, which will override the default ones. \"keyBinding\": { // for example: // \"Always on Top\": \"Ctrl+Shift+P\" \"注释\":\"Ctrl+Alt+/\", \"代码块\":\"Ctrl+Alt+P\", \"打开文件夹…\":\"Ctrl+Alt+O\" }, Mac 官方说明 需要到系统偏好设置—>键盘-->快捷键-->应用快捷键那边设置。找到 Typora.App,菜单名称填 代码,然后输入希望的快捷键。我的设置是⌃+⌘+C。 更改风格 开发好的工具 如何客制化格式 简单使用:添加 base.user.css 文件,并改变行内代码的颜色,以及公式颜色 123456789# 行内代码code { color: red}# 行内公式.MathJax_SVG{ color: DarkBlue;} Typora的代码使用 CodeMirror 项目,尝试了一下修改 base.user.css 文件确实可以改变代码段的高度,并带滚动。但同时也限定了进行代码编辑时的整个窗口高度。所以没有用 123456789# 缺点:打开源代码模式的时候,整个页面也被限制成了只有300px高.CodeMirror { max-height: 300px;}.CodeMirror-scroll { overflow-y: auto; overflow-x: auto; max-height: 300px;} 注意到书写模式的时候,整个编辑器都被包裹在 <div id="write"> </div> 里面。在源代码模式的时候,没有这个 write 元素的包裹,而整个源代码窗口都被作用为一个 CodeMirror 元素对待。因此,作一些改变就能满足要求 1234567891011#write .CodeMirror { max-height: 350px;}# 设定上下 padding 会让滚动条在小代码区消失#write .CodeMirror-scroll { overflow-y: auto; overflow-x: auto; max-height: 330px; padding-top: 10px; padding-bottom: 10px;} 1# 避免只有一行的代码区,因为会显示滚动条,不好看。一行代码就用行内代码好了。 如果要限制来自 GistHub 的代码高度,只能限定其父元素 iframe 123iframe { max-height: 500px;} Windows版的 Typora 的数学模块保存在 path/resource/app/lib.asar 压缩文件中。需要用asar解压 如何查看 asar 内部结构 asar 如何加密解密 123npm install -g asarasar extract 压缩文件 解压文件夹asar pack 文件夹 压缩文件名 文本搜索 打开的单篇文章内搜索: Windows Control + F Mac ⌘+F 文件夹内的搜索 Windows Control + Shift + F Mac ⇧+⌘+F","categories":[{"name":"IT","slug":"IT","permalink":"http://maiernte.github.io/wiki/categories/IT/"},{"name":"Tools","slug":"IT/Tools","permalink":"http://maiernte.github.io/wiki/categories/IT/Tools/"}],"tags":[{"name":"工具","slug":"工具","permalink":"http://maiernte.github.io/wiki/tags/工具/"}]},{"title":"Ubuntu重设root用户密码","slug":"IT/Tools/Ubuntu重设root用户密码","date":"2019-07-26T15:51:03.000Z","updated":"2019-08-14T06:34:27.000Z","comments":true,"path":"ubuntu-reset-root-pw.html","link":"","permalink":"http://maiernte.github.io/wiki/ubuntu-reset-root-pw.html","excerpt":"","text":"重设密码 原理上参考这份中文指引就好。由于我的服务器是IONOS公司的,这里主要记录IONOS的官方指引。(严格按照步骤) 12网址 www.ionos.de/hilfe# 选择 Server & Cloud Infrastructure 打开 KVM-Konsole 在用户管理平台软重启系统 Soft-Restart 在 KVM-Konsole 这边按 ESC 键 当出现类似一下界面,按 E 键 然后会来到这个界面。 用上下键移动到“linux。。。”开始的那一行,并左右键移动到这行的末尾,空格,输入 init=/bin/bash 按 F10 开始重启。等完成,进入命令模式后,输入以下命令。 12345mount -o remount,rw /passwdEnter new UNIX password:Retype new UNIX password:passwd: password updated successfull 最后输入命令重启系统! 1reboot -f 设置公共SSH 在配置 github 的时候已经生成了 ssh-key ,可以用以下方法。 123456cd ~/.sshcp id_rsa.pub authorized_keysssh-copy-id -i ~/.ssh/id_rsa.pub root@217.160.61.19 # 我的用户名和服务器地址,默认端口 22# 指定端口号为2212:ssh-copy-id -i ~/.ssh/id_rsa.pub -p 2212 user@ipssh root@217.160.61.19 # 登录并输入密码,第二次就不再需要密码了。","categories":[{"name":"IT","slug":"IT","permalink":"http://maiernte.github.io/wiki/categories/IT/"},{"name":"Tools","slug":"IT/Tools","permalink":"http://maiernte.github.io/wiki/categories/IT/Tools/"}],"tags":[{"name":"工具","slug":"工具","permalink":"http://maiernte.github.io/wiki/tags/工具/"}]},{"title":"搭建Hexo博客的流水账","slug":"IT/Web/搭建Hexo博客的流水账","date":"2019-07-25T03:49:15.000Z","updated":"2019-08-15T10:44:25.000Z","comments":true,"path":"how-build-my-hexo-blog.html","link":"","permalink":"http://maiernte.github.io/wiki/how-build-my-hexo-blog.html","excerpt":"建网过程中的一些流水账。以备将来查询。","text":"建立网站 Github配置 输入命令 ssh-keygen -t rsa -b 4096 -C "myname@gmail.com"。 密码 T1。(下列展开后复制) 将文件 ~/.ssh/id_rsa.pub 中的内容复制到 Github 的SSH-Key 内就可以了。(备份文件已上传百度网盘) 在Github上新建SSH-Key名称为gmail 具体步骤参阅此文章 123456789101112ssh-keygen -t rsa -b 4096 -C "username@gmail.com"[Enter][password T..1]eval "$(ssh-agent -s)"ssh-add -K ~/.ssh/id_rsacd ~cd .sshlsvim id_rsa.pub(然后复制钥匙串) 测试公匙 123$ ssh -T git@github.comHi username! You've successfully authenticated, but GitHub does not provide shell access. 安装Hexo 参考资料1 7。 安装node.js 因为以前已经安装过,所以跳过。 安装 Hexo $ npm install hexo-cli -g 创建网站 1234mkdir mywikicd mywikihexo initnpm install 生成静态页面 hexo g or hexo generate 启动本地网站服务 hexo s or hexo server 网站一般会运行在 http://localhost:4000/ Press Ctrl+C to stop. 用pow做服务本地运行 Install 1$ curl get.pow.cx | sh Setup Symlink the folder into ~/.pow 12$ cd ~/.pow$ ln -s /path/to/test 发布到Github 终于搭建好站点部署环境啦,那么要怎么样将我们本地生成预览好的页面发布到github上呢?很简单,Follow! 首先,打开blog目录下的_config.yml,找到deploy段,配置成这样 deploy: type: git repository: git@github.com:yourname/yourname.github.io.git branch: master 注意将代码里面的yourname换成你账号的username。 设置git身份信息 git config --global user.name “你的用户名” git config --global user.email “你的邮箱” 执行以下指令进行部署 hexo d -g 如果提示没找到git,请先执行以下指令 cnpm install hexo-deployer-git --save 再次部署后,浏览器打开 https://yourname.github.io 就可以看到刚才本地预览页面。 网站基本配置 Next 主题 主题配置文件说明 点击显/隐内容 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970# Hexo 站点配置文件## Docs: https://hexo.io/docs/configuration.html## Source: https://github.com/hexojs/hexo/# 网站配置title: Hexo # 网站标题subtitle: # 网站副标题description: # 网站描述author: John Doe # 你的昵称language: # 网站使用的语言(英文:en, 简体中文:zh-Hans,繁体中文:zh-tw)timezone: # 网站时区,用于生成页面时填充相关时间,默认使用电脑时区,一般不用改# URL## 如果你的站点要放入子目录, 请将url设置为'http://yoursite.com/child' 并将根目录设置为'/child/'url: http://yoursite.com # 站点网址root: / # 网站根目录permalink: :year/:month/:day/:title/ #文单的永久链接格式permalink_defaults: # 永久链接中各部分的默认值# 目录source_dir: source # 资源文件夹,这个文件夹用来存放博客内容public_dir: public # 公共文件夹,这个文件夹用来存放生成的站点静态文件tag_dir: tags # 标签文件夹archive_dir: archives # 归档文件夹category_dir: categories # 分类文件夹code_dir: downloads/code # Include code文件夹i18n_dir: :lang # 国际化文件夹,存放各种语言定义skip_render: # 跳过指定文件的渲染# 写作new_post_name: :title.md # 新文章的文件名称default_layout: post # 预设布局titlecase: false # 把标题转换为 title caseexternal_link: true # 在新标签中打开链接filename_case: 0 # 把文件名称转换为 (1) 小写或 (2) 大写render_drafts: false # 显示草稿post_asset_folder: false # 启动 Asset 文件夹relative_link: false # 把链接改为与根目录的相对位址future: true # 显示未来的文章highlight: # 代码块的设置 enable: true line_number: true auto_detect: false tab_replace:# 分类 & 标签default_category: uncategorized # 默认分类category_map: # 分类别名tag_map: # 标签别名# 日期 / 时间格式## Hexo 使用 Moment.js 来解析和显示时间## http://momentjs.com/docs/#/displaying/format/date_format: YYYY-MM-DD # 日期格式time_format: HH:mm:ss # 时间格式# 分页## 每页显示的文章量 (0 = 关闭分页功能)per_page: 10pagination_dir: page# 扩展## Plugins: https://hexo.io/plugins/## Themes: https://hexo.io/themes/theme: landscape # 主题# 部署## Docs: https://hexo.io/docs/deployment.htmldeploy: type: Wikitten主题 具体配置参考开发者说明,更详细的描述参阅hexo-theme-icarus。为了与主题Next不冲突,作以下修改。 自行修改 tags, about,categories 等index.md,而不能从主题复制,覆盖站点原有设置。 languages\\zh-CN.yml 重命名为 zh-Hans.yml _config.yml 菜单作以下更改 123456menu: 首页: / 归档: /archives/ 分类: /categories/ 标签: /tags/ 关于: /about/ thumbnail: true 使得每个post在快速列表里,显示图标。但就是每个帖子都要设定,很麻烦。 post 中的 toc 要设置为 true,如果需要显示目录的话。 同时部署两个项目 第一个项目使用 Github 上面默认的 Github Pages,即 username.github.io 。在站点配置文件中如下: 12345678url: http://username.github.ioroot: /......deploy: type: git repository: git@github.com:username/username.github.io.git branch: master 第二个站点开通一个 普通的repository,添加名为gh-pages 的Branch,并将gh-pages设为默认Branch。我将第二个仓库命名为 wiki ,那第二个站点就运行在https://username.github.io/wiki`次级目录下面。 站点配置文件更改如下: 12345678url: http://username.github.io/wikiroot: /wiki/......deploy: type: git repository: git@github.com:username/wiki.git branch: gh-pages 同样用 hexo d -g 部署命令发布,两个站点就都运行起来了。 为了使得两个项目使用同一个笔记资源,将站点中的 source 文件夹移到项目意外,将配置文件里的 source_dir: source 改为 source_dir: ../source(这里使用了相对目录)。 参考文章 (细节已经失效,但思路值得参考) 站内搜索 安装插件 12npm install hexo-generator-search --savenpm install hexo-generator-searchdb --save 配置hexo站点主配置文件_config.yml, 添加 12345search: path: search.xml field: post format: html limit: 10000 修改next主题配置文件_config.yml,启用 local_search 1234local_search: enable: true trigger: auto top_n_per_article: 1 生成search.xml文件以及发布 12hexo ghexo d -g # 本地运行 hexo s 去除主题字样 关于添加头像、标签、分类、「关于」等具体的修改,跟着参考资料2里面的步骤做就好了。最后说说如何去掉底部强力驱动及主题字样。 找到 \\themes\\next\\layout_partials\\下面的footer.swig文件,打开: 123456789<div class=\"powered-by\"> {{ __('footer.powered', '<a class=\"theme-link\" href=\"https://hexo.io\">Hexo</a>') }}</div><div class=\"theme-info\"> {{ __('footer.theme') }} - <a class=\"theme-link\" href=\"https://github.com/iissnan/hexo-theme-next\"> NexT.{{ theme.scheme }} </a></div> 第一条是“由Hexo驱动” 的Hexo链接,把xml段删除,只留两个单引号’’。 第二条是“主题-Next.XX”,将xml段都删掉,不留引号。 123456<div class=\"powered-by\"> {{ __('footer.powered', '') }}</div><div class=\"theme-info\"> {{ __('footer.theme') }}</div> 找到这个地方\\themes\\next\\languages\\ 下面的语言文件zh-Hans.yml(以中文为例): 123footer: powered: \"由 %s 强力驱动\" theme: 主题 将上面的文字改成自己想要的即可。 添加评论功能 Gitment **此项目已经终止!**改为Disqus,以及其它评论服务。 安装功能模块。在项目的根目录: 1npm i --save gitment 在Github申请应用。settings -> Developer Settings -> OAuth Apps 1234Application name:随便写Homepage URL:这个也可以随意写,就写你的博客地址就行Application description:描述,也可以随意写Authorization callback URL:这个必须写你的博客地址 申请好之后点注册,然后就可以看到两个东西ClientID和Client Secret,后面会用到。 配置Gitment,打开themes/next/_config.yml: 123456789101112131415# Gitment# Introduction: https://imsun.net/posts/gitment-introduction/gitment: enable: true mint: true # RECOMMEND, A mint on Gitment, to support count, language and proxy_gateway count: true # Show comments count in post meta area lazy: false # Comments lazy loading with a button cleanly: false # Hide 'Powered by ...' on footer, and more language: # Force language, or auto switch by theme github_user: {you github user id} github_repo: 随便写一个你的公开的git仓库就行,到时候评论会作为那个项目的issue client_id: {刚才申请的ClientID} client_secret: {刚才申请的Client Secret} proxy_gateway: # Address of api proxy, See: https://github.com/aimingoo/intersect redirect_protocol: # Protocol of redirect_uri with force_redirect_protocol when mint enabled 注意到这里基本上已经OK了,再看你的博客应该可以显示评论了.不过每篇博客都需要你手动初始化评论功能(如果你的历史博客很多那就一篇一篇去点吧,不过貌似有人写了批量处理脚本,没试过哈). 而由于 github 中 Issues 的 label 长度限制为最大 50 个字符,当 文章标题长度过长时,该label就会生成失败,而导致初始化错误,弹出 Validation Failed 的提示。 通过网上的搜索,发现可以使用文章创建时的时间来代替文章标题,作为这个唯一的label标签。 找到giment的配置:/themes/next/layout/_third-party/comments/gitment.swig 文件, 并找到如下部分: 12345var gitment = new {{CommentsClass}}({ id: window.location.pathname, owner: '{{ theme.gitment.github_user }}', repo: '{{ theme.gitment.github_repo }}', ... 将id后面的路径值修改为 ‘itfanr_blog_<!–1–>’ 就可以了。 Disqus 目前只开通Disqus的评论。 开通Disqus账号,并添加一个点 应用。具体步骤参看Hexo搭建博客系列:(六)Hexo添加Disqus评论。 在主题配置文件(_config.yml)文件中找到以下代码,添加你Disqus设置的Website Name在shortname。 12345# Disqusdisqus: enable: true shortname: tian-ya-de-zhi-fu count: true 更详细请参阅网上。 新文章命名规则 发表新文章后系统崩溃。 在根目录的配置文件中找到类似的: 1234# Writingnew_post_name: 新文章.md # File name of new postsdefault_layout: post... 将其改为由时间和题目组成: 1234# Writingnew_post_name: year-:month-:day-:title.md # File name of new postsdefault_layout: post... 进阶设置 显示 首页文章显示预览 默认设定下。首页的文章每一篇都显示全文,不方便浏览。需要到主题的配置文件里将auto_excerpt 的 enable 改为 true。而length 字节表示文章预览的长度。 1234# Automatically Excerpt. Not recommand.auto_excerpt: enable: true length: 300 永久链接 新文章的名字采用了中文(见上),中文出现在地址栏上不美观。也不利于SEO,以及增加了博文URL的层数。解决办法是给每篇文章制定链接地址。 修改网站的配置文件中永久地址的设定: 1permalink: :urlname.html 给每篇文章指定 urlname 123456title: 《少有人走的路》笔记date: 2019-07-21 00:14:37urlname: road-less-traveled-summarytags: - 心理学categories: 读书笔记 编译后新的地址为 http://mywiki.test/road-less-traveled-summary.html。看起来就清爽多了。 图片链接 开通资源文件夹,创建新文章的时候会自动建立一个与文章同名的文件夹。可以将图片或者其它资源文件放到里面(打算将思维导图放到这里)。因为自定义了文件名的方式,所以根据官方描述无效。 安装第三方插件hexo-asset-image 1npm install hexo-asset-image --save 在文章中图片的链,可以省略路径,直接引用图片名: 1![mypicture](mypicture.jpg) 修改插件代码 我在使用永久链接的时候在每篇文章的实际地址都加上了.html。文章的地址显示如下 1http://mywebsite.com/my-articel-url.html 而插件生成的图片地址如下: 1http://mywebsite.com/my-articel-url.htm/mypicture.jpg 多出了 .htm 这几个字符,而实际图片的地址应该是: 1http://mywebsite.com/my-articel-url/mypicture.jpg 找到 node_modules/hexo-asset-imge 目录下的 index.js 文件,将以下代码中的 1 改成 5,就可以正常显示图片了。 1var endPos = link.length - 1 考虑到将来项目膨胀,应该将图片放到图床,比如七牛。 站内链接 导航到站内别的文章使用以下方式就可以。 链接方式 [文章名](urlname.html) 设定代码区的高度 Hexo自身的式样暂时还没找到。其实也不太需要。如果代码不长直接显示全部就好了。太长的话不如放到$Gits$,通过限制gist的高度实现。Net主题修改 next/themes/next/source/css/_custom/custom.styl ,Wikitten主题则在文件 wikitten/themes/Wikitten/source/css/_partial/article.styl 中修改。 12345.gist .gist-file.gist-data { max-height: 450px;} 添加注脚支持 插件项目 安装插件 npm install hexo-footnotes --save 项目配置文件 添加 123# 注意第二行的前面没有 \"-\" 符号,官方说明有. 但是会导致无法编译.plugins: hexo-footnotes 更换Markdown渲染 Markdown-it-plus 如果更换了这个渲染,就无需上面那个注脚插件, 因为已经支持了. 首先卸载掉旧的渲染, 然后安装新的. 1234npm un hexo-renderer-marked --savenpm i hexo-renderer-markdown-it-plus --save# 查看是否已经安装npm ls hexo-renderer-markdown-it-plus 然后在项目配置文件, 添加下面文字. 更深入的设置, 参看 markdown-it-plus 项目的说明文档. 12345678910markdown_it_plus: highlight: true html: true xhtmlOut: true breaks: true langPrefix: linkify: true typographer: quotes: “”‘’ plugins: 辅助功能 本地运行服务 在Mac中可以用本地服务Pow运行网站,不用每次更改重启服务器hexo s。 安装Pow 1$ curl get.pow.cx | sh 建立项目链接,myapp 是项目的名字。比如真实路径~/Project/mywiki 12$ cd ~/.pow$ ln -s /path/to/myapp 执行完以上步骤后在浏览器打开链接 http://myapp.test/ 就能看到网站。更改内容后要执行==生成== 命令才能看到更新hexo generate or hexo g 。 不想运行,直接把项目文件夹删除就可以。 绑定个人域名 在万网买一个顶级域名,开通后添加两个域名解释 123#记录名 主机记录 记录值CNAME www username.github.ioCNAME @ username.github.io 在项目的根目录添加一个名为 CNAME 的文件,然后填入万网注册的域名, 这里是 goldentianya.pub 。第一次我是手动添加的。添加后进入 repository 的 setting, 往下混动到 Custom domain ,可以看到系统已经自动把用户域名加进去了。 将来不希望用这个域名,域名重定向后,在浏览器输入 username.github.io 后 Chrome 会一直转向 goldentianya.pub 。需要打开开发者工具,选中 disable cache ,再刷新一遍地址就好了。 next 项目要将 CNAME 文件复制到 /themes/next/source 目录下个,编译的时候会拷贝到 public 目录。wikitten 项目不需要,域名定向以后能找到 goldentianya/wiki 站点,十分神奇。 隐藏文章 全隐藏 根据插件hext-sage-posts 作者的博文9中描述,安装插件 1npm install hexo-sage-posts --save 并将初创时的Hello-world.md 文章的Metadata中加入sage: true,文章就从网站上消失了。但在别的文章下面导航栏中,通过“下一篇”或者“上一篇”还是能被找到。被隐藏的文章其地址仍旧没有改变,只是不不出现在首页导航,和分类中而已。 从首页隐藏 为了不让太琐碎的文章充斥首页,但又可以在分类中找到。可以采用这种方式。 在文章的Metadata部分添加关键字 notshow: true。 找到 Hexo\\themes\\next\\layout\\index.swig 文件中以下部分: 123456789{% block content %} <section id=\"posts\" class=\"posts-expand\"> {% for post in page.posts %} {{ post_template.render(post, true) }} <!--修改此行--> {% endfor %} </section> {% include '_partials/pagination.swig' %}{% endblock %} 将以上代码第四行修改为 123{% if post.notshow != true %} {{ post_template.render(post, true) }}{% endif %} 文章加密 安装插件 hexo-blog-encrypt 1npm install --save hexo-blog-encrypt 并在站点配置文件中启用该插件: 12encrypt: enable: true 然后在文章的头部添加上对应的字段 123456789101112---title: 文章加密date: 2019-01-04T22:20:13.000Zcategory: 教程tags: - 博客 - Hexokeywords: 博客文章密码password: TloveYabstract: 此文章含有敏感内容。message: 输入密码,查看文章--- password: 是该博客加密使用的密码 abstract: 是该博客的摘要,会显示在博客的列表页 message: 这个是博客查看时,密码输入框上面的描述性文字 Hexo Admin 安装后台管理插件 hexo-damin 123npm install --save hexo-adminhexo server -dopen http://localhost:4000/admin/ 初次运行后,设置管理账户。 1234admin: username: maiernte password_hash: $2a$10$QeeWfDwIxbJ94h8EDfplDe9aLB0uaNrjMeVGhaYnfF0BBDosDze0S secret: NamoAmitabha! 访问量统计 介绍文章 (有图) 原文(有代码) 第一步, 到Lean Cloud增添一个应用,并创建类似Counter 的类。设置成 $ 所有人可读可写 $ 在安全中心添加 Web 安全域名, 添加Blog域名,防止有人Hack我们的数据库。 按上面的文章修改 Hexo 以及主题配置。 在线交流 使用 道客 Daovoice 接入方式 将下面代码粘贴在页面的 之前。 1<script>(function(i,s,o,g,r,a,m){i["DaoVoiceObject"]=r;i[r]=i[r]||function(){(i[r].q=i[r].q||[]).push(arguments)},i[r].l=1*new Date();a=s.createElement(o),m=s.getElementsByTagName(o)[0];a.async=1;a.src=g;a.charset="utf-8";m.parentNode.insertBefore(a,m)})(window,document,"script",('https:' == document.location.protocol ? 'https:' : 'http:') + "//widget.daovoice.io/widget/5e5fa370.js","daovoice")</script> 调用下面的 JavaScript 与注册用户沟通 12345678daovoice('init', { app_id: "5e5fa370", user_id: "NO_89757", // 必填: 该用户在您系统上的唯一ID email: "daovoice@example.com", // 选填: 该用户在您系统上的主邮箱 name: "道客船长", // 选填: 用户名 signed_up: 1449821660 // 选填: 用户的注册时间,用Unix时间戳表示});daovoice('update'); 调用下面的 JavaScript 与匿名访客沟通 1234daovoice('init', { app_id: "5e5fa370"});daovoice('update'); 完成代码粘贴后,检测是否成功接入: Ping 一下 待解决问题 [x] 文章评论 [x] 在线编辑? [x] 使用七牛图床 [ ] 脑图摆放 (官方文档/数据文件) [x] 文件下载(可能还是要靠七牛) [x] 用submodule管理主题 在 hexo 中使用 git submodules 管理主题 [ ] SEO [ ] 访问量统计 [ ] 加速 Github Pages + CDN全站加速 [ ] 在vps上部署hexo博客的那些事 有趣插件 [x] 短地址 & 指定摘要 [ ] 农历/很好的学习做插件的例子 [ ] 插入pdf 可以学习如何插入epub [ ] hexo-include 加载文本内容, html, js, text [x] Hexo-NexT给文章添加结束语 [x] Hexo-NexT接入网页在线联系功能 [ ] include markdown — 讲解详细的博客 这个也不错 1.Hexo博客搭建全攻略(一):基于Hexo+Github环境搭建 ↩2.Hexo博客搭建全攻略(二):NexT主题配置 ↩3.Hexo博客搭建全攻略(三):三方服务集成 ↩4.Hexo博客搭建全攻略(四):高级应用 ↩5.Hexo博客搭建全攻略(五):基于Github Issue搭建评论系统 ↩6.Hexo博客搭建全攻略(六):博文图片处理 ↩7.十步之内轻松搞定 Hexo + GitHub搭建个人博客 ​​ ↩8.如何优雅的 隐藏博客 ↩9.为 Hexo 博客添加隐藏文章 / 限定公开功能 ↩10.Hexo 中文文档 ↩","categories":[{"name":"IT","slug":"IT","permalink":"http://maiernte.github.io/wiki/categories/IT/"},{"name":"Web","slug":"IT/Web","permalink":"http://maiernte.github.io/wiki/categories/IT/Web/"}],"tags":[{"name":"Hexo","slug":"Hexo","permalink":"http://maiernte.github.io/wiki/tags/Hexo/"}]},{"title":"坚果云有关","slug":"IT/Tools/坚果云有关","date":"2019-07-25T03:41:28.000Z","updated":"2019-08-14T22:10:30.000Z","comments":true,"path":"about-jianguoyu.html","link":"","permalink":"http://maiernte.github.io/wiki/about-jianguoyu.html","excerpt":"忽略文件 配置文件 customExtRules.conf。在 Window 版可以在软件直接打开,在 Mac App 里面没有这个选项,要自行查找这个配置文件。官方说明 在 Windows 和 Mac 下面目录可能不一样。","text":"忽略文件 配置文件 customExtRules.conf。在 Window 版可以在软件直接打开,在 Mac App 里面没有这个选项,要自行查找这个配置文件。官方说明 在 Windows 和 Mac 下面目录可能不一样。 Mac 系统或 Linux 系统这个文件通常位于 12vim ~/.nutstore/db/customExtRules.conffold/to/ignore # 文件夹的绝对路径 安卓系统上同步文件夹 安卓版的坚果云客户端只会打开临时指定的文件。如果希望跟在PC上一样的操作,将整个文件库都同步到指定的文件夹内,就要用FolderSync软件。 登陆坚果云官网,账户信息–>安全选项–>第三方应用管理,生成一个新的第三方应用 androidSync,密码为 xxxxxxxxxxxxxxxx,然后按照上述官网的指南一步一步配置 FolderSync 就可以了。回头还是用 「坚果云 Markdown」这款软件来阅读md文档。 托管密码 设置为 SafeInClound 的托管云盘。用户名是坚果云的登陆账户,密码为专门为其开通的第三方应用 mypass 的专门密码。Local Pfad 填写云盘内存储数据库文件的文件夹。","categories":[{"name":"IT","slug":"IT","permalink":"http://maiernte.github.io/wiki/categories/IT/"},{"name":"Tools","slug":"IT/Tools","permalink":"http://maiernte.github.io/wiki/categories/IT/Tools/"}],"tags":[{"name":"工具","slug":"工具","permalink":"http://maiernte.github.io/wiki/tags/工具/"}]},{"title":"使用Github维护知识库","slug":"IT/Tools/使用Github维护知识库","date":"2019-07-24T21:02:14.000Z","updated":"2019-08-15T09:40:53.000Z","comments":true,"path":"use-github-in-wiki.html","link":"","permalink":"http://maiernte.github.io/wiki/use-github-in-wiki.html","excerpt":"部署以及更新 初建:将文件夹设置为仓库。只是第一次需要,以后就基本不用。 git init 更新:更新所有的文件。 git add . 描述:更新描述(optional 不是必须的) git commit -m "my command..." 推送:上传到云仓库 git push -u origin master","text":"部署以及更新 初建:将文件夹设置为仓库。只是第一次需要,以后就基本不用。 git init 更新:更新所有的文件。 git add . 描述:更新描述(optional 不是必须的) git commit -m "my command..." 推送:上传到云仓库 git push -u origin master 详细指令 12345678git remote add origin https://github.com/maiernte/NewAngular.gitgit push -u origin master# For the next commit$ git add . # add to index only files created/modified and not those deleted$ git add -u # add to index only files deleted/modified and not those created$ git add -A # do both operation at once, add to index all files 下载及更新 1234567#下载整个项目git clone XXXXX#从服务器更新git pull [xxxxxx]#Helpgit hepl VERBgit VERB -h 克隆指定 Branch, 因为有时候 master 和 gh-pages 上存放的是不同的文档。 1git clone https://github.com/maiernte/gitbook_python_finance.git --branch master new_fold 设置忽略文件夹以及文件 12touch .gitignorevim .gitignore 并添加类似的行 12345678910111213# See https://help.github.com/ignore-files/ for more about ignoring files.# dependencies/node_modules# testing/coverage# production/build# misc.DS_Store.env.localnpm-debug.log*yarn-debug.log* 设置git身份信息 12git config --global user.name \"你的用户名\"git config --global user.email \"你的邮箱\" 密码和凭证 保存 Github 用户名和密码 Mac 下面每次 push 都要询问用户名和密码,很麻烦。而且将来不利于用脚本控制部署。有个解决的办法:进入项目根目录,执行一下命令 1git config --global credential.helper store 然后推送一次,输入账号和密码后,第二次推送就不需要了! SSH Key 凭证 12# 加入 SSH Agentssh-agent -s 如果出现类似Agent pid XXXX这样的字样,则跳过下一步,否则输入: 1eval `ssh-agent -s` 直到出现Agent pid XXXX这样的提示之后,输入: 1ssh-add ~/.ssh/id_rsa 这样,你成功的在本地生成了一个可用的SSH key。 下面将这个key添加到github网站。 打开https://github.com/settings/ssh,点击Add SSH Key,复制id_rsa.pub中的所有内容到Key框中,在Title框中输入方便自己记忆的名字(建议输入能让自己明白是哪台电脑的名字,方便以后管理)。 当网页显示添加成功后,就已经完成了全部的操作。 下面进行一些测试,同样是打开Git Bash,输入: 1ssh -T git@github.com bash中会显示如下字样: 123The authenticity of host 'github.com (207.97.227.239)' can't be established.RSA key fingerprint is 16:27:ac:a5:76:28:2d:36:63:1b:56:4d:eb:df:a6:48.Are you sure you want to continue connecting (yes/no)? 输入yes之后,计算机会自动将github.com列入已知的host,然后会出现如下提示: 12Hi username! You've successfully authenticated, but GitHub does notprovide shell access. 如果成功看见,说明你已经配置好了,快去享受爽快的hexo一键部署吧; 如果出现任何错误提示,请仔细检查自己的操作,或者将错误信息发给我。 参阅:十步轻松搞定Hexo 如果要多台电脑共同使用同一个SSH-Key,先在第二台电脑上用这个key的相同邮件生成一个新的key 1ssh-keygen -t rsa -b 4096 -C "username@gmail.com" 用第一台电脑上的两个key文件 id_rsa, id_rsa.pub 覆盖第二台电脑的文件(注意备份)。确保NEW上的两个文件的权限是正确的,id_rsa是600,id_rsa.pub是644,比如: 1234567-rw------- 1 fancy fancy 1675 2013-03-19 12:55 id_rsa-rw-r--r-- 1 fancy fancy 406 2013-03-19 12:55 id_rsa.pub# 查看权限命令是 ls -l# 更改权限命令是chmod 600 ~/.ssh/id_rsachmod 644 ~/.ssh/id_rsa.pub 删除仓库 点开仓库 点击右上角的 Settings 滚动到最下面 Done Zone, 选择 Delete this repository。 恢复所有修改 12345678910111213git checkout . #本地所有修改的。没有的提交的,都返回到原来的状态git stash #把所有没有提交的修改暂存到stash里面。可用git stash pop回复。git reset --hard HASH #返回到HASH点,不保留修改。git reset --soft HASH #同上,保留修改。HASH 是节点号,z.B. 7d593c5git clean -df #返回到某个节点git clean 参数 -n 显示 将要 删除的 文件 和 目录 -f 删除 文件 -df 删除 文件 和 目录--------------------- git describe --always # 查看当前节点号git log # 查看所有HEAD号和Commit描述 更加暴力的方式是 1it checkout . && git clean -xdf 清除历史记录 代码 1234567891011121314151617181. Checkout git checkout --orphan latest_branch2. Add all the files git add -A3. Commit the changes git commit -am "commit message"4. Delete the branch git branch -D master5. Rename the current branch to master git branch -m master6. Finally, force update your repository git push -f origin master 私人仓库 作为个人笔记,不应该设为public,这样别人可以浏览。==2019== 年Github更新了新的政策: GitHub Free:包含无限制的私人存储库。有了 GitHub Free,开发人员可以将 GitHub 用于私有项目,每个存储库最多可以有三个协作者。许多开发人员希望使用私人仓库申请工作,做一些 side project,或者在公开发布之前先私下尝试一些东西。从今天开始,这些场景在 GitHub 上可以免费实现(未来可能有更多场景)。 公共存储库仍然是免费的,并包括无限合作者。 点开仓库 点击右上角的 Settings 滚动到最下面 Done Zone, 选择 Make this repository private。 文摘资源 Git submodule 子模块的管理和使用","categories":[{"name":"IT","slug":"IT","permalink":"http://maiernte.github.io/wiki/categories/IT/"},{"name":"Tools","slug":"IT/Tools","permalink":"http://maiernte.github.io/wiki/categories/IT/Tools/"}],"tags":[{"name":"工具","slug":"工具","permalink":"http://maiernte.github.io/wiki/tags/工具/"}]},{"title":"Next以及wikitten主题添加内容折叠","slug":"IT/Web/Next主题添加内容折叠","date":"2019-07-23T18:29:33.000Z","updated":"2019-07-31T03:51:34.000Z","comments":true,"path":"next-collapse-block.html","link":"","permalink":"http://maiernte.github.io/wiki/next-collapse-block.html","excerpt":"添加代码 当有大段的代码直接展示在页面时,看起来臃肿且不便于观看,此时将代码折叠式最好的选择。下面是在Hexo的Next主题上添加折叠功能。","text":"添加代码 当有大段的代码直接展示在页面时,看起来臃肿且不便于观看,此时将代码折叠式最好的选择。下面是在Hexo的Next主题上添加折叠功能。 在main.js中添加折叠js Next主题的主要js位于 themes/next/source/js/src/post-details.js,在下面添加一下代码段: 12345678$(document).ready(function(){ $(document).on('click', '.fold_hider', function(){ $('>.fold', this.parentNode).slideToggle(); $('>:first', this).toggleClass('open'); }); //默认情况下折叠 $(\"div.fold\").css(\"display\",\"none\");}); Wikitten 主题添加到 themes/wikitten/source/js/main.js 后面。 自定义内建标签 在主题scripts下添加一个tags.js,位于themes/next/scripts/tags.js 123456789101112131415161718192021222324/* @haohuawu 修复 Nunjucks 的 tag 里写 ```代码块```,最终都会渲染成 undefined 的问题 https://github.com/hexojs/hexo/issues/2400*/const rEscapeContent = /<escape(?:[^>]*)>([\\s\\S]*?)<\\/escape>/g;const placeholder = '\\uFFFD';const rPlaceholder = /(?:<|&lt;)\\!--\\uFFFD(\\d+)--(?:>|&gt;)/g;const cache = [];function escapeContent(str) { return '<!--' + placeholder + (cache.push(str) - 1) + '-->';}hexo.extend.filter.register('before_post_render', function(data) { data.content = data.content.replace(rEscapeContent, function(match, content) { return escapeContent(content); }); return data;});hexo.extend.filter.register('after_post_render', function(data) { data.content = data.content.replace(rPlaceholder, function() { return cache[arguments[1]]; }); return data;}); 再继续添加一个fold.js,位于themes/next/scripts/fold.js 12345678/* global hexo */// Usage: {% fold ???? %} Something {% endfold %}function fold (args, content) { var text = args[0]; if(!text) text = \"点击显/隐\"; return '<div><div class=\"fold_hider\"><div class=\"close hider_title\">' + text + '</div></div><div class=\"fold\">\\n' + hexo.render.renderSync({text: content, engine: 'markdown'}) + '\\n</div></div>';}hexo.extend.tag.register('fold', fold, {ends: true}); wikitten主题将这两个文件复制到 themes/wikitten/scripts 目录下。 添加自定义样式 位于themes/next/source/css/_custom/custom.styl 1234567891011.hider_title{ font-family: \"Microsoft Yahei\"; cursor: pointer; color: red;}.close:after{ content: \"▼\";}.open:after{ content: \"▲\";} wikitten 主题将此代码添加到 themes/wikitten/source/css/_partial/article.styl 文件下面。在next 主题必须将==color: red==去掉,否则会影响大纲栏的颜色。 使用 在我们需要折叠的地方前后添加便签,示例用法: 123{% fold 点击显/隐内容 %}需要隐藏的内容。。。{% endfold %} 参考 Hexo next博客添加折叠块功能添加折叠代码块 Next主题实现内容折叠 jQuery 实现内容折叠功能 Hexo 标签插件 官方 实例 嵌套代码 Some Content 点击显/隐内容 <xsl:call-template name=“SetGlobaleVariable”> <xsl:with-param name=“name-variable”>po_bfa_swbh_laufbahn</xsl:with-param> <xsl:with-param name=“wert-variable” select="$bf_laufbahnzulage"/> </xsl:call-template> Mai, Düsseldorf linkgoogle.de Hexo 代码方式 Lorem ipsum dolor sit amet, consectetur adipiscing elit. Pellentesque hendrerit lacus ut purus iaculis feugiat. Sed nec tempor elit, quis aliquam neque. Curabitur sed diam eget dolor fermentum semper at eu lorem. DavidLevithan KOS xsldownloadcode11 code snippet Gist Hexo 方式 Gist (“48edcb5cfd92937ae61360b74852d4e1” 就是id。 而 “xml” 是我创建时的文件名)。地址是 git.github.com Javascript 方式","categories":[{"name":"IT","slug":"IT","permalink":"http://maiernte.github.io/wiki/categories/IT/"},{"name":"Web","slug":"IT/Web","permalink":"http://maiernte.github.io/wiki/categories/IT/Web/"}],"tags":[{"name":"Hexo","slug":"Hexo","permalink":"http://maiernte.github.io/wiki/tags/Hexo/"}]},{"title":"RZF Organisation","slug":"文档/RZF-Organisation","date":"2019-07-22T18:23:00.000Z","updated":"2019-08-22T08:39:21.000Z","comments":true,"path":"rzf-organisation.html","link":"","permalink":"http://maiernte.github.io/wiki/rzf-organisation.html","excerpt":"","text":"Kontakt Abteilung Verteiler “V-Krank” Für Ihre Krank- bzw. Gesundmeldung sowie alle übrigen Mitteilungen zum Thema Krankheit nutzen Sie bitte den Verteiler V-Krank (V-Krank-5011@fv.nrw.de). Verteiler “V-Heimarbeitszeiten” Für die Meldung der Heimarbeitszeiten nutzen Sie bitte den Verteiler V-Heimarbeitszeiten (V-Heimarbeitszeiten-5011@fv.nrw.de). Verteiler “V-Dienstreisezeiten” Über den Verteiler V-Dienstreisezeiten (V-Dienstreisezeiten-5011@fv.nrw.de) teilen Sie bitte Ihre Dienstreisezeiten, Lehrgangzeiten sowie das Ende des Dienstgeschäftes bei Dienstgängen mit. Zur Berechnung der Reisezeiten nutzen Sie bitte das im OASE-Vordruckschrank hinterlegte Berechnungsblatt (Vordruck H76 Reisezeitenberechnung). Verteiler “V-GST” Den Verteiler V-GST (V-GST-5011@fv.nrw.de) verwenden Sie insbesondere für die nachfolgenden Angelegenheiten: Fragen/Mitteilungen zum Thema Urlaub, Sonderurlaub, Dienstbefreiung Mitteilung von Zeiten bei vergessenen oder fehlerhaften GLAZ-Buchungen Mitteilung über die ganztägige Kernzeitinanspruchnahme (GLAZ-Tag) alle Fragen/Mitteilungen zu den übrigen Personalangelegenheiten, die nicht über die vorgenannten Verteiler abgedeckt sind. Personal Rohde, Rainer Telefon : (0211) 4572 - 2554 E-Mail: rainer.rohde@fv.nrw.de Uphoff, Christian christian.uphoff@fv.nrw.de \\Drucker \\C0114237\\DR011226","categories":[{"name":"文档","slug":"文档","permalink":"http://maiernte.github.io/wiki/categories/文档/"}],"tags":[{"name":"工作","slug":"工作","permalink":"http://maiernte.github.io/wiki/tags/工作/"}]},{"title":"Mac使用标签","slug":"IT/Mac/Mac使用标签","date":"2019-07-22T16:58:50.000Z","updated":"2019-07-31T03:51:34.000Z","comments":true,"path":"mac-using-tags.html","link":"","permalink":"http://maiernte.github.io/wiki/mac-using-tags.html","excerpt":"","text":"使用标签 在 Mac 上,执行以下任一项操作: 给打开的文件添加标签:将鼠标指针悬停在文稿标题右侧,点按箭头,在“标签”栏中点按,然后输入新标签,或者从列表中选取一个标签。 存储新文件时添加标签:点按“文件”>“存储”。在“存储”对话框中,在“标签”栏中点按,然后输入新标签,或者从列表中选取一个标签。 给桌面上或“访达”中的文件添加标签:选择项目,然后打开“文件”菜单。也可以按住 Control 键点按该项目,或用双指轻点它。在“标签”下方选取颜色,或点按“标签”以从更多标签中进行选择或输入新标签。在“访达”窗口中,也可以选择该项目,点按“标签”按钮 ,然后输入新标签,或从列表中选取一个标签。 查找含有标签的项目 在 Mac 上,点按程序坞中的“访达”图标 以打开“访达”窗口。 请执行以下一项操作: 搜索标签:在搜索栏中输入标签颜色或名称,然后从建议中选择该标签。 在边栏中选择标签:若要查看带有某个标签的所有项目,请在“访达”边栏中点按标签。若要更改在边栏中看到的项目,请选取“访达”>“偏好设置”,点按“标签”,然后选择想要查看的标签。 按标签将项目分组: 点按“分组”按钮,然后选取“标签”。 按标签排序项目:在任何显示方式下,选取“显示”>“查看显示选项”,点按“排序方式”弹出式菜单,然后选取“标签”。在“列表显示”下,选择“标签”复选框以显示分栏,将指针移到“标签”分栏上方,然后点按。再次点按分栏名称来倒序排列。 移除标签 在 Mac 上,请执行以下一项操作: 从项目中移除标签:按住 Control 键点按项目或使用双指轻点项目,然后点按“标签”。选择您想要移除的标签,然后按下 Delete 键。 从 Mac 中移除标签:在“访达”中,选取“访达”>“偏好设置”,然后点按“标签”。选择您想要移除的标签,然后点按移除按钮——。 编辑标签 在 Mac 上的“访达”中,选取“访达”>“偏好设置”,然后点按“标签”。 请执行以下一项操作: 在“访达”边栏中查看标签:选择标签右侧的蓝色复选框。 更改标签颜色:点按标签 旁边的颜色,然后选取新的颜色。 更改标签名称:点按标签,点按标签名称,然后输入新名称。 创建新标签:点按添加按钮 。 删除标签:选择标签,然后点按移除按钮 ——。 将标签添加到快捷键菜单中:在列表中选择标签,然后将它拖到您想要在窗口底部的个人收藏部分中替换的标签上方。当您按下 Control 键点按文件时,在出现的快捷键菜单中可至多有七个标签。 从快捷键菜单中移除标签:将标签拖出“个人收藏标签”部分,直到看到移除符号。","categories":[{"name":"IT","slug":"IT","permalink":"http://maiernte.github.io/wiki/categories/IT/"},{"name":"Mac","slug":"IT/Mac","permalink":"http://maiernte.github.io/wiki/categories/IT/Mac/"}],"tags":[{"name":"Mac","slug":"Mac","permalink":"http://maiernte.github.io/wiki/tags/Mac/"}]},{"title":"Mac备忘录","slug":"IT/Mac/Mac备忘录","date":"2019-07-22T16:47:47.000Z","updated":"2020-05-07T07:28:37.649Z","comments":true,"path":"mac-memo.html","link":"","permalink":"http://maiernte.github.io/wiki/mac-memo.html","excerpt":"","text":"指令和任务 隐藏文件夹 Terminal 命令 1234//显示隐藏文件defaults write com.apple.finder AppleShowAllFiles -bool true//不显示隐藏文件defaults write com.apple.finder AppleShowAllFiles -bool false 快速命令,打开访达窗口,然后 ⌘ + ⇧ + . 就可以隐藏/显示。 需要重启Finder使设置生效 : 重启Finder:窗口左上角的苹果标志–>强制退出–>Finder–>重新启动 允许任何来源软件 系统默认在 安全与隐私 里只显示 “App Store” 和 “App Store 和被认可的开发者”,没有 “任何来源”。开启的话需要在终端输入 sudo spctl --master-disable 并输入开机密码。 任务控制 将任务放在后台运行:command + & 将任务丢到后台暂停:ctrl-z 查看后台所有任务状态:jobs -l (会列出 1、2、3序列号) 将后台的任务拿到前台处理:fg %jobnumber (指序列号,而不是任务id) 将后台的任务变成运行中:bg %jobnumber 管理后台当中的任务:kill -signal %jobnumber 文件管理 标签的使用 参看 mac 标签的使用 通用技巧 输入法 查看按键字符 偏好设置 → 键盘 → 输入法,窗口右面会显示键盘⌨️图案,按住shift⇧键或者option⌥,会显示在不同功能键下面的字符。 通过Automator添加快捷键 文章来源 一次打开 Finder —> 应用程序 —> automator 选取 服务 从左边的双栏选取 使用工具—>运行AppleScript, 并双击运行。 出现文本框后选定(右栏最上边)没有输入 1234567on run {input, parameters} (* Your script goes here *) tell application "Safari" reopen activate end tellend run ⌘+S 保存,命名为 Open Safari。关闭automator 转到 系统偏好设置—>键盘—>快捷键—>服务—>通用—>open safari ,然后设定快捷键就好了。 电源管理 pmset是macOS下用来操作、电源管理的工具,可设定休眠模式、时间和唤醒时间或显示电源信息,不过因为它是一个命令列的指令,因此得透过终端机察看或修改设定。当你开启「终端机」输入pmset -g 会看到具体设置。 Standbydelay 28800 :将系统储存于內存中休眠,会消耗一些电力。 Autopowerofdelay 28800 : 把系统写入SSD硬盘中,将內存暂存关闭,依照这篇文章的说法,两者延迟时间28800秒(约八小时)会让电脑多维持內存八小时左右的电力。 tcpkeepalive :设定睡眠后是否还保持网络连接, 以便可以透过TCP唤醒系统 hibernatemode :睡眠模式。数字越小,耗电越高。可以设置为 25 1234sudo pmset -b autopoweroffdelay 300 # 将睡眠时间缩短为300秒(五分钟)sudo pmset -b standbydelay 300 # 然后将系统储存到SSD硬盘sudo pmset -b tcpkeepalive 0 # 将透过TCP唤醒系统的功能关闭sudo pmset -a hibernatemode 25 中间的参数-b是使用电池下的参数,-c为外接电源下的参数设定, -a 为所有情况下的设定。 升级到Mojave后鼠标发飘 前往偏好设置–>网络–>设定服务顺序(左下角齿轮),然后将蓝牙PAN拖到最上面。 网络资源 应用软件 大量破解资源分享的网站 MacEnjoy 在线文档 iMac 2012 规格 升级SSD固态硬盘 iMac 2012 21.5吋 拆卸指南 Mac升级外挂SSD硬盘 如何选择另一个启动磁盘 :pen: 官方说明 更换SSD固态硬盘攻略 固态硬盘通过USB 3连接到电脑,并格式化成 Mac OS 扩展 格式。 用 Carbon Copy Cloner(官网下载)把原硬盘的数据镜像到 SSD。完成后要制作恢复分区「Recovery HD」破解版下载地址 或者 SuperDuper :pen: 免费版可以全盘备份,而不支持增量操作。 重启,听到 「当 」一声后按住 Option 键(windows 键盘上的 Alt)。然后选择SSD作为启动硬盘。 开机后用 Trim Enabler(官网下载)开启 Trim 读写加速。:+1:","categories":[{"name":"IT","slug":"IT","permalink":"http://maiernte.github.io/wiki/categories/IT/"},{"name":"Mac","slug":"IT/Mac","permalink":"http://maiernte.github.io/wiki/categories/IT/Mac/"}],"tags":[{"name":"Mac","slug":"Mac","permalink":"http://maiernte.github.io/wiki/tags/Mac/"}]},{"title":"爱乐之城——影评","slug":"摘录/爱乐之城——影评","date":"2019-07-21T19:17:19.000Z","updated":"2019-08-14T06:31:50.000Z","comments":true,"path":"lalaland-film.html","link":"","permalink":"http://maiernte.github.io/wiki/lalaland-film.html","excerpt":"","text":"我在凌晨三点醒来的夜里,想起已失去的你,曾经说着永远一起,现在却不再联系。如果当时的我们能少一些固执,是否会有更好的结局。 洛杉矶,华纳兄弟电影厂旁边的咖啡馆,明星来往不息。一身素雅的米娅是这里的收银员。她的梦想就是成为一个知名演员及编剧。所以她经常请假去试镜,跑遍大大小小的片场。虽然每次她都充满希望,但现实却是四处碰壁。这天,又一次遭受打击的米娅垂头丧气回到家中。洗去一身疲态后,她站在镜子面前暗自神伤哼起歌来 。这时室友火急火燎的出现,邀请她一起去参加派对。本来心情极度郁闷的米娅不想去凑热闹。经不住一帮二货室友的游说,精心打扮一番后她们就出发了。 洛杉矶的月色下,灯红酒绿,觥筹交错。但热闹是属于他们的,安静下来后她却感到愈加落寞。人潮中充斥着过剩的荷尔蒙,但却没有她想要的一双眼睛。世界瞬息万变,她却岿然不动。逃离狂欢派对后,违规停放的车子又被拖走。米娅只能走路回家,在安静的街头上。忽然一阵悠扬的钢琴声传来,如梦似幻,温润缠绵。米娅停下脚步,来到了一个毫不起眼的地下酒吧。一个优雅的男人坐在无人注意的角落里安静的弹奏着。此刻,全世界好像都暗了下来,只有他闪着耀眼的光芒。男人名叫塞巴斯汀,是一个爵士乐钢琴师。他对音乐有着自己独特的追求,不愿弹奏靡靡之音。可一曲弹罢,没有人为他鼓掌,他也被老板炒了鱿鱼。塞巴斯汀愤愤的离开,米娅鼓起勇气迎面走过去,想要认识这个让她着迷的男人。但一句话还没说完,男人就径直的走开了。米娅扑了个空,尴尬的站在那里不知所措。 生活依然按部就班,米娅依然忙着追逐她的梦想。一次派对上,米娅又遇上了塞巴斯汀。他加入了一个爵士乐队,但他们的演奏依旧没人捧场。为了惩罚这个「严肃」的音乐人,也为了报复上次给她造成的尴尬,米娅点了一首非常不严肃的音乐,她甚至随着音乐舞动起来。而塞巴斯汀却站在那里既尴尬又无奈。米娅的行为让塞巴斯汀想起了那晚的无礼。他向米娅道了歉,两人算是相识了。聚会结束后,米娅又找不到车子,于是两人在夜色下散步。洛杉矶的夜色此刻显得如此迷人,在暧昧的氛围中,他们默契地跳着属于他们的舞蹈。 第二天塞巴斯汀来到米娅工作的咖啡店,下班后他们一起在片场附近的街头闲聊,塞巴斯汀鼓励米娅给自己写剧本,而不是去演别人的剧本。自己给自己创造角色,说不定会有意想不到的效果。米娅也向塞巴斯汀坦白说,她讨厌爵士乐。于是固执的塞巴斯汀就带米娅来到一个演奏爵士乐的酒吧,他试图改变米娅对爵士乐的看法,向她解释爵士乐的起源。然而米娅还是不能理解,对音乐有执念的塞巴斯汀表示,他不想让爵士乐就此消亡,他想要创建自己的俱乐部,在那里只有纯粹的爵士乐,那是他一直以来的梦想。 这天又一次试镜失败的米娅心情沮丧,经过电影院门口时,她想起和塞巴斯汀的电影院之约。顿时心情变得愉悦,这时几个月不见一次的男友却来接她一起吃饭。餐桌上米娅心不在焉,男友却把她晾在一边,自顾自的和哥哥聊天。而在电影院门口的塞巴斯汀焦急的等着米娅,此时餐厅传来了熟悉的曲子,那个夜晚塞巴斯汀弹奏的正是这首曲子。米娅随即起身跑了出去,穿过色彩缤纷的霓虹灯,她找到了失落的塞巴斯汀,此时的两个人根本无心观看电影。他们指尖轻触,随后十指紧扣,接着互相靠近……但灯光却忽然打开,两人无奈的相视一笑。之后米娅带着塞巴斯汀来到天文馆,他们在浪漫的氛围中翩翩起舞,魅惑的蓝色星空下,两人仿佛和整个宇宙融为一体。 金风玉露终于相逢,热恋之吻甘之如饴。随后两人一边热恋,一边为各自的梦想努力。他们一起旅行、一起恶作剧,他们走遍大街小巷,他弹琴、她跳舞,在塞巴斯汀的影响下,米娅渐渐喜欢上了爵士乐。这天早上,塞巴斯汀无意中听到了米娅和她母亲的通话。米娅的母亲对她们的未来很担忧,因为塞巴斯汀没有稳定的工作。寥寥几句话,就将塞巴斯汀从梦中拉回现实。他接受了前乐队主唱的邀请,成为了他们的键盘手。但这就意味着塞巴斯汀必须放弃自己的坚持,跟着乐队的风格走。晚上回家的米娅,听到塞巴斯汀的琴声,感受到了他失落的情绪。无需过多的话语,米娅和着琴声唱着歌,这种默契让他们心照不宣。就这样两人互相鼓励,互相安慰,塞巴斯汀的乐队开始走红。米娅也陆陆续续接到了一些大大小小的角色。看着梦想之门慢慢打开,他们也变得越来越忙碌。乐队巡演时,米娅站在台下看着万众瞩目的塞巴斯汀,喧闹的人群,闪烁的灯光,流行的爵士乐,一切看起来都那么美好……台上的男人意气风发、星光闪耀,米娅却觉得和他有了距离。晚上回到家的米娅得到了一个大大的惊喜。忙碌的他们很久都没有见面了,塞巴斯汀明天一早又要离开,他想要让米娅跟他一起,米娅却问他喜不喜欢现在弹奏的音乐?但此时的塞巴斯汀已经尝到了名利带来的甜头,他放弃了曾经的梦想,也放弃了曾经的坚持。他以为这些是米娅想要的:稳定的生活,不菲的收入,以及聚少离多的爱情。他说以前那些梦想太虚无缥缈,现在他需要成熟起来。最后激动的塞巴斯汀对米娅说,你喜欢以前不堪的我,是因为相比而言,那会让你感觉自我良好。这句伤人的话使得他们关系僵化,接着米娅一声不响的离开。第二天在给乐队拍宣传片的时候,摄影师让塞巴斯汀随便弹,于是他弹起了熟悉的曲子,接着他似乎想起了什么……再一次试镜被嘲笑后,米娅心情降至冰点。她准备返回老家,这个城市再没什么值得她留恋,梦想也好,爱人也罢,终究只是一场梦。面对挽留的塞巴斯汀,她再也无法忍受,哭着说她受够了。米娅回到了自己的家,塞巴斯汀也回到了乐队。 一段时间后,塞巴斯汀出现在了米娅家门口。一个知名导演正在选角,试镜电话打给了塞巴斯汀,在塞巴斯汀的鼓励下,米娅鼓起勇气决定再试一次。导演让米娅随便讲一个故事,于是她用歌声讲述了自己的梦想。面试过后,他们来到天文馆门口,一起谈论着对未来的打算。他说你的梦想一定会实现的。秋天的洛杉矶,纯净而理性。他们的感情在这里开始,也在这里结束…… 五年后米娅成了知名演员,实现了自己的梦想。她事业有成,结婚生子,生活安稳,家庭美满。晚上米娅和丈夫遭遇堵车,路边散步时发现了一个酒吧。热闹的气氛吸引了米娅的注意,这正是当年塞巴斯汀带她去的酒吧。米娅发现酒吧的名字是她多年前为塞巴斯汀取的。这里只有纯粹的爵士乐,塞巴斯汀的梦想就是拥有这样一个地方。落坐以后,塞巴斯汀看到了台下的米娅,沉默片刻后,他弹起了那首熟悉的音乐。 就像最初他们相见时那样,他们忘记了全世界。那个夜晚,那次初见,时间仿佛从未流逝。但这次不等她说完一句话,他就热烈的吻上了她唇。他毫无顾忌,她毫无防备,他们痴迷于彼此的味道。他们翩翩起舞,一路走向梦想,走进热恋,相互陪伴,相互成全,一起成长,一起狂欢。然后携手走进那片星空。他眼神温柔,她身姿婀娜。他们打造着自己的小窝,享受着二人世界。爱的结晶来到他们身边,放佛那些美好是和他一起度过的。直到今天这个夜晚,他们始终如一,此志不渝。 曲终之后,她被拉回现实,然后和丈夫一起离开。在拐角处她转身,回头,两人遥遥相望,然后互相报以微笑。时隔经年,若我遇见你,我该如何与你致意?以眼泪,以沉默! 我一同学特别喜欢这部电影,我知道那是因为她在电影中看到了自己。她的挚爱,七年长跑,可终究还是没能走到一起。或许这就是所谓的「在别人的故事里,流着自己的眼泪」。你是否也在无人的深夜,想起某个人,然后哭着醒来。看着周围的一切,熟悉又陌生,那个藏在心里的人啊,此时你身在哪里?可知有人还在深爱着你。虽然思念依然刻骨铭心,但你们之间却只剩下曾经。最怕的莫过于,在寂静无声的日子里,莫名其妙的,突然听懂了一首歌,只是你听到的不再是歌曲,而是人生。 「初识不知曲中意,再听已是曲中人」……就像是做了一场梦,醒来之时万籁俱寂,物是人非事事休,欲语泪先流……年少时我们总想给最爱的TA更多,却忽略了TA最想要的只是真实的你。后来的我们什么都有了,但却没了我们。我还是我,你还是你,我们却不再是我们。……于是你只能在某个深夜,听着歌,流着泪,然后默默的在心里对那个人说,今夜,我不关心世界,今夜,我只想你。","categories":[{"name":"摘录","slug":"摘录","permalink":"http://maiernte.github.io/wiki/categories/摘录/"}],"tags":[{"name":"影视","slug":"影视","permalink":"http://maiernte.github.io/wiki/tags/影视/"}]},{"title":"财富自由之路-李笑来","slug":"读书笔记/财富自由之路-李笑来","date":"2019-07-21T07:05:22.000Z","updated":"2019-08-14T06:36:09.000Z","comments":true,"path":"road-to-asset-freedom.html","link":"","permalink":"http://maiernte.github.io/wiki/road-to-asset-freedom.html","excerpt":"","text":"进度:10课 哲学层面 金钱、时间、注意力 钱不是最重要,它可以再生。时间也不是,它本质上不属于你,你只能试着与它做朋友。注意力是自己可以做主的。必须把宝贵的注意力全部放在自己身上。放在自己的哪儿上?答:“成长”。不珍惜自己注意力的人最终注定是贫穷的,因为他们终生被收割,不可能有真正有价值的产出,怎么可能最终变得富有?另外,要放在自己的真爱上,以及对整个社会真正有贡献的事情上。(对于后两者,关注的焦点还是“成长”。) 注意力才是你人生最宝贵的财富(不是金钱和时间),你的一切价值都是你的注意力的产出。 俗三个大坑:1. 莫名其妙的凑热闹。2. 心急火燎的随大流。3. 操碎了别人的心 (万众创业关你屁事,干好自己的活)。 金钱、时间和注意力的比较:$ 注意力 > 时间 > 金钱 $ 凡是可以用钱买的其实都是便宜的。 凡是能用钱买来的时间就是便宜的。 凡是能用时间换来的注意力持续就是有价值的。 :question: 时间和金钱谁更重要。 答案是时间。因为财富自由的定义就是“不为生活需要出售时间”。另外一个角度是,“花钱买你的时间更划算”。 :question: 注意力和时间更重要。 注意力是能让你有所产出的唯一资源!而时间不一定是你的,时间不会自动产出。(李笑来: 花大量时间与老婆沟通,陪伴,以便换来自己集中注意力工作的机会。) 合作与信任 追求百分百的安全感,肯定会把自己困在了永恒的当下。必须放弃一部分安全感,才能有深入的、长期的观察和思考。打破枷锁的方法: 放弃部分安全感,才能获得进步。 通过有效社交,补全主动放弃的安全感。 :bookmark:【合作】​ 的本质是大家各自放弃一小部分安全感,并把那一部分安全感交给合作方来保障。 :bookmark: 【信任】就是相信对方不会利用自己主动放弃的那一部分安全感。所谓缺乏安全感,就是不相信别人竟然可以不利用自己放弃的那一部分安全感,所以只能自己去搞定百分之百的安全感,让人心力交瘁。 不要与缺乏安全感的人合作。尤其是婚姻。 最大的勇敢,就是在孑然一身的时候,还勇于放弃部分安全感。“大智若愚”,大智更像是结果。若愚才是原因。 将军赶路不打小鬼。 活在真实中 如果想活在真实的世界,就要勇于面对「真实」。要搞清楚以下几个概念。 什么算落后 20%之后都是落后,因为世界20%的人占了有限资源的80%。在人工智能和新技术时代,可能1%之后都算落后。将来可能是千分之一,万分之一之后都算。 我们每个人都已经可以尽量感知到这个世界的全部。所以要对自己是否处在落后状态有清晰认知。 我们对知识的渴求已经变成害怕落后。这是种危机感和焦虑,但它能帮我们持续进步,摆脱落后。 乌比冈湖效应:Lake Wobegon Effect 每个人都自认高于平均水平。 邓宁- 克鲁格效应 :Dunning-Kruger Effect 能力欠缺的人有一种虚幻的自我优越感,错误的认为自己比真实情况更加优秀。 麻烦守恒定律:以前因为怕麻烦二省去的麻烦,在未来的某一天,或者未来的某一时刻,一定会以另一种形式呈现在你面前。麻烦不会无缘无故的消失,问题也不会无缘无故的解决。 元认知能力 :pencil:指对自己的思考过程的认知和理解。 元认知能力起作用的三个步骤: 哦,原来我是这么想的。 嗯?我这么想难道是不对的吗? 啊!我应该这么想才对。。。。 认知能力好比是马,而元认知能力是马车夫。所谓可以用来解放自己的“心智”,指的就是具备足够的元认知能力的大脑。人与人之间的技能差异,证据确凿来自于“刻意锻炼”。而一个人能做到“刻意锻炼”,唯一能够仰仗的就是元认知能力。 元认知能力是一个人可拥有的最重要的能力。 元认知能力不仅可以习得,还可以通过刻意训练长期持续发展。 我们知道我们想要改变的,能够改变的,不是“现在的自己”,而是“将来的自己”。通过刻意练习提高元认知能力的三个方法:坐享、兴趣、反思。 坐享:可以增加大脑皮层的沟回。 兴趣:兴趣是最好的教学。 反思:每天花十分钟反思一下自己的思路和思考结果,琢磨一下自己想法有没有逻辑错误。不仅是元认知能力的刻意训练方式,也是调整情绪的根本。 竞争力 多维竞争 😂 据说绝大多数人的幸福感是建立在比较之上的。有个玩笑:所谓的幸福就是自己的收入总比妹夫的收入多百分之二十。。。。。 😂 一般人所谓的“成长”,就是不断的把别人比下去的过程。 维度在生活上有三个体现: 生活是有多个维度的。 在多个维度打造竞争力。 至少在一个维度上足够突出。凡事都是有成本。处处平庸是不行的。 面对维度,要有以下意识: 单个维度,大家比的是长度,两个维度上大家比的是面积,三个维度上大家比的是体积。 每次跨界,都是给自己拓展一个新的维度。 对新知识保持开放态度。 应用层面 「活在未来」 如何活在未来 对未来要有个预测 那个预测需要时间才能得到结果 笃信你的预测是正确的。 于是你按照那个预测的结果行动、选择、思考。 你终将走到那个结果出现的时刻 最终证明你的预测是正确的。 那么,由于你提前按未来正确的结果行动、选择、思考,于是,在相当长的时间里,你生活的一部分就是“活在未来”。 人际关系的本质 人际关系在本质上还是交易。明白这一点,就能更清楚的看清楚关于贵人的问题。 $ 求助别人 != 麻烦别人 $ 求助不是低声下气的行为,而是一种交易。不仅如此,还是一种隐蔽的、意义巨大的交易。贵人之所以原因帮助你,是因为他已经看到你的价值。分清楚“求助”、“乞讨”、“添麻烦”、“占便宜”之间的区别。 能够遇到贵人在一定程度上是偶然也是必然,它是自己生活的一面镜子。你是贵人,生活这面镜子就帮你找到更多的贵人。至于是偶然还是必然,其实你是控制不了的。自己首先得是个贵人,才能遇到贵人,甚至更多贵人。最不济,你也已经成为自己的贵人,而且不会轻易离你而去。“遇到贵人”这件事从来不是我们的目的,相反“成为贵人”倒是我们应该努力的方向。在你出手相助的那一瞬间,你已经得到了自然的回报。 12条遇到贵人的原则: 乐观的人更容易成为他人的贵人 贵人更容易遇到贵人 能帮助他人进步,才是真正的贵人 优秀的、值得尊重的人,更容易获得帮助。 乐于分享的人容易获得帮助 不给他人制造负担的人容易获得帮助 不以求助为耻的人容易获得帮助 求助的时候不仅仅用金钱作为回报,帮助他人的时候也不应该收取金钱回报。 贵人不一定是牛人,贵人通常“以和为贵”。 很多时候,人们的成功,来源于大量的人希望看到他成功。反过来,如果大量的人不愿意看到某人成功,那么这个人真的很难获得所谓的“贵人相助” 正在做“正确”事情,更容易获得贵人相助。也就是所谓的“得道多助”。 活在未来的人更容易遇到贵人,因为别人能在他身上看到未来。 资本的定义 钱和资本不是一样的东西,正如砖头和房子不是一回事。钱要成为资本必须满足三个基本要素: 资金的金额大小 资金的使用时限 资金背后的智慧 残酷的事实,大多数人其实不配站在资本之后。好消息是资本背后的实力是可以习得的。不能被自己心平气和判上无期徒刑的资金,就别假装资本出来混迹江湖。大多数人在股票市场上“投资”的不是资本,而是“装傻充愣的资金”而已。 暂时不知道往哪里分 好的工具应该让人离开它,而不是黏住它。 你创造财富能力取决于你能给别人创造多少真正的价值。(只有你觉得有价值的话,是几乎没有什么意义的)。 财富自由之路 - 思维导图 (看全景导图请点击链接)","categories":[{"name":"读书笔记","slug":"读书笔记","permalink":"http://maiernte.github.io/wiki/categories/读书笔记/"}],"tags":[{"name":"成长","slug":"成长","permalink":"http://maiernte.github.io/wiki/tags/成长/"},{"name":"经济","slug":"经济","permalink":"http://maiernte.github.io/wiki/tags/经济/"}]},{"title":"《少有人走的路》笔记","slug":"读书笔记/《少有人走的路》笔记","date":"2019-07-20T22:14:37.000Z","updated":"2019-08-01T04:04:18.000Z","comments":true,"path":"road-less-traveled-summary.html","link":"","permalink":"http://maiernte.github.io/wiki/road-less-traveled-summary.html","excerpt":"成熟 = 自律 + 爱","text":"成熟 = 自律 + 爱 自律 【自律】 : 主动要求自己以积极的态度去承受痛苦,解决问题。 自律的四个原则:延迟满足感、承担责任、忠于事实、保持平衡。:smile: 1 延迟满足感 人生当中总是绕着困难走。一个揍孩子和对孩子大喊大叫的父母就是不懂得延迟满足感的父母。 应该陪着孩子一起经历困难和痛苦。而父母试图通过家庭暴力的方式,试图将父母本身的责任区隔开。父母没有学会延迟满足感,这个孩子将来长大了也不会。很多人延迟满足感的能力非常糟糕,来自于父母的不自律。当父母不自律的时候,孩子就没法获得足够的爱和照顾。—— 所以这个孩子会忽略自我的价值。有的人喜欢浪费时间,而浪费时间的意思就是,_「我这个人的时间没什么价值」_。 不会延迟满足感的人,在长大后看到问题会假装没看到,以为等着问题慢慢就会过去,期待问题自行消失。 训斥孩子 ~> 是为了迅速达成目的,而不是耐心陪孩子面对问题。 父母不自律 => 孩子不自律 不会延迟满足感 => 有意忽略问题 2 承担责任 神经官能症: 把一切东西都认为是自己的问题。 我如果怎么样就好了。我要是不怎么样就好了。总是充满后悔和内疚。祥林嫂 人格失调症:他认为这一切都不是我的问题。他能找到任何一个理由,是因为外在的东西,他就不会责怪自己,他认为都是你们的问题。 「神经官能症」自己活得很痛苦,「人格失调症」让别人活得很痛苦。 作者提供在冲绳岛上的一个案例,一个军官的妻子,宁愿自杀也不愿意去学自动挡开车的事。 从某种意义上说,所有的孩子都患有人格失调症,都会本能的逃避责罚。 同时又患有某种神经官能症,把自己承受的痛苦看成是罪有应得。缺少关心的孩子会自惭形秽,认为自己不够可爱,缺点大于优点等等。 如果你不能解决问题,那么你自己就会成为问题。我们需要合理的承担责任,既不把责任全部推卸到外部,也不把责任全部揽到自己身上。保持一个合理的平衡。 如果你不能让自己成为人格更加健全,更加成熟的人。你就会把问题带给你的孩子,带给你的家庭。 3 忠于事实 大量的人是生活在自己的幻想当中的。这叫人生地图。他给自己绘制一张人生地图,他认为人生就这样,他已经认定了。这就叫做“不忠于事实”,他只 忠于自己的幻想。 案例:有个人小时候被父母欺骗过,就是父母说话经常不算数。导致他潜意识积累了一个信念:“父母是不可信”的。当他的人生地图绘制出来这么一个坐标,认为父母不可信了自后,他几乎就推论到“人人都不可信”。所以在他一生的成长过程当中,他跟警察发生矛盾,跟领导发生矛盾,跟顾客发生矛盾,跟妻子发生矛盾。案例中最后他唯一信任的是他的两个孩子。妻子把两个孩子带走,所以他人生也崩溃了。他跟作者约定时间不来,然后他说能不能星期六,作者说我的时间是跟别人约过的,不能随便调整。他说:“你不是心理医生吗?为什么不能多关心我一点呢”?他认为作者(心理医生)也是不可信任的人,直接拉黑。 这种人你很难跟他解释,很难让他面对真正的世界。因为在他心目当中完全是用自己的一套逻辑在解决问题。 所以所谓的「心理治疗」,就是鼓励「说真话」的游戏。鼓励大家能够面对事实,能够把自己看到的真相,感受到的真实的感觉,说出来的一个过程。所以没有经过这样的调试,有大量的人是天天活在「幻觉」当中的,就是沉浸在自己的人生地图当中。根本不去看一看,别人的地图是什么样。也根本不去看一看实际的生活当中,事实是什么样的。 移情:人们会把对一个人的感情和经验移植在别人身上。会认为别人也这样。 应该说移情、或者忽略史实,也是一种懒惰的表现。因为去更新地图是件很费力的事情。 4 保持平衡 既要承担责任,也要拒绝承担不该承担的责任。差不多又回到了「中庸」之道。「延迟满足」也不能延迟到无限, 从来不过好日子。既要延迟满足,也要过好当下的生活。要有一个富于弹性的约束机制。好像骑自行车下坡一样,既要享受速度,也要注意刹车。为了待会安全的拐弯,也要捏一捏车闸。 生活就是一个不断放弃的过程。必须能够学会放弃一件又一件的事情。包括接受心理治疗就是「放弃」—— 放弃了一个「自己是正常人」 的想法。 埃里克 埃里克森列举的人一生当中不断放弃的事情 首先要放弃「无需对外界要求作出回应」的婴儿状态。 三四岁的时候有「无所不能的幻觉」,这个要放弃掉。(为何小孩子特别喜欢绿巨人、钢铁侠、金刚狼这样的超级英雄?因为每个人在三四岁的时候都曾经幻想过自己是无所不能的超人。所以这种童话永远有市场。) 放弃完全占有父亲或者母亲的欲望。放弃童年的依赖感。 放弃心中被扭曲了的父母形象。(我们曾经以为父母是完美的)放弃。 青春期的自以为拥有「无穷潜力」的感觉。放弃! I am the King of the World! 无拘无束的自由 青年时期的灵巧与活力 青春时期的性吸引力;长生不老的空想。 对子女的权威(在子女面前总是说了算的) 各种各样「暂时性」的权力——退休了,社会给你的权力也没有了。 身体永远健康——放弃 最后,自我以及生命本身也要放弃。 爱 【爱】 :为了促进自己和他人心智成熟,而不断拓展自我界限,实现自我完善的一种意愿。 核心观点就是「要看重心智成熟这件事」。心智成熟是发生在你和被爱的那个人之间的,两个人都需要达成心智成熟。 不要以为一昧的付出就是爱。爱的要求很高。要达成两个的共同成熟 一个人懂得什么是真正的爱,才能够是一个真正成熟的人。否则你会看到很多人以「爱」的名义在伤害、控制、占有对方。「爱」有以下四个误区:过度关注、坠入情网、精神灌注、自我牺牲。 过度关注 实际上是一种「依赖」 例子,一个妈妈,孩子都上高中了,还每天开车接送孩子上学。说孩子一个上学走太让人担心了。「过度关注」实际上是一种「依赖」。(妈妈在“依赖”这个孩子)这种类型的人经常说的话是“没有你我活不下去”。这个小孩之所以出现在书中,是因为孩子长大后来做了心理咨询。他在人生当中做任何事情都不成功。他的能力非常的欠缺。为什么?因为他从小到大完全被母爱这样束缚着。他妈妈根本不去管孩子能否「成熟」。他妈妈根本不去管这样做对孩子的心智健康、发展有没有好处。唯一的就是「你别出事,我必须盯着你」!`她不是为对方在做这样的事,她是在为自己做这样的事情。如果发展到极致,变得很严重的话,会变成一种疾病,叫「消极性依赖人格失调症」。—— 他必须依赖某一个外在的东西,他才能够觉得自己是存在的。如果有这么一个人,就是死死的缠住他,就是不离开他。有一个人作为对象,他才能找到自己的位置。如果找不到这样的人,就很可能会沉迷于毒品和酒精。 对「爱」无度的索求 对别人的爱根本与对方无关,他只是希望找到一个人,能够投射自己在上面,能够找到自己——「因为有人爱我,我就存在」。(例子,有个人离婚了,生活很痛苦,用酒精麻醉自己。咨询的第二天来跟医生说,我好了,我现在很幸福。因为昨晚在酒吧认识一个女人,她说她爱我。我现在很好。)总是苦思如何获得别人的爱,却没有精力去爱别人。就像饥肠辘辘的人,总想着向别人讨要食物,却拿不出食物来帮助别人。他们永远孤独寂寞,永远无法体会到满足感。尤其可怕的是,他们不知道自己患上了「消极性依赖人格失调症」。其造成原因多是童年缺乏爱,然后总觉的自己「没资格被爱」。人要感觉自己是被爱的,才有资格跟别人平起平坐,独立地生活和对话。患有这种心理疾病的人,他根本没有感觉到自己的资格,永远都在怀疑别人不爱他。所以只要别人拒绝他,就会感到无比的痛苦和伤心。而他永远需要找到一个紧紧拉住的,依赖的对象。这不是爱,这是占有。 坠入情网 坠入情网是欲望。是你体内的激素分泌。因为我们的基因要求我们要生殖,见到异性感觉自己爱上他了。实际上是自己的一种欲望。一段时间后当你的欲望被释放掉了,体内的激素的大潮开始退去的时候,会发现这个人看起啦那么讨厌。坠入情网实际上是「自我界限的短暂崩溃」。除了自我界限的理论,还有以下几个点: 不是出于主管意愿,它不是一个有计划有意识的选择。(很多人只把它看成一个感觉,而不是一个「动作」,爱是一个动词,不是感觉) 不是自我界限的扩展,而是自我界限的部分的暂时性的崩溃。扩展自我界限需要付出足够的努力,坠入情网却无需努力。 坠入情网唯一的作用是消除寂寞。而不是有目的的促进心灵的成长。 简单来说贪恋爱可能是「爱」的发端,可能能培养出来爱,但它不是「爱」本身。 精神贯注 爱宠物、爱好这些也不是爱,而是「精神贯注」。就是当你把自己的精神贯注在一个事物上的时候,你以为这只狗“懂你”,其实上是“你投射在了它身上”,你在猜想它的想法。跟真正的爱不一样。为什么呢: 首先,我们跟宠物的沟通非常有限。我们不知道他们每天在想什么,却一厢情愿的把自己的想法和感受投射在它们身上。实际上这只是我们的主观愿望罢了。 其次,我们喜欢宠物的原因是因为它们表现乖巧,任凭摆弄。如果宠物不听话,破坏家具,随意大小便,甚至咬上我们几口。我们就可能把它赶出家门。如果要改变宠物的心智,我们只能把它送到宠物学校。如果与某个人相处,局面就完全不同了。 有一种精神贯注叫「婴儿之爱」。 很多妈妈只喜欢婴儿期的孩子。等孩子三四岁以后妈妈开始烦了。赶紧推给爷爷奶奶带。反过来呢,母爱很充沛,喜欢别人家的孩子,刚生的小婴儿。 这种不是爱,而是「唯命是从的追求」。 比如二战后美国的「战争新娘」。一开始新娘对丈夫唯命是从,当她们懂得英语,开始融入美国社会以后,矛盾就渐渐开始产生,离婚率开始上升。 以上几种感情我们误以为是爱,其实不是。它们都有共同的特征,就是以「爱」作为幌子,只想满足自己的需要。却从来不把对方的心智成熟当一回事。 自我牺牲 甚至还有人人会发展出来「自我牺牲式的爱」。有个妻子,她老公总是欺骗她,总是有外遇。每次闹完,老公回来道歉,她又开始接受他。五六次以后,妻子去找心理医生谈。心理医生告诉她要想清楚,不能老是这样接受他。有一次这个妻子说,我又原谅他了,这次他是真的改好了。他特别怎么怎么样。结果医生发现这个妻子有“受虐倾向”。有受虐倾向的人,会把「自我牺牲」当作是「爱」。他们觉得只要我能够牺牲、奉献就好。 这些东西也是来自童年的经历,就是他童年当中如果有一个这样的“楷模”,总是以自我牺牲为标榜,总是以为我为别人牺牲了那么多,所以 “你看我多好,多高尚”,他在潜意识当中就会慢慢接受“自我牺牲就是爱”这种想法。 **自我界限**: 小孩子刚出生的时候是没有自我界限的。他在挥动胳膊的时候,觉得整个房间都在动,他与这个世界没有是分割的。到了两三岁发现自己挥动胳膊的时候,房间没有动,甚至他发现自己哭的时候,别人并不饿。 才能慢慢感受到原来自己跟他人是不一样的。到青春期这个人的自我界限已经开始完全封闭起来了。原来这个世界只有我自己,连我的父母都不了解我,我的喜怒哀乐他们根本不知道。所以人们开始陷入深深的孤独。青春期的孩子觉得自己最“孤独”,他觉得没人理解他,我是一个完全独一无二的个体,谁跟我都不一样,他的自我界限完全封闭起来。 到了谈恋爱。谈恋爱是需要冒风险的,你是需要有勇气打开自我的界限,和另外一个人融为一体的。所以初恋的时候,很多人会有「**圣洁**」的感觉。就是“我打开了”,有一个人竟然“完全懂我”。有一个人可以跟我融为一体,那种水乳交融的感觉,他以为自己找到了「真爱」。因为他的边界在短期的崩溃。当他的自我边界崩溃以后,他感受到了生命的狂喜,那个就是短暂的获得了「爱」的感觉。但是那是假象。`因为那个并不建立在令我和对方人格不断成熟的一个过程当中。他并不是希望达成心智的成熟,他只是自我边界的短暂崩溃`。所以过了一两个月以后,这个自我界限慢慢弥合起来,他发现说“这个人怎么跟我也不一样”?“这个人的想法跟我也不同”。 现在的孩子谈恋爱特别快,有感觉就谈,没感觉了就分。把「感觉」当成了「爱」,事实上感觉只是欲望,是性欲。 但不要觉得欲望不是一件好事,无论是欲望,还是依赖,或者过度关注这样的东西,都是`培养爱的基础`。 正是因为两个人打破了边界,走到一起,双方有可能为对方作出了承诺。接下来为了完成自己的承诺,需要不断的努力,需要有自律性。当你的自律性跟承诺相结合在起来的时候,你的这个短暂的恋爱的感觉爱,会慢慢滋生出真正的爱。 能够带来对方和自己心智共同的成熟。 真正的「爱」 :爱是实际行动,是真正的付出。 爱的感觉与精神贯注密不可分。后者是把情感与兴趣贯注在对外的对象上,将其当作属于自己的一部分。精神贯注虽然跟真正的爱容易混淆,但是依然有显著的区别。首先,精神贯注的对象不一定是有生命的事物。因此就不见得会有心灵的感受。其次,对某种事物产生精神贯注的人,未必会重视其心智的成熟。(比如无原则溺爱孩子的父母)第三,精神贯注可能与智慧和责任无关。(酒吧认识一个人,立刻就情有所钟。但没有任何计划性,没有后续责任)。最后,精神贯注随时都有可能消失。今晚还很开心,明天不开心就分手啰。 真正的爱需要投入和奉献,需要付出全部的智慧与力量。要使爱的对象得到成长,就必须付出足够多的努力,不然爱的愿望就会落空。 唯有真正的投入与奉献,才是实现爱的有效方式。真正的爱是自主的选择,无论「爱」的「感觉」是否存在, 都要奉献出情感和智慧。 「爱」的表现 倾听。我们真的能够拿出时间来,认真倾听对方的说话。最起码的尊重是通过倾听来展开的,我们要做一个良好的「倾听者」。 要有心里准备,接受爱的时候,就要准备承担风险。(有人经历过丧失亲人,之后就特别怕建立亲密关系。因为怕失去,「失去」的痛苦吓坏了他。)(爱还要面临冲突的风险。) 需要尊重对方的独立性。否则就是占有,就是依赖。 信仰 科学也是信仰 科学也是一种信仰。这个世界上上信科学的人比信宗教的人多。人不是生活在一个真实的世界当中的,人是生活在思想家为我们所设定的思想通道当中的。科学家在不断的拓宽我们人类的视线,建立了科学的信仰。 作者认为宗教的信仰在某种程度上可能会导致人的某些情况下的精神分裂。但是在某些情况下也会带来信念,帮助人们解决心理的问题。比喻:倒洗澡水的时候,千万不要把婴儿也倒出去。对待信仰的时候,不能过于简单化。 原罪 作者认为人类的「原罪」就是「懒惰」。 自律需要用力,爱需要用力,这个世界天然的方向是「熵增」,屋子一定会变乱。我花力气把屋子整理干净十个「逆熵」的过程,逆熵是需要话费气力的。 人天生喜欢熵增,喜欢懒惰。在伊甸园,其实上帝经常在园子里散步。这两孩子如果能去问一下,这玩意儿能吃吗?人类的命运就改变了。这两个人为什么不去问 一下上帝呢?因为这两孩子「懒惰」,而「懒惰」的背后是「恐惧」。他们担心问了上帝以后受到上帝的责罚。 (天涯:我认为这个解释不对。那个时候的亚当和夏娃没有罪恶感,也从来没有受过责罚,怎么会有这个恐惧呢?而恐惧则是被赶出伊甸园以后人类才有的心智。) 有人不好好学习,是因为就算好好学习了也未必学得好啊。如果好好学了而没有学好,就会面对失去「我不是没能力,只是不愿学而已」这块遮羞布的恐惧。 尽量要做到潜意识和意识「合一」。因为潜意识里面有很多的能量,而我们由于“懒惰”以及“恐惧”不愿意去开发的,不愿意去面对的。 这本书为什么叫【少有人走的路】呢?因为人人都喜欢熵增的方向,都喜欢轻松的方向,人人都喜欢懒惰的方向。喜欢部分什么劲,就得到一切的这种感觉。如果你想要变得成熟,就要费力去做一些逆熵的行为,自律的事,延迟满足的事,用行动表达「爱」的 过程。 两种力量 这个世界始终是由两种力量来统治的,分别是「政治的力量」和「心灵的力量」。 【政治的力量】:以公开或者隐秘的方式,去强迫别人遵循自己的意愿。这种力量既存在于权力之中,也存在于金钱之中。然而他并不属于拥有权力或者金钱的人。归根到底,政治的力量和德行以及智慧无关,最愚蠢最邪恶的人也可能成为地球的统治者。 【心灵的力量】:则完全存在于人类的心中,它和强迫、控制别人的力量没有关系。它是在意识基础上作出决定的力量。也就是「意识的力量」。 如果我们的心理能够得到力量,我们就会感到舒适和愉快,在人生的旅途上稳扎稳打,循序渐进。 进步带给我们的愉悦感难以言喻。没有什么比成为人生的专家,熟知自己所做的事情,更让人感觉到幸福。我们的心灵越是成熟,就越有可能成为人生的专家。当我们的心智成熟到一定的阶段,我们就会更加谦逊而快乐。","categories":[{"name":"读书笔记","slug":"读书笔记","permalink":"http://maiernte.github.io/wiki/categories/读书笔记/"}],"tags":[{"name":"成长","slug":"成长","permalink":"http://maiernte.github.io/wiki/tags/成长/"},{"name":"心理","slug":"心理","permalink":"http://maiernte.github.io/wiki/tags/心理/"}]}]} \ No newline at end of file diff --git a/docs/css/blog-encrypt.css b/docs/css/blog-encrypt.css index b7bb979..e69de29 100644 --- a/docs/css/blog-encrypt.css +++ b/docs/css/blog-encrypt.css @@ -1,72 +0,0 @@ -.hbe-input-container { - width: 80%; - max-width: 800px; - position: relative; - display: -webkit-box; - display: -ms-flexbox; - display: flex; - -webkit-box-orient: vertical; - -webkit-box-direction: reverse; - -ms-flex-flow: column-reverse; - flex-flow: column-reverse; - -webkit-box-align: start; - -ms-flex-align: start; - align-items: flex-start; - margin: 100px auto; -} -.hbe-input-container input { - -webkit-box-ordinal-group: 11; - order: 10; - -ms-flex-order: 10; - outline: none; - border: none; - width: 100%; - padding: 15px 0; - font-size: 20px; - border-bottom: 1px solid #d5d5d5; - text-indent: 10px; -} -.hbe-input-container input::-moz-placeholder { - opacity: 0; -} -.hbe-input-container input::-webkit-input-placeholder { - opacity: 0; -} -.hbe-input-container input:-ms-input-placeholder { - opacity: 0; -} -.hbe-input-container input, -.hbe-input-container label { - transition: all 0.3s; -} -.hbe-input-container label { - -webkit-box-ordinal-group: 101; - -ms-flex-order: 100; - font-size: 18px; - order: 100; - color: #3f4f5b; - -webkit-transform-origin: left bottom; - transform-origin: left bottom; - -webkit-transform: translate(10px, 40px); - transform: translate(0px, 40px); -} -.hbe-input-container .bottom-line { - order: 2; - width: 0; - height: 2px; - background: #658db5; - transition: all 0.3s; -} -.hbe-input-container input:focus { - border-bottom-color: #fff; -} -.hbe-input-container input:focus ~ div, -.hbe-input-container input:not(:placeholder-shown) ~ div { - width: 100%; -} -.hbe-input-container input:focus + label, -.hbe-input-container input:not(:placeholder-shown) + label { - color: #52616c; - -webkit-transform: translate(10px) scale(0.9); - transform: translate(10px) scale(0.9); -} diff --git a/docs/funny-sloga-collection.html b/docs/funny-sloga-collection.html index a2336eb..e69de29 100644 --- a/docs/funny-sloga-collection.html +++ b/docs/funny-sloga-collection.html @@ -1,556 +0,0 @@ - - - - - - 零散句子 | 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - -
    - - - - -
    -
    - - -
    - - - - - -

    - 零散句子 -

    - - -
    - - -
    - - - -
    - 文章目录 -
    1. 1. 幸福的路有两条
    2. 2. Matrix
    3. 3. 几个顺口溜
    -
    - - - -
    幸福的路有两条
    -

    中岛美雪写的歌《幸福》(任贤齐翻唱的伤心太平洋):到幸福的路有两条,一条是所有愿望都成真,另外一条是把愿望这东西扔掉。

    - -
    Matrix
    -
    -

    Cypher: You know, I know this steak doesn’t exist. I know that when I put it in my mounth, the Matrix is telling my brain that it is … juicy and delicious. After nine years, you know what I realize? en … Ignorance is bliss

    -
    -
    几个顺口溜
    -
      -
    • 认认真真说假话,扎扎实实走过场。
    • -
    • 失败乃成功之母——失败生了100个孩子,其中一个叫「成功」,其它99个还叫「失败」。
    • -
    • “人类一思考,上帝就发笑。” —— “你一说要学什么东西,人们就发笑。”
    • -
    • 晚上想想千条路,早上起来走原路。(有个共同特点:不困难、不痛苦)
    • -
    • 暂时的失败要比暂时的成功要好得多。
    • -
    • 别让「半途而废」 成为你唯一坚持下来的事情。
    • -
    • 世上没有听一遍就管用的道理。
    • -
    • (你的脑袋)不要做别人思想的跑马场。
    • -
    • 路是自己走的,脚上的泡也是自己好的。
    • -
    • 忍一时越想越气,退一步越想越亏。(总是忍的人,从来都不开心。总是退让的人,却从来没有真的海阔天空)
    • -
    • 遇到烂事不纠结,遇到烂人不纠缠。
    • -
    • 每个人都想努力做,却总是做不好。
    • -
    • 曹操评袁绍:「色厉胆薄,好谋无断,干大事而惜身,见小利而忘命。」
    • -
    - -
    - -
    -
    -
    -
    - - - - - - - - - - - -
    -
    - -
    -
    - - - - - - - -
    -
    -
    -
    - -
    -
    - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - - - \ No newline at end of file diff --git a/docs/funny-things-collection.html b/docs/funny-things-collection.html index 949d6f8..e69de29 100644 --- a/docs/funny-things-collection.html +++ b/docs/funny-things-collection.html @@ -1,557 +0,0 @@ - - - - - - 缠中说禅 | 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - -
    - - - - -
    -
    - - -
    - - - - - -

    - 缠中说禅 -

    - - -
    - - -
    - - - -
    - 文章目录 -
    1. 1. 诗词
      1. 1.1. 满江红
      2. 1.2. 临江仙
      3. 1.3. 卜算子
    -
    - - - -

    [TOC]

    -
    诗词
    -
    满江红
    -

    万古长空,今犹昔,一朝风月。何处住?
    -春花夏雨,秋鸿冬雪。
    -百代浮华皆作土,千江吸尽无堪说。
    -问世间,多少梦消磨、英雄血。
    -星旋轨,天补裂,山崩柱,河倾缺。
    -捣神宫鬼府,凤巢龙穴。
    -怒剑穿云惊浩宇,狂涛卷日横孤筏。
    -纵生死,劫火洗乾坤,齐欢悦。

    -
    临江仙
    -

    浊水倾波三万里,愀然独坐孤峰。
    -龙潜狮睡侯飙风。
    -无情皆竖子,有泪亦英雄。
    -长剑倚天星斗烂,古今过眼成空。
    -乾坤俯仰任穷痛。
    -半轮沧海上,一苇大江东。

    -
    卜算子
    -

    本是后山人,偶做堂前客。
    -醉舞经阁半卷书,坐井说天阔。
    -大志戏功名,海斗量祸福。
    -论到囊中羞涩时,怒指乾坤错。

    -

    —— 丁元英

    - -
    - -
    -
    -
    -
    - - - - - - - - - - - -
    -
    - -
    -
    - - - - - - - -
    -
    -
    -
    - -
    -
    - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - - - \ No newline at end of file diff --git a/docs/gitbook_with_typora_gh-pages.html b/docs/gitbook_with_typora_gh-pages.html index c08eaec..e69de29 100644 --- a/docs/gitbook_with_typora_gh-pages.html +++ b/docs/gitbook_with_typora_gh-pages.html @@ -1,621 +0,0 @@ - - - - - - Gitbook攻略 | 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - -
    - - - - -
    -
    - - -
    - - - - - -

    - Gitbook攻略 -

    - - -
    - - -
    - - - -
    - 文章目录 -
    1. 1. 安装
    2. 2. 新建书籍
    3. 3. 发布到Github Pages
      1. 3.1. 更新和维护
    4. 4. 个性化配置
      1. 4.1. 数学插件
      2. 4.2. 目录插件
    5. 5. 编译错误列表
      1. 5.1. sharing 插件出错
        1. 5.1.1. 解决方法
    -
    - - - -

    本文为你介绍如何使用利用 Typora + gitbook-cli + Github Pages 书写Gitbook. 在本地用 Typora 书写 md 文件, 用 gitbook-cli 编译, 最后发布到 Github Pages 上.

    - -

    安装

    -

    前提是已经安装了Node, 直接用npm包管理工具安装:

    -
    1
    2
    sudo npm install -g gitbook-cli
    gitbook -V # 注意是大写V
    -
    -

    CLI version: 2.3.2
    -GitBook version: 3.2.3

    -
    -

    新建书籍

    -
      -
    1. -

      为新书建立一个根目录 mkdir pytho_finance

      -
    2. -
    3. -

      在该目录下执行(命令行下):gitbook init,之后会在该目录下产生2个文件,分别是README.md(书籍的介绍)和SUMMARY.md(书籍的目录结构)。

      -
    4. -
    -

    gitbook目录的写法

    -
      -
    1. -

      按照上图格式填写目录和文件, 然后再次执行 gitbook init , GitBook 会查找 SUMMARY.md 文件中描述的目录和文件,如果没有则会将其创建.

      -
    2. -
    3. -

      然后就可以预览书籍了 gitbook serve. 执行命令后会对 Markdown 格式的文档进行转换,默认转换为 html 格式,提示Serving book on http://localhost:4000,打开网址即可查看.

      -
    4. -
    5. -

      构建书籍

      -
    6. -
    -
    1
    gitbook build
    -

    默认将生成的静态网站输出到 _book 目录。实际上,这一步也包含在 gitbook serve 里面,因为它们是 HTML,所以 GitBook 通过 Node.js 给你提供服务了。

    -

    build 命令可以指定路径, 或者指定端口, 或者生产 pdf , epub, mobi 等格式. 具体参考文章.

    -

    发布到Github Pages

    -
    1
    2
    3
    4
    5
    git init
    git remote add origin https://github.com/maiernte/gitbook_python_finance.git
    git add .
    git commit -m "new book"
    git push -u origin master # 将源代码推送到master
    -

    在GitHub的仓库中新添一个 gh-pages 的Branch.

    -
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    mkdir new_fold
    cd new_fold
    rm -rf . # 删除这个目录下所有文件, 注意那 .git 文件夹不能删除

    # 在源代码目录中,也就是md文件的目录
    gitbook build

    # 将会产生一个 _book 目录
    # 添加忽略, 以免下次推送的时候 _book 目录被推送.
    echo "*~" > .gitignore
    echo "_book" >> .gitignore
    echo "/node_modules" >> .gitignore

    cp -r _book/* path_to/new_fold
    -

    :pen: 忽略文件夹,windows下的测试是 /node_modules, 不加双引号。

    -

    进入新目录, 推送编译后的html 和 js 文件到 gh-pages 的分支中去.

    -
    1
    2
    3
    4
    cd path_to/new_fold
    git add .
    git commit -m "to gh-pages"
    git push -u origin gh-pages
    -

    如此实现了将源代码保存到master, 将静态网站推送到gh-pages, 一个仓库搞定! 在浏览器输入仓库地址, 就可以看到自己的Gitbook. 比如我新书地址

    -
    -

    https://maiernte.github.io/gitbook_python_finance/

    -
    -

    更新和维护

    -

    因为master 和 gh-pages 上存放的是不同的文档,所以拉取的时候也有指定 branch

    -
    1
    2
    3
    4
    5
    # 拉取源代码
    git clone https://github.com/maiernte/gitbook_python_finance.git --branch master new_fold

    # 拉取静态网站
    git clone https://github.com/maiernte/gitbook_python_finance.git --branch gh-pages new_fold
    -

    个性化配置

    -

    在项目的根目录上添加一个 book.json 文件, 用来更全面的配置项目. 比如头文件, 插件等等.

    -
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    {
    "title": "使用Python处理金融数据",
    "author": "鎏金天涯 <mai.yongfeng@gmail.com>",
    "description": "使用Python处理金融数据的各种技术",
    "generator": "site",
    "plugins": ["mathjax"],
    "links": {
    "sidebar": {
    "鎏金天涯个人博客": "http://goldentianya.pub"
    }
    }
    }
    -

    数学插件

    -

    在上述文件添加了 "plugins": ["mathjax"], 并执行命令

    -
    1
    gitbook install ./ # 会添加一堆 node_modules 包
    -

    更详细的配置请参阅官方文档.

    -

    目录插件

    -

    项目地址和文档

    -

    book.json 文件修改为 "plugins": ["mathjax", "page-toc" ], ​ 每一页的目录就会出现在右上角。

    -

    编译错误列表

    -

    版本

    -
    1
    2
    CLI version: 2.3.2
    GitBook version: 3.2.3
    -

    sharing 插件出错

    -

    添加了 page-toc 插件后,gitbook serve 的时候总是出现错误。就算把文章改回原来的样子也无补于事。

    -
    -

    info: 7 plugins are installed
    -info: loading plugin “livereload”… OK
    -info: loading plugin “highlight”… OK
    -info: loading plugin “search”… OK
    -info: loading plugin “lunr”… OK
    -info: loading plugin “sharing”… OK
    -info: loading plugin “fontsettings”… OK
    -info: loading plugin “theme-default”… OK
    -info: found 1 pages
    -info: found 0 asset files

    -

    Error: ENOENT: no such file or directory, stat ‘D:\f040371\git_book\plattform_finance_book\gitbook\gitbook-plugin-sharing\buttons.js’

    -
    -

    解决方法

    -

    修改 C:\Users\f040371\.gitbook\versions\3.2.3\lib\output\website\copyPluginAssets.js 文件中的 112 行

    -

    copyPluginAssets.js

    -

    confirm: true 改为 confirm: false

    -

    参考文章:

    -
    -

    使用GitBook和Typora写知识库

    -

    gitbook+git+typora 的使用过程

    -

    GitBook + Typora + Git 编写电子文档

    -

    Gitbook 发布到 Github Pages

    - -
    - -
    -
    -
    -
    - - - - - - - - - - - -
    -
    - -
    -
    - - - - - - - -
    -
    -
    -
    - -
    -
    - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - - - \ No newline at end of file diff --git a/docs/hellow-world.html b/docs/hellow-world.html index 9d8af01..e69de29 100644 --- a/docs/hellow-world.html +++ b/docs/hellow-world.html @@ -1,536 +0,0 @@ - - - - - - Hello World | 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - -
    - - - - -
    -
    - - -
    - - - - - -

    - Hello World -

    - - -
    - - -
    - - - - - - -
    -
    - - -
    -
    -
    - - - - -
    - -
    -
    -
    -
    - - - - - - - - - - - -
    -
    - -
    -
    - - - - - - - -
    -
    -
    -
    - -
    -
    - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - - - \ No newline at end of file diff --git a/docs/helpfull-shell-command.html b/docs/helpfull-shell-command.html index 1b1a971..e69de29 100644 --- a/docs/helpfull-shell-command.html +++ b/docs/helpfull-shell-command.html @@ -1,688 +0,0 @@ - - - - - - 有用的Shell命令 | 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - -
    - - - - -
    -
    - - -
    - - - - - -

    - 有用的Shell命令 -

    - - -
    - - -
    - - - -
    - 文章目录 -
    1. 1. 文件&内容检索
      1. 1.1. 正则表达式注意的地方
      2. 1.2. grep
      3. 1.3. sed 命令
        1. 1.3.1. 文本替代
        2. 1.3.2. 整行替代
      4. 1.4. find
      5. 1.5. 查找最新文件
    2. 2. 字符串处理
      1. 2.1. 数组转字符串
      2. 2.2. 字符串转数组
      3. 2.3. 字符串替换
        1. 2.3.1. 消除回车符、换行符、制表符
      4. 2.4. 详细用法
      5. 2.5. basename和dirname
    3. 3. 查看硬盘剩余空间
      1. 3.1. 查看 package 版本
    4. 4. Windwos 下的脚本
    -
    - - - -

    在线网站可以找到基本的东西:Linux命令大全 shell 正则表达式

    -

    文件&内容检索

    -

    正则表达式注意的地方

    -
      -
    • 花括号之前要加转义字符 [a-z]\{3\}
    • -
    • 空格就是转义加空格\ ,而不是\s 。如 [a-z0-9_\ ]\{3,\}
    • -
    • 这几个符号 _ - . #都不需要加转义符。
    • -
    • 不要轻易加==行结束符==$,可能回车才是最后符号,所以可能找不到。
    • -
    - -

    grep

    -
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    # -r 递归搜索子目录
    # -l 只显示文件
    # -n 显示文件和匹配的行
    # 搜索 “markdown” 字符串并输入到文件里
    # Formating the Results...
    grep $begrif $directory $args |awk '{ print "[" $1 "](" $1 ")\n" }' > suchergebnisse.md
    # 将结果转为Windows目录
    sed -i -- 's/\/D\//D:\/\//g' suchergebnisse.md
    echo "Fertig! Ergebnisse siehe Datei 'suchergebnisse.md'"
    read
    -

    更多参数请读此文 示例脚本

    -

    grep 正则表达式的例子

    -
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    #!bin/bash
    # {#part0000_split_050.html#nav_point-99 .calibre13}
    result=$(grep '{#part0000_split_[0-9]\{3\}.html[a-z0-9_\ -.#]\{3,\}calibre13}' 文件名)

    if [ "$result" = "" ];
    then
    echo "Nichts gefunden!"
    fi

    echo $result
    read
    -

    grep或操作

    -
    1
    2
    3
    grep -E '123|abc' filename  // 找出文件(filename)中包含123或者包含abc的行
    egrep '123|abc' filename // 用egrep同样可以实现
    awk '/123|abc/' filename // awk 的实现方式
    -

    grep与操作

    -
    1
    grep pattern1 files | grep pattern2 //显示既匹配 pattern1 又匹配 pattern2 的行。
    -

    其它常用选项

    -
    1
    2
    3
    4
    5
    grep -i pattern files   //不区分大小写地搜索。默认情况区分大小写,
    grep -l pattern files //只列出匹配的文件名,
    grep -L pattern files //列出不匹配的文件名,
    grep -w pattern files //只匹配整个单词,而不是字符串的一部分(如匹配‘magic’,而不是‘magical’),
    grep -C number pattern files //匹配的上下文分别显示[number]行,
    -
    点击显/隐代码
    - -
    -

    sed 命令

    -

    参考文献

    -

    文本替代

    -

    以下文本替换通过pandoc导入后的文件,残留很多内部跳转链接:如

    -
    1
    {#part0000_split_003.html#nav_point_1 .not-in-toc}
    -
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    #!bin/bash
    echo running
    #sed 's/^#part0000_split_$/p' -f ../Linux_shell_Anleitung.md ;
    sed -i -- 's/^\[\]{#part0000_split_[0-9]\{3\}.html}$//g' ../Linux_shell_Anleitung.md

    #{#part0000_split_017.html#nav_point_21 .calibre8} {#part0000_split_003.html#nav_point_1 .not-in-toc}
    sed -i -- 's/{#part0000_split_[0-9]\{3\}.html#[a-z0-9_-]\+ .[a-z0-9_-]\+}//g' ../Linux_shell_Anleitung.md

    echo fertig!
    read
    -

    整行替代

    -

    参考文献

    -

    替代以 categories: 开头的整行(允许行开头有空格或制表符)。c 代表整行,以字符串 categories: [IE] 替代整行。

    -
    1
    2
    3
    4
    # Linux 下的写法
    sed -i -- '/^[[:blank:]]*categories:/c categories: [IE]' result.txt
    # Mac 下的写法
    sed -i '' 's/^[[:blank:]]*tags:.*/tags: [心理]/' $1
    -

    错误:如果将参数 c 写在前面,会将整个文本每一行都替换掉。

    -
    1
    2
    # Linux 下的写法
    sed -i -- 'c/^[[:blank:]]*categories:/categories: [IE]/' result.txt
    -

    find

    -
    1
    2
    3
    4
    # 查找所有的 md 文件
    find /root/bibliothek/markdowns/blog_posts/ -type f -name "*.md"
    # 查找一天之前的文件, 一小时前时 -1h,一周 -1w
    find . -type f -mtime -1d
    -

    如果要处理复杂的事情,就要用到函数

    -
    1
    2
    3
    4
    5
    6
    7
    8
    9
    # 定义函数
    showFileInfo(){
    echo $1
    }

    # 声明函数
    export -f showFileInfo
    # 使用函数
    find $dirPath -name "*.md" | xargs -n 1 -P 10 -I {} bash -c 'showFileInfo "$@"' _ {} \;
    -

    查找最新文件

    -
      -
    • -

      将文件按从新到旧排列,取第一个。

      -

      ls -t *.cpp | head -1

      -
    • -
    • -

      将文件按从旧到新排列,取最后一个。

      -

      ls -rt *.cpp | tail -1

      -
    • -
    • -

      列出文件时间戳

      -

      ls -l simpleNode.js |awk '{print $6 "-" $7 "-" $8 }'

      -
    • -
    • -

      整合以上两个命令,找到最新的文件,读取时间戳

      -

      ls -t *.* | head -1 | xargs ls -l | awk '{print $6 "-" $7 "-" $8 }'

      -
    • -
    -

    字符串处理

    -

    字符串处理参考文献 将分隔符的字符串转为数组的几种方法

    -

    配合使用,可以直接用 shell 实现文件内标签和分类的替换。

    -

    数组转字符串

    -

    使用分隔符将数组转字符串:

    -
    1
    2
    3
    4
    ids=(1 2 3 4); 
    lst=$( IFS='/'; echo "${ids[*]}" );
    echo $lst
    # 结果是:1/2/3/4
    -

    字符串转数组

    -

    懒得写,看范例

    -

    字符串替换

    -
    1
    2
    3
    4
    5
    # 原串 [娱乐,经济,重要] => 目标串 [娱乐, 经济, 重要]
    ${tags/,/, } # 只替换了一个,结果变成 [娱乐, 经济,重要]
    ${tags//,/, } # 替换了所有符合的,结果变成 [娱乐, 经济, 重要]
    # 原串 [重要] => 目标串 重要
    ${tags//[\[\] ]/}
    -

    消除回车符、换行符、制表符

    -
    1
    2
    3
    # arg是个字符串变量, 可能带有回车符\r
    # 把它整个作为参数使用会带来很多麻烦。用以下命令将其替换掉
    newvar=${arg//[$'\t\r\n']/}
    -

    详细用法

    -

    参考文献

    -
      -
    1. ${var##*/}
      -该命令的作用是去掉变量var从左边算起的最后一个’/‘字符及其左边的内容,返回从左边算起的最后一个’/’(不含该字符)的右边的内容。使用例子及结果如下:
    2. -
    -
    1
    2
    var=dir1/dir2/file.txt 
    --> file.txt
    -

    从运行结果可以看到,使用该命令,可以提取出我们需要的文件名file.txt

    -

    若使用时在shell程序文件中,可以使用变量来保存这个结果,再加以利用,如file=${var##*/}

    -
      -
    1. ${var##*.}
      -该命令的作用是去掉变量var从左边算起的最后一个’.‘字符及其左边的内容,返回从左边算起的最后一个’.’(不含该字符)的右边的内容。使用例子及结果如下:
    2. -
    -
    1
    2
    var=dir1/dir2/file.txt 
    --> txt
    -

    从运行结果可以看到,使用该命令,可以提取出我们需要的文件后缀。

    -

    如果文件的后缀不仅有一个,例如,file.tar.gz,命令${var##*.}仅能提取最后一个后缀,而我想提取tar.gz时该怎么办?那么就要用下面所说的${var#*.}命令了。

    -
      -
    1. ${var#*.}
      -该命令的作用是去掉变量var从左边算起的第一个’.‘字符及其左边的内容,返回从左边算起第一个’.’(不含该字符)的右边部分的内容。使用例子及结果如下:
    2. -
    -
    1
    2
    var=dir1/dir2/file.tar.gz 
    --> tar.gz
    -

    从运行结果可以看到,使用该命令,可以提取出文件的多个后缀。

    -
      -
    1. ${var%/*}
      -该命令的使用是去掉变量var从右边算起的第一个’/‘字符及其右边的内容,返回从右边算起的第一个’/’(不含该字符)的左边的内容。使用例子及结果如下:
    2. -
    -
    1
    2
    var=dir1/dir2/file.txt 
    --> dir1/dir2
    -

    从运行的结果可以看到,使用该命令,可以提取出我们需要的文件所在的目录

    -
      -
    1. ${var%%.*}
      -该命令的使用是去掉变量var从右边算起的最后一个’.‘字符及其右边的内容,返回从右边算起的最后一个’.’(不含该字符)的左边的内容。使用例子及结果如下:
    2. -
    -
    1
    2
    var=dir1/dir2/file.txt 
    --> dir1/dir2/file
    -

    当我们需要建立一个与文件名相同名字(没有后缀)的目录与对应的文件相对应时,就可以使用该命令来进行操作。例如,解压文件的情况就与此类似,我们压缩文件file.zip时,会在与file.zip同级目录下建立一个名为file的目录。

    -
      -
    1. 总结
    2. -
    -

    其实${}并不是专门为提取文件名或目录名的,它的使用是变量的提取和替换等等操作,它可以提取非常多的内容,并不一定是上面五个例子中的’/‘或’.’。也就是说,上面的使用方法只是它使用的一个特例。

    -

    看到上面的这些命令,可能会让人感到非常难以理解和记忆,其实不然,它们都是有规律的。

    -
      -
    • -

      #:表示从左边算起第一个

      -
    • -
    • -

      %:表示从右边算起第一个

      -
    • -
    • -

      ##:表示从左边算起最后一个

      -
    • -
    • -

      %%:表示从右边算起最后一个

      -
    • -
    -

    换句话来说,#总是表示左边算起,%总是表示右边算起。

    -

    *:表示要删除的内容,对于#和##的情况,它位于指定的字符(例子中的’/‘和’.’)的左边,表于删除指定字符及其左边的内容;对于%和%%的情况,它位于指定的字符(例子中的’/‘和’.’)的右边,表示删除指定字符及其右边的内容。这里的’'的位置不能互换,即不能把号放在#或##的右边,反之亦然。

    -

    例如:${var%%x*}表示找出从右边算起最后一个字符x,并删除字符x及其右边的字符。

    -

    看到这里,就可以知道,其实该命令的用途非常广泛,上面只是指针文件名和目录名的命名特性来进行提取的一些特例而已。

    -

    basename和dirname

    -

    ${}并不是专门为提取文件名和目录名设计的命令,那么basenamedirname命令就是专门为做这一件事而已准备的了。

    -
      -
    1. basename
      -该命令的作用是从路径中提取出文件名,使用方法为basename NAME [SUFFIX]。
    2. -
    -

    1.1 从路径中提出出文件名(带后缀),例子如下:

    -

    1.2 从上面命令的用法中可以看到,后缀(SUFFIX)是一个可选项。所以,若只想提取出文件名file,而不带有后缀,还可以在变量的后面加上后缀名,例子如下:

    -
      -
    1. dirname
      -该命令的作用是从路径中提取出目录名,使用方法为 dirname NAME。使用例子如下:
    2. -
    -

    这样就提取出了file.txt文件所在的目录。

    -

    注:该命令不仅能提取出普通文件所的目录,它能提取出任何文件所在的目录,例如目录所在的目录,如下:

    -

    它提取出了目录dir2所在的目录dir1.

    -
    -

    查看硬盘剩余空间

    -
    1
    2
    3
    4
    5
    # 整个硬盘空间
    df -hl
    # 查看某个文件夹大小
    du -h your_directory # 列出每个子文件夹大小
    du -hcs your_directory # 汇总
    -

    查看 package 版本

    -
    1
    apt-cache show packagename
    -

    Windwos 下的脚本

    -

    windows 下显示环境变量

    -

    echo %http_proxy%

    -

    windows 下设置代理服务器
    -$$

    -

    $$

    -
    1
    2
    set http_proxy=http://username:pwd$$$@proxy-rzf:8080
    set https_proxy=http://username:pwd$$$@proxy-rzf:8080
    - -
    - -
    -
    -
    -
    - - - - - - - - - - - -
    -
    - -
    -
    - - - - - - - -
    -
    -
    -
    - -
    -
    - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - - - \ No newline at end of file diff --git a/docs/hexo-blog-alltag-verwalten.html b/docs/hexo-blog-alltag-verwalten.html index ed78291..e69de29 100644 --- a/docs/hexo-blog-alltag-verwalten.html +++ b/docs/hexo-blog-alltag-verwalten.html @@ -1,545 +0,0 @@ - - - - - - Hexo日常管理 | 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - -
    - - - - -
    -
    - - -
    - - - - - -

    - Hexo日常管理 -

    - - -
    - - -
    - - - -
    - 文章目录 -
    1. 1. 复制MD文件
      1. 1.0.0.1. 查找最新文件
  • 2. 其它
  • 3. 参考文件
  • 4. 会导致编译奔溃的错误
  • -
    - - - -

    复制MD文件

    - -

    查找最新文件

    -
    1
    2
    3
    4
    ls -t /Users/mai/Projects/hexo/source/_posts/*.md | head -1 | xargs ls -l | awk '{print  $6 "-" $7 "-" $8 }'

    # 最旧的文件就应该是
    ls -t /Users/mai/Projects/hexo/source/_posts/*.md | tail -1 | xargs ls -l | awk '{print $6 "-" $7 "-" $8 }'
    -

    其它

    -

    Hexo 代码折叠

    -
    1
    2
    3
    {% fold 点击显/隐内容 %}
    需要隐藏的内容。。。
    {% endfold %}
    -

    参考文件

    -

    有用的shell命令

    -

    会导致编译奔溃的错误

    -

    大括号和井号连在一起

    -
    1
    2
    3
    {#、 #}、{#} 这三种情况都会导致系统奔溃
    {} 和 # 之间如果有别的字符就不会。如 { # }
    或者放在代码段内也不会。行内代码不能避免这种情形。
    - -
    - -
    -
    -
    -
    - - - - - - - - - - - -
    -
    - -
    -
    - - - - - - - -
    -
    -
    -
    - -
    -
    - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - - - \ No newline at end of file diff --git a/docs/hexo-onlineeditor.html b/docs/hexo-onlineeditor.html new file mode 100644 index 0000000..e69de29 diff --git a/docs/how-build-my-hexo-blog.html b/docs/how-build-my-hexo-blog.html index 25afedb..e69de29 100644 --- a/docs/how-build-my-hexo-blog.html +++ b/docs/how-build-my-hexo-blog.html @@ -1,899 +0,0 @@ - - - - - - 搭建Hexo博客的流水账 | 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - -
    - - - - -
    -
    - - -
    - - - - - -

    - 搭建Hexo博客的流水账 -

    - - -
    - - -
    - - - -
    - 文章目录 -
    1. 1. 建立网站
      1. 1.1. Github配置
      2. 1.2. 安装Hexo
      3. 1.3. 发布到Github
      4. 1.4. 网站基本配置
        1. 1.4.1. Next 主题
        2. 1.4.2. Wikitten主题
        3. 1.4.3. 同时部署两个项目
        4. 1.4.4. 站内搜索
        5. 1.4.5. 去除主题字样
      5. 1.5. 添加评论功能
        1. 1.5.0.1. Gitment
        2. 1.5.0.2. Disqus
    2. 1.6. 新文章命名规则
  • 2. 进阶设置
    1. 2.1. 显示
      1. 2.1.1. 首页文章显示预览
      2. 2.1.2. 永久链接
      3. 2.1.3. 图片链接
      4. 2.1.4. 站内链接
      5. 2.1.5. 设定代码区的高度
      6. 2.1.6. 添加注脚支持
      7. 2.1.7. 更换Markdown渲染
    2. 2.2. 辅助功能
      1. 2.2.1. 本地运行服务
      2. 2.2.2. 绑定个人域名
      3. 2.2.3. 隐藏文章
        1. 2.2.3.1. 全隐藏
        2. 2.2.3.2. 从首页隐藏
        3. 2.2.3.3. 文章加密
      4. 2.2.4. Hexo Admin
      5. 2.2.5. 访问量统计
      6. 2.2.6. 在线交流
      7. 2.2.7. 待解决问题
  • 3. 有趣插件
    1. 3.0.1.
  • -
    - - - -

    建立网站

    -

    Github配置

    -

    输入命令 ssh-keygen -t rsa -b 4096 -C "myname@gmail.com"

    -

    密码 T1。(下列展开后复制)

    -
    -

    将文件 ~/.ssh/id_rsa.pub 中的内容复制到 Github 的SSH-Key 内就可以了。(备份文件已上传百度网盘)

    -
    -
      -
    1. 在Github上新建SSH-Key名称为gmail
    2. -
    -

    具体步骤参阅此文章

    -
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    ssh-keygen -t rsa -b 4096 -C "username@gmail.com"
    [Enter]
    [password T..1]

    eval "$(ssh-agent -s)"
    ssh-add -K ~/.ssh/id_rsa

    cd ~
    cd .ssh
    ls
    vim id_rsa.pub
    (然后复制钥匙串)
    -
      -
    1. 测试公匙
    2. -
    -
    1
    2
    3
    $ ssh -T git@github.com

    Hi username! You've successfully authenticated, but GitHub does not provide shell access.
    -

    安装Hexo

    -

    参考资料1 7

    -
      -
    1. 安装node.js 因为以前已经安装过,所以跳过。
    2. -
    3. 安装 Hexo $ npm install hexo-cli -g
    4. -
    5. 创建网站
    6. -
    -
    1
    2
    3
    4
    mkdir mywiki
    cd mywiki
    hexo init
    npm install
    -
      -
    1. 生成静态页面 hexo g or hexo generate
    2. -
    3. 启动本地网站服务 hexo s or hexo server
    4. -
    -
    -

    网站一般会运行在 http://localhost:4000/
    -Press Ctrl+C to stop.

    -
    -
      -
    1. 用pow做服务本地运行
    2. -
    -

    Install

    -
    1
    $ curl get.pow.cx | sh
    -

    Setup

    -

    Symlink the folder into ~/.pow

    -
    1
    2
    $ cd ~/.pow
    $ ln -s /path/to/test
    -

    发布到Github

    -

    终于搭建好站点部署环境啦,那么要怎么样将我们本地生成预览好的页面发布到github上呢?很简单,Follow!

    -

    首先,打开blog目录下的_config.yml,找到deploy段,配置成这样

    -
    -

    deploy:
    -type: git
    -repository: git@github.com:yourname/yourname.github.io.git
    -branch: master

    -
    -

    注意将代码里面的yourname换成你账号的username。

    -

    设置git身份信息

    -
    -

    git config --global user.name “你的用户名”
    -git config --global user.email “你的邮箱”

    -
    -

    执行以下指令进行部署

    -

    hexo d -g

    -

    如果提示没找到git,请先执行以下指令

    -

    cnpm install hexo-deployer-git --save

    -

    再次部署后,浏览器打开 https://yourname.github.io 就可以看到刚才本地预览页面。

    -

    网站基本配置

    -

    Next 主题

    -

    主题配置文件说明

    -
    点击显/隐内容
    -
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    # Hexo 站点配置文件
    ## Docs: https://hexo.io/docs/configuration.html
    ## Source: https://github.com/hexojs/hexo/

    # 网站配置
    title: Hexo # 网站标题
    subtitle: # 网站副标题
    description: # 网站描述
    author: John Doe # 你的昵称
    language: # 网站使用的语言(英文:en, 简体中文:zh-Hans,繁体中文:zh-tw)
    timezone: # 网站时区,用于生成页面时填充相关时间,默认使用电脑时区,一般不用改

    # URL
    ## 如果你的站点要放入子目录, 请将url设置为'http://yoursite.com/child' 并将根目录设置为'/child/'
    url: http://yoursite.com # 站点网址
    root: / # 网站根目录
    permalink: :year/:month/:day/:title/ #文单的永久链接格式
    permalink_defaults: # 永久链接中各部分的默认值

    # 目录
    source_dir: source # 资源文件夹,这个文件夹用来存放博客内容
    public_dir: public # 公共文件夹,这个文件夹用来存放生成的站点静态文件
    tag_dir: tags # 标签文件夹
    archive_dir: archives # 归档文件夹
    category_dir: categories # 分类文件夹
    code_dir: downloads/code # Include code文件夹
    i18n_dir: :lang # 国际化文件夹,存放各种语言定义
    skip_render: # 跳过指定文件的渲染

    # 写作
    new_post_name: :title.md # 新文章的文件名称
    default_layout: post # 预设布局
    titlecase: false # 把标题转换为 title case
    external_link: true # 在新标签中打开链接
    filename_case: 0 # 把文件名称转换为 (1) 小写或 (2) 大写
    render_drafts: false # 显示草稿
    post_asset_folder: false # 启动 Asset 文件夹
    relative_link: false # 把链接改为与根目录的相对位址
    future: true # 显示未来的文章
    highlight: # 代码块的设置
    enable: true
    line_number: true
    auto_detect: false
    tab_replace:

    # 分类 & 标签
    default_category: uncategorized # 默认分类
    category_map: # 分类别名
    tag_map: # 标签别名

    # 日期 / 时间格式
    ## Hexo 使用 Moment.js 来解析和显示时间
    ## http://momentjs.com/docs/#/displaying/format/
    date_format: YYYY-MM-DD # 日期格式
    time_format: HH:mm:ss # 时间格式

    # 分页
    ## 每页显示的文章量 (0 = 关闭分页功能)
    per_page: 10
    pagination_dir: page

    # 扩展
    ## Plugins: https://hexo.io/plugins/
    ## Themes: https://hexo.io/themes/
    theme: landscape # 主题

    # 部署
    ## Docs: https://hexo.io/docs/deployment.html
    deploy:
    type:
    - -
    -

    Wikitten主题

    -

    具体配置参考开发者说明,更详细的描述参阅hexo-theme-icarus。为了与主题Next不冲突,作以下修改。

    -
      -
    1. 自行修改 tags, about,categoriesindex.md,而不能从主题复制,覆盖站点原有设置。
    2. -
    3. languages\zh-CN.yml 重命名为 zh-Hans.yml
    4. -
    5. _config.yml 菜单作以下更改
    6. -
    -
    1
    2
    3
    4
    5
    6
    menu:
    首页: /
    归档: /archives/
    分类: /categories/
    标签: /tags/
    关于: /about/
    -
      -
    1. thumbnail: true 使得每个post在快速列表里,显示图标。但就是每个帖子都要设定,很麻烦。
    2. -
    3. post 中的 toc 要设置为 true,如果需要显示目录的话。
    4. -
    -

    同时部署两个项目

    -

    第一个项目使用 Github 上面默认的 Github Pages,即 username.github.io 。在站点配置文件中如下:

    -
    1
    2
    3
    4
    5
    6
    7
    8
    url: http://username.github.io
    root: /
    ...
    ...
    deploy:
    type: git
    repository: git@github.com:username/username.github.io.git
    branch: master
    -

    第二个站点开通一个 普通的repository,添加名为gh-pages 的Branch,并将gh-pages设为默认Branch。我将第二个仓库命名为 wiki ,那第二个站点就运行在https://username.github.io/wiki`次级目录下面。

    -

    站点配置文件更改如下:

    -
    1
    2
    3
    4
    5
    6
    7
    8
    url: http://username.github.io/wiki
    root: /wiki/
    ...
    ...
    deploy:
    type: git
    repository: git@github.com:username/wiki.git
    branch: gh-pages
    -

    同样用 hexo d -g 部署命令发布,两个站点就都运行起来了。

    -

    为了使得两个项目使用同一个笔记资源,将站点中的 source 文件夹移到项目意外,将配置文件里的 source_dir: source 改为 source_dir: ../source(这里使用了相对目录)。

    -

    参考文章 (细节已经失效,但思路值得参考)

    -

    站内搜索

    -
      -
    1. 安装插件
    2. -
    -
    1
    2
    npm install hexo-generator-search --save
    npm install hexo-generator-searchdb --save
    -
      -
    1. 配置hexo站点主配置文件_config.yml, 添加
    2. -
    -
    1
    2
    3
    4
    5
    search:
    path: search.xml
    field: post
    format: html
    limit: 10000
    -
      -
    1. 修改next主题配置文件_config.yml,启用 local_search
    2. -
    -
    1
    2
    3
    4
    local_search:
    enable: true
    trigger: auto
    top_n_per_article: 1
    -
      -
    1. 生成search.xml文件以及发布
    2. -
    -
    1
    2
    hexo g
    hexo d -g # 本地运行 hexo s
    -

    去除主题字样

    -

    关于添加头像、标签、分类、「关于」等具体的修改,跟着参考资料2里面的步骤做就好了。最后说说如何去掉底部强力驱动及主题字样。

    -
      -
    1. 找到 \themes\next\layout_partials\下面的footer.swig文件,打开:
    2. -
    -
    1
    2
    3
    4
    5
    6
    7
    8
    9
    <div class="powered-by">
    {{ __('footer.powered', '<a class="theme-link" href="https://hexo.io">Hexo</a>') }}
    </div>
    <div class="theme-info">
    {{ __('footer.theme') }} -
    <a class="theme-link" href="https://github.com/iissnan/hexo-theme-next">
    NexT.{{ theme.scheme }}
    </a>
    </div>
    -

    第一条是“由Hexo驱动” 的Hexo链接,把xml段删除,只留两个单引号’’。

    -

    第二条是“主题-Next.XX”,将xml段都删掉,不留引号。

    -
    1
    2
    3
    4
    5
    6
    <div class="powered-by">
    {{ __('footer.powered', '') }}
    </div>
    <div class="theme-info">
    {{ __('footer.theme') }}
    </div>
    -
      -
    1. 找到这个地方\themes\next\languages\ 下面的语言文件zh-Hans.yml(以中文为例):
    2. -
    -
    1
    2
    3
    footer:
    powered: "由 %s 强力驱动"
    theme: 主题
    -

    将上面的文字改成自己想要的即可。

    -

    添加评论功能

    -

    Gitment

    -

    **此项目已经终止!**改为Disqus,以及其它评论服务。

    -
      -
    1. 安装功能模块。在项目的根目录:
    2. -
    -
    1
    npm i --save gitment
    -
      -
    1. 在Github申请应用。settings -> Developer Settings -> OAuth Apps
    2. -
    -
    1
    2
    3
    4
    Application name:随便写
    Homepage URL:这个也可以随意写,就写你的博客地址就行
    Application description:描述,也可以随意写
    Authorization callback URL:这个必须写你的博客地址
    -

    申请好之后点注册,然后就可以看到两个东西ClientIDClient Secret,后面会用到。

    -
      -
    1. 配置Gitment,打开themes/next/_config.yml:
    2. -
    -
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    # Gitment
    # Introduction: https://imsun.net/posts/gitment-introduction/
    gitment:
    enable: true
    mint: true # RECOMMEND, A mint on Gitment, to support count, language and proxy_gateway
    count: true # Show comments count in post meta area
    lazy: false # Comments lazy loading with a button
    cleanly: false # Hide 'Powered by ...' on footer, and more
    language: # Force language, or auto switch by theme
    github_user: {you github user id}
    github_repo: 随便写一个你的公开的git仓库就行,到时候评论会作为那个项目的issue
    client_id: {刚才申请的ClientID}
    client_secret: {刚才申请的Client Secret}
    proxy_gateway: # Address of api proxy, See: https://github.com/aimingoo/intersect
    redirect_protocol: # Protocol of redirect_uri with force_redirect_protocol when mint enabled
    -

    注意到这里基本上已经OK了,再看你的博客应该可以显示评论了.不过每篇博客都需要你手动初始化评论功能(如果你的历史博客很多那就一篇一篇去点吧,不过貌似有人写了批量处理脚本,没试过哈).

    -

    而由于 github 中 Issueslabel 长度限制为最大 50 个字符,当 文章标题长度过长时,该label就会生成失败,而导致初始化错误,弹出 Validation Failed 的提示。

    -

    通过网上的搜索,发现可以使用文章创建时的时间来代替文章标题,作为这个唯一的label标签。

    -

    找到giment的配置:/themes/next/layout/_third-party/comments/gitment.swig 文件, 并找到如下部分:

    -
    1
    2
    3
    4
    5
    var gitment = new {{CommentsClass}}({
    id: window.location.pathname,
    owner: '{{ theme.gitment.github_user }}',
    repo: '{{ theme.gitment.github_repo }}',
    ...
    -

    id后面的路径值修改为 ‘itfanr_blog_<!–1–>’ 就可以了。

    -

    Disqus

    -

    目前只开通Disqus的评论。

    -
      -
    1. 开通Disqus账号,并添加一个点 应用。具体步骤参看Hexo搭建博客系列:(六)Hexo添加Disqus评论
    2. -
    3. 主题配置文件(_config.yml)文件中找到以下代码,添加你Disqus设置的Website Name在shortname。
    4. -
    -
    1
    2
    3
    4
    5
    # Disqus
    disqus:
    enable: true
    shortname: tian-ya-de-zhi-fu
    count: true
    -

    更详细请参阅网上。

    -

    新文章命名规则

    -

    发表新文章后系统崩溃。

    -

    在根目录的配置文件中找到类似的:

    -
    1
    2
    3
    4
    # Writing
    new_post_name: 新文章.md # File name of new posts
    default_layout: post
    ...
    -

    将其改为由时间和题目组成:

    -
    1
    2
    3
    4
    # Writing
    new_post_name: year-:month-:day-:title.md # File name of new posts
    default_layout: post
    ...
    -

    进阶设置

    -

    显示

    -

    首页文章显示预览

    -

    默认设定下。首页的文章每一篇都显示全文,不方便浏览。需要到主题的配置文件里将auto_excerptenable 改为 true。而length 字节表示文章预览的长度。

    -
    1
    2
    3
    4
    # Automatically Excerpt. Not recommand.
    auto_excerpt:
    enable: true
    length: 300
    -

    永久链接

    -

    新文章的名字采用了中文(见上),中文出现在地址栏上不美观。也不利于SEO,以及增加了博文URL的层数。解决办法是给每篇文章制定链接地址。

    -
      -
    1. 修改网站的配置文件中永久地址的设定:
    2. -
    -
    1
    permalink: :urlname.html
    -
      -
    1. 给每篇文章指定 urlname
    2. -
    -
    1
    2
    3
    4
    5
    6
    title: 《少有人走的路》笔记
    date: 2019-07-21 00:14:37
    urlname: road-less-traveled-summary
    tags:
    - 心理学
    categories: 读书笔记
    -

    编译后新的地址为 http://mywiki.test/road-less-traveled-summary.html。看起来就清爽多了。

    -

    图片链接

    -
      -
    1. 开通资源文件夹,创建新文章的时候会自动建立一个与文章同名的文件夹。可以将图片或者其它资源文件放到里面(打算将思维导图放到这里)。因为自定义了文件名的方式,所以根据官方描述无效。
    2. -
    3. 安装第三方插件hexo-asset-image
    4. -
    -
    1
    npm install hexo-asset-image --save
    -

    在文章中图片的链,可以省略路径,直接引用图片名:

    -
    1
    ![mypicture](mypicture.jpg)
    -
      -
    1. 修改插件代码
    2. -
    -

    我在使用永久链接的时候在每篇文章的实际地址都加上了.html。文章的地址显示如下

    -
    1
    http://mywebsite.com/my-articel-url.html
    -

    而插件生成的图片地址如下:

    -
    1
    http://mywebsite.com/my-articel-url.htm/mypicture.jpg
    -

    多出了 .htm 这几个字符,而实际图片的地址应该是:

    -
    1
    http://mywebsite.com/my-articel-url/mypicture.jpg
    -

    找到 node_modules/hexo-asset-imge 目录下的 index.js 文件,将以下代码中的 1 改成 5,就可以正常显示图片了。

    -
    1
    var endPos = link.length - 1
    -

    考虑到将来项目膨胀,应该将图片放到图床,比如七牛。

    -

    站内链接

    -

    导航到站内别的文章使用以下方式就可以。

    -

    链接方式 [文章名](urlname.html)

    -

    设定代码区的高度

    -

    Hexo自身的式样暂时还没找到。其实也不太需要。如果代码不长直接显示全部就好了。太长的话不如放到$Gits$,通过限制gist的高度实现。Net主题修改 next/themes/next/source/css/_custom/custom.styl ,Wikitten主题则在文件 wikitten/themes/Wikitten/source/css/_partial/article.styl 中修改。

    -
    1
    2
    3
    4
    5
    .gist 
    .gist-file
    .gist-data {
    max-height: 450px;
    }
    -

    添加注脚支持

    -

    插件项目

    -
      -
    1. 安装插件 npm install hexo-footnotes --save
    2. -
    3. 项目配置文件 添加
    4. -
    -
    1
    2
    3
    # 注意第二行的前面没有 "-" 符号,官方说明有. 但是会导致无法编译.
    plugins:
    hexo-footnotes
    -

    更换Markdown渲染

    -

    Markdown-it-plus

    -

    如果更换了这个渲染,就无需上面那个注脚插件, 因为已经支持了. 首先卸载掉旧的渲染, 然后安装新的.

    -
    1
    2
    3
    4
    npm un hexo-renderer-marked --save
    npm i hexo-renderer-markdown-it-plus --save
    # 查看是否已经安装
    npm ls hexo-renderer-markdown-it-plus
    -

    然后在项目配置文件, 添加下面文字. 更深入的设置, 参看 markdown-it-plus 项目的说明文档.

    -
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    markdown_it_plus:
    highlight: true
    html: true
    xhtmlOut: true
    breaks: true
    langPrefix:
    linkify: true
    typographer:
    quotes: “”‘’
    plugins:
    -

    辅助功能

    -

    本地运行服务

    -

    在Mac中可以用本地服务Pow运行网站,不用每次更改重启服务器hexo s

    -
      -
    1. 安装Pow
    2. -
    -
    1
    $ curl get.pow.cx | sh
    -
      -
    1. 建立项目链接,myapp 是项目的名字。比如真实路径~/Project/mywiki
    2. -
    -
    1
    2
    $ cd ~/.pow
    $ ln -s /path/to/myapp
    -
      -
    1. 执行完以上步骤后在浏览器打开链接 http://myapp.test/ 就能看到网站。更改内容后要执行==生成== 命令才能看到更新hexo generate or hexo g
    2. -
    3. 不想运行,直接把项目文件夹删除就可以。
    4. -
    -

    绑定个人域名

    -
      -
    1. 在万网买一个顶级域名,开通后添加两个域名解释
    2. -
    -
    1
    2
    3
    #记录名  主机记录  记录值
    CNAME www username.github.io
    CNAME @ username.github.io
    -
      -
    1. 在项目的根目录添加一个名为 CNAME 的文件,然后填入万网注册的域名, 这里是 goldentianya.pub 。第一次我是手动添加的。添加后进入 repository 的 setting, 往下混动到 Custom domain ,可以看到系统已经自动把用户域名加进去了。
    2. -
    3. 将来不希望用这个域名,域名重定向后,在浏览器输入 username.github.io 后 Chrome 会一直转向 goldentianya.pub 。需要打开开发者工具,选中 disable cache ,再刷新一遍地址就好了。
    4. -
    5. next 项目要将 CNAME 文件复制到 /themes/next/source 目录下个,编译的时候会拷贝到 public 目录。wikitten 项目不需要,域名定向以后能找到 goldentianya/wiki 站点,十分神奇。
    6. -
    -

    隐藏文章

    -

    全隐藏

    -

    根据插件hext-sage-posts 作者的博文9中描述,安装插件

    -
    1
    npm install hexo-sage-posts --save
    -

    并将初创时的Hello-world.md 文章的Metadata中加入sage: true,文章就从网站上消失了。但在别的文章下面导航栏中,通过“下一篇”或者“上一篇”还是能被找到。被隐藏的文章其地址仍旧没有改变,只是不不出现在首页导航,和分类中而已。

    -

    从首页隐藏

    -

    为了不让太琐碎的文章充斥首页,但又可以在分类中找到。可以采用这种方式。

    -
      -
    1. 在文章的Metadata部分添加关键字 notshow: true
    2. -
    3. 找到 Hexo\themes\next\layout\index.swig 文件中以下部分:
    4. -
    -
    1
    2
    3
    4
    5
    6
    7
    8
    9
    {% block content %}
    <section id="posts" class="posts-expand">
    {% for post in page.posts %}
    {{ post_template.render(post, true) }} <!--修改此行-->
    {% endfor %}
    </section>

    {% include '_partials/pagination.swig' %}
    {% endblock %}
    -

    将以上代码第四行修改为

    -
    1
    2
    3
    {% if post.notshow != true %}
    {{ post_template.render(post, true) }}
    {% endif %}
    -

    文章加密

    -
      -
    1. 安装插件 hexo-blog-encrypt
    2. -
    -
    1
    npm install --save hexo-blog-encrypt
    -

    并在站点配置文件中启用该插件:

    -
    1
    2
    encrypt:
    enable: true
    -
      -
    1. 然后在文章的头部添加上对应的字段
    2. -
    -
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    ---
    title: 文章加密
    date: 2019-01-04T22:20:13.000Z
    category: 教程
    tags:
    - 博客
    - Hexo
    keywords: 博客文章密码
    password: TloveY
    abstract: 此文章含有敏感内容。
    message: 输入密码,查看文章
    ---
    -
      -
    • -

      password: 是该博客加密使用的密码

      -
    • -
    • -

      abstract: 是该博客的摘要,会显示在博客的列表页

      -
    • -
    • -

      message: 这个是博客查看时,密码输入框上面的描述性文字

      -
    • -
    -

    Hexo Admin

    -

    安装后台管理插件 hexo-damin

    -
    1
    2
    3
    npm install --save hexo-admin
    hexo server -d
    open http://localhost:4000/admin/
    -

    初次运行后,设置管理账户。

    -
    1
    2
    3
    4
    admin:
    username: maiernte
    password_hash: $2a$10$QeeWfDwIxbJ94h8EDfplDe9aLB0uaNrjMeVGhaYnfF0BBDosDze0S
    secret: NamoAmitabha!
    -

    访问量统计

    -

    介绍文章有图

    -

    原文(有代码)

    -
      -
    1. -

      第一步, 到Lean Cloud增添一个应用,并创建类似Counter 的类。设置成 $ 所有人可读可写 $

      -
    2. -
    3. -

      在安全中心添加 Web 安全域名, 添加Blog域名,防止有人Hack我们的数据库。

      -
    4. -
    5. -

      按上面的文章修改 Hexo 以及主题配置。

      -
    6. -
    -

    在线交流

    -

    使用 道客 Daovoice

    -

    接入方式

    -
      -
    1. 将下面代码粘贴在页面的 之前。
    2. -
    -
    1
    <script>(function(i,s,o,g,r,a,m){i["DaoVoiceObject"]=r;i[r]=i[r]||function(){(i[r].q=i[r].q||[]).push(arguments)},i[r].l=1*new Date();a=s.createElement(o),m=s.getElementsByTagName(o)[0];a.async=1;a.src=g;a.charset="utf-8";m.parentNode.insertBefore(a,m)})(window,document,"script",('https:' == document.location.protocol ? 'https:' : 'http:') + "//widget.daovoice.io/widget/5e5fa370.js","daovoice")</script>
    -
      -
    1. 调用下面的 JavaScript 与注册用户沟通
    2. -
    -
    1
    2
    3
    4
    5
    6
    7
    8
    daovoice('init', {
    app_id: "5e5fa370",
    user_id: "NO_89757", // 必填: 该用户在您系统上的唯一ID
    email: "daovoice@example.com", // 选填: 该用户在您系统上的主邮箱
    name: "道客船长", // 选填: 用户名
    signed_up: 1449821660 // 选填: 用户的注册时间,用Unix时间戳表示
    });
    daovoice('update');
    -
      -
    1. 调用下面的 JavaScript 与匿名访客沟通
    2. -
    -
    1
    2
    3
    4
    daovoice('init', {
    app_id: "5e5fa370"
    });
    daovoice('update');
    -

    完成代码粘贴后,检测是否成功接入: Ping 一下

    -

    待解决问题

    - -

    有趣插件

    - -

    -

    讲解详细的博客

    -

    这个也不错

    - -
    - -
    -
    -
    -
    - - - - - - - - - - - -
    -
    - -
    -
    - - - - - - - -
    -
    -
    -
    - -
    -
    - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - - - \ No newline at end of file diff --git a/docs/how-to-manage-big-hexo-blog.html b/docs/how-to-manage-big-hexo-blog.html index 41383bc..e69de29 100644 --- a/docs/how-to-manage-big-hexo-blog.html +++ b/docs/how-to-manage-big-hexo-blog.html @@ -1,586 +0,0 @@ - - - - - - 如何系统化管理Hexo博客 | 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - -
    - - - - -
    -
    - - -
    - - - - - -

    - 如何系统化管理Hexo博客 -

    - - -
    - - -
    - - - -
    - 文章目录 -
    1. 1. 建立博客的初衷
    2. 2. 解决思路
      1. 2.1. 硬件
      2. 2.2. 软件
    3. 3. 难点的解决办法
      1. 3.1. 笔记复制的解决办法
      2. 3.2. 管理笔记的分类
    -
    - - - -

    建立博客的初衷

    -

    虽说这篇笔记的题目是「如何管理」,为了更好的回答这个问题,必须要回到最原始问题上来——我为何要建一个博客,而且是费那么大劲。而我的初衷是建立和维护一个属于自己的「知识库」。通常来说,为了达成这个目的,更好的选择是笔记APP,而不是博客。我确实也是这么做的。一开始用印象笔记,因为它死活不支持多级目录,我又转到国内的为知笔记,做了五年的VIP用户。但它五年来似乎从没改进过。随着近年来有道云异军突起,以及IOS生态圈中琳琅满目的APP,如熊掌记、Notion、谷歌的Keep、阿里的语雀。。。。。。各有各的惊艳,各有各的槽点。

    -

    随着国外的Github和国内的Coding等公司,相继开放永久免费、不限流量的静态网页托管平台,如Github Pages。我走上了自建Bolg的不归路。当然不是说,搭博客这条路完全没有槽点。而是——自己造的孽,含着泪也会继续造下去。至少它满足了我以下几点「必不可少」的要求:

    -
      -
    • [x] 多级目录
    • -
    • [x] 支持Markdown文本
    • -
    • [x] 支持分类、标签、以及站内全文检索
    • -
    • [x] 没有IOS、Windows、Android等平台限制
    • -
    -

    说白了,我是利用Github提供的免费平台,把Blog当笔记本来用。最后选了Hexo,简单易用、界面绚丽、插件丰富。除开自用的「知识平台」功能以外,偶尔还能发发博文装大尾巴狼,也是蛮不错的感觉。

    -

    网上介绍怎么搭建Hexo以及添加绚丽功能的帖子海了去了,但我基本没有发现分享「如何管理」的。因为绝大多数这些博主,搭建Hexo只是用来玩一阵子。回头有更新更好玩的东西,就跑去玩别的了。极少数有博客,站内文章超过50篇的。所以,对他们来说,根本不存在——管理——这个议题。

    -

    虽然Hexo在逻辑上支持分类标签,但物理上它把所有的Post都放到一个单一的目录下面。而我是打算把它当作知识库,长期、密集使用的。可预见的将来,站内笔记会非常多。不但写新贴,还可能经常更改旧贴。那势必会带来一个问题:如何管理数量少日益膨胀的笔记?

    -

    解决思路

    -

    我能想到的办法很简单,也很传统。就是不但逻辑分类,而且也必须物理上分目录存放。理论上在自己的PC分目录保存就好了。但我有好几台电脑,单位一台、自己Windows一台、Mac一台,还有平板。为了让能在不同的电脑上能随时修改、添加笔记,必须放在托管在云端。

    -

    硬件

    -

    没有必要租用传统的VPS,太贵了,而且连10%的运算能力都用不上。用共享的Web Hosting就完全能解决需求。比如百度云,或者Azure的Web App。而我是租用 1&1 公司的Web Hosting,每个月 1€

    -
      -
    • 1 CPU
    • -
    • 500M 内存
    • -
    • 20G SSD
    • -
    -

    就算那么低的运算能力,平时我的网站也用不到25%的运算能力。应付起啦,绰绰有余。

    -

    软件

    -

    我采用了MM-Wiki 管理平台(以下简称维基平台)。这是一个非常优秀的开源项目,具体请参看作者的文档。部署超级简单,可以说一键部署,然后就可以用起啦了。简单来说这个平台有以下几个特点:

    -
      -
    • [x] 支持空间管理、空间内支持多级目录。
    • -
    • [x] 支持Markdown编辑。
    • -
    • [x] 支持附件。
    • -
    • [x] 有修改记录。
    • -
    • [ ] 不支持内容搜索,只支持笔记的题目搜索。
    • -
    • [ ] 标签只支持到空间级别,目录和笔记都没有标签。
    • -
    -

    但它跟Hexo博客搭配使用,就完全满足我的需求了。其实Hexo博客中,有个仿维基的Wikitten主题,跟MM-Wiki项目非常像。但毕竟不是所有内容,都适合摆在公开的地方。以MM-Wiki 作为私用平台,增加了私隐保护。

    -

    我的做法是,在维基平台中开辟一个独立的空间,用来存放博客上所有的源文件。而在Github Pages上托管的静态网站其实都是HTML文件。所有的改动,都必须在源Markdownn文件上修改,然后再推送到博客网站的。

    -

    在维基平台修改、添加、删除笔记的源文件。然后复制到Hexo的项目目录,编译后推送到Github Pages站点。维基百科内置的在线版Editor.md 编辑器,非常美观实用。基本上我都不太需要在自己的电脑上用Typora等编辑器写MD文本了。思路有了,实现起来还是有一点问题。

    -

    难点的解决办法

    -

    首先,在维基平台内,MD文件是分目录存储的。这个目录不能直接拷贝到Hexo的_post目录。懒得每修改一个,或者添加一个笔记,就立马拷贝到博客中去。解决笔记复制的问题。

    -

    其次,笔记的物理保存目录,必须跟Hexo上的「分类」是一一对应的。否则,管理起来会很麻烦。在维基平台移动了笔记的保存目录后,在一一修改内容,也是很吃力的事情。

    -

    笔记复制的解决办法

    -

    说来也超级简单,一个脚本命令就够了。先用find命令在指定目录找出所有的MD文件,然后通过管道传给复制命令cp,搞定!

    -
    1
    find  /root/bibliothek/markdowns/博客草稿/  -type f -name "*.md" -exec cp {} /home/_post/ \;
    -

    然后hexo d -g编译、发布,结束!

    -

    管理笔记的分类

    -

    这个问题有一点麻烦。因为必须打开每一个文件,读取笔记的头文件描述,然后再比较跟文件的物理位置是否符合。我尝试用shell脚本解决这难题。无奈我的的shell脚本功底是在很差,搞半天未果就放弃了。用Java或者.NET Core啥的,正儿八经写一个Console程序,也不是不行。但有种杀鸡用牛刀的感觉。

    -

    最后想到了用Javascript。因为编译Hexo是需要安装Node.js的,写一段JavaScript,让Node跑起来。通往罗马的道路千万条,选一条自己最熟悉的就完了。

    -
    点击查看代码
    - -
    -
    -

    上面这个脚本使用的都是我个人设置,你如果要用的话需要改成自己实际文件目录。

    -
    -

    -
    - -
    -
    -
    -
    - - - - - - - - - - - -
    -
    - -
    -
    - - - - - - - -
    -
    -
    -
    - -
    -
    - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - - - \ No newline at end of file diff --git a/docs/index.html b/docs/index.html index 35fbccd..e69de29 100644 --- a/docs/index.html +++ b/docs/index.html @@ -1,1304 +0,0 @@ - - - - - - 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - -
    - - - - -
    - - - - - - - - -
    -
    - - -
    - - - - - -

    - MathJax用于易学领域 -

    - - -
    - - -
    - - - - -

    关于利用 MathJaxKatex 数学公式解释器,实现易学上排六爻盘和八字盘个功能。今天实现了易学上的核心功能。有望将来能添加更多的函数,以便利各位同门以及广大易友。

    - - - -
    -
    - 查看更多 -
    - -
    -
    -
    -
    - - - - - - - -
    -
    - - -
    - - - - - -

    - 用TypeScript编写JS函数库 -

    - - -
    - - -
    - - - - -

    本文具体介绍如何用TypeScript编写JavaScript库文件,以及制作npm工具包。主要参考下面两篇文章。我也省却一步步解释,只罗列相关的代码和我遇到的坑。想知道代码含义的请参阅原帖

    -

    - - - -
    -
    - 查看更多 -
    - -
    -
    -
    -
    - - - - - - - -
    -
    - - -
    - - - - - -

    - 还在用七牛? -

    - - -
    - - -
    - - - - -

    自从七牛换了服务条款,每个空间就只分配测试域名, 30天到期。想省钱的用户,必须每30天倒腾一次。如果忘记了,过了期限,据说图都找不回来。不想费那个劲的用户, 得绑定自己的域名。 这样不但增加费用,还要考虑到域名备案。 十分麻烦。

    - - - -
    -
    - 查看更多 -
    - -
    -
    -
    -
    - - - - - - - -
    -
    - - -
    - - - - - -

    - Gitbook攻略 -

    - - -
    - - -
    - - - - -

    本文为你介绍如何使用利用 Typora + gitbook-cli + Github Pages 书写Gitbook. 在本地用 Typora 书写 md 文件, 用 gitbook-cli 编译, 最后发布到 Github Pages 上.

    - - - -
    -
    - 查看更多 -
    - -
    -
    -
    -
    - - - - - - - - - - - - - - - - - - - - - - - -
    -
    - - -
    - - - - - -

    - 同步Hexo文章与Mac上原笔记的分类和标签 -

    - - -
    - - -
    - - - - - - - - - - - - - - - - - - - - - - -

    最近才搞明白,原来Hexo博客的_post文件夹里面的Markdown原文件是可以按照分级嵌套的目录结构摆放的。编译的时候才放到public这个单一目录下。如果能让文章在Hexo的==分类==严格跟md文件的存储目录一一对应,将来需要找原文件的时侯会方便很多。😄

    -

    使用Mac系统的同学也知道,mac有个很风骚的操作,就是给文件分配不同颜色的标签,非常方便文件寻找。我也希望博客上的文章标签,能跟Mac系统里的标签统一起来。:smile:

    -

    实现物理存储目录与Hexo分类统一很简单,将源md文件的相对存储路径写到文件meta元素的categories里面就行了。比如源文件放在我的博客-->IT-->前端,文章的头文件就写成这样:categories:[IT, 前端]

    -

    实现标签的统一稍微麻烦一点,需要先读取文件实际分配到的标签。网上已经有一个公开的项目, tag 。下载并安装,就可以通过 tag 命令读取文件和文件夹的标签。

    -
    1
    2
    3
    4
    5
    6
    # 安装
    brew install tag
    # 查看版本
    tag --version
    # 读取文件标签
    tag --list fileUrl
    -

    - - - - -

    -
    - 查看更多 -
    - -
    -
    -
    -
    - - - - - - - -
    -
    - - -
    - - - - - -

    - 有用的Shell命令 -

    - - -
    - - -
    - - - - -

    在线网站可以找到基本的东西:Linux命令大全 shell 正则表达式

    -

    文件&内容检索

    -

    正则表达式注意的地方

    -
      -
    • 花括号之前要加转义字符 [a-z]\{3\}
    • -
    • 空格就是转义加空格\ ,而不是\s 。如 [a-z0-9_\ ]\{3,\}
    • -
    • 这几个符号 _ - . #都不需要加转义符。
    • -
    • 不要轻易加==行结束符==$,可能回车才是最后符号,所以可能找不到。
    • -

    - - - -
    -
    - 查看更多 -
    - -
    -
    -
    -
    - - - - - - - -
    -
    - - -
    - - - - - -

    - Hexo日常管理 -

    - - -
    - - -
    - - - - - - - - - - - - - - - - - - - - - - -

    复制MD文件

    - -

    查找最新文件

    -
    1
    2
    3
    4
    ls -t /Users/mai/Projects/hexo/source/_posts/*.md | head -1 | xargs ls -l | awk '{print  $6 "-" $7 "-" $8 }'

    # 最旧的文件就应该是
    ls -t /Users/mai/Projects/hexo/source/_posts/*.md | tail -1 | xargs ls -l | awk '{print $6 "-" $7 "-" $8 }'
    -

    其它

    -

    - - - - -

    -
    - 查看更多 -
    - -
    -
    -
    -
    - - - - - - - - -
    -
    -
    -
    - -
    -
    - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - - - \ No newline at end of file diff --git a/docs/javascript-typescript-skills.html b/docs/javascript-typescript-skills.html index 43b67c5..e69de29 100644 --- a/docs/javascript-typescript-skills.html +++ b/docs/javascript-typescript-skills.html @@ -1,558 +0,0 @@ - - - - - - JavaScript & Typescript技术摘要 | 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - -
    - - - - -
    -
    - - -
    - - - - - -

    - JavaScript & Typescript技术摘要 -

    - - -
    - - -
    - - - -
    - 文章目录 -
    1. 1. 零散知识点
    2. 2. Promise
      1. 2.0.1. 输出链条
      2. 2.0.2. 等待多个 Promise
  • 3. 声明以及定义扩展
  • 4. 读取文本
    1. 4.0.0.1. Html5 标准按钮
    2. 4.0.0.2. 使用nix-file-helpers 插件
  • 5. 测试
    1. 5.0.0.1. 引用第三方js文件
  • -
    - - - -

    Javasript 和 Typescript 的重要技巧。

    - -

    零散知识点

    - -

    Promise

    -
    输出链条
    -

    文档 Promises chaning

    -

    :pencil2: 可以在 then 函数里面跑出 结果 或者 第二个 Promise

    -
    等待多个 Promise
    -
    1
    2
    3
    4
    let p1 = promise1
    let p2 = promise2
    const promises = Promise.all([p1, p2])
    return promises
    -

    声明以及定义扩展

    -

    *.d.ts 文件中声明类型

    -
    1
    2
    3
    4
    declare type Book = {
    title: string,
    comment?: string
    }
    -

    对 JavaScript 的原型进行扩展, 在一个 TS 文件进行定义和实现

    -
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    // ...path/common.ts
    export {} // this will make it module
    declare global {
    interface String {
    IsNullOrEmpty():boolean;
    Latex(color?:string):string;
    }
    }

    String.prototype.IsNullOrEmpty = function(){
    return this == undefined || this == null || this == ""
    }
    -

    在需要的地方引用

    -
    1
    2
    3
    4
    import '..path/common';

    let str = ""
    const is_it_empty = str.IsNullOrEmpty()
    -

    读取文本

    -
    Html5 标准按钮
    -
    1
    <div type='file' (change)='LoadLocalFile($event)'></div>
    -

    Javascript 读取文本内容并转为数据库 (使用 sql.js)

    -
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    LoadLocalFile(file) {
    const fileurl: File = file.target.files[0];
    const reader = new FileReader();
    reader.onload = () => {
    console.log('read file:', reader.result);
    const buffer = reader.result;
    const Uints = new Uint8Array(buffer as ArrayBuffer);
    const db = new SQL.Database(Uints);
    const nodes = db.exec('SELECT * From node');
    console.log(nodes);
    };

    reader.readAsArrayBuffer(fileurl);
    }
    -
    使用nix-file-helpers 插件
    -

    文档地址

    -

    演示地址

    -

    Html

    -
    1
    2
    3
    4
    5
    <ion-button   ngxFilePicker #filePicker="ngxFilePicker" 
    [readMode]="readMode"
    (readStart)="onReadStart($event)"
    (filePick)="onFilePicked($event)"
    (readEnd)="onReadEnd($event)">导入案例</ion-button>
    -

    代码,读取文件

    -
    1
    2
    3
    4
    5
    6
    onFilePicked(file: ReadFile) {
    const Uints = new Uint8Array(file.content as ArrayBuffer);
    const db = new SQL.Database(Uints);
    const nodes = db.exec('SELECT * From node');
    console.log(nodes);
    }
    -

    测试

    -
    引用第三方js文件
    -

    angular.json 文件的 test-->scripts 中添加需要引用的文件。

    - -
    - -
    -
    -
    -
    - - - - - - - - - - - -
    -
    - -
    -
    - - - - - - - -
    -
    -
    -
    - -
    -
    - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - - - \ No newline at end of file diff --git a/docs/lalaland-film.html b/docs/lalaland-film.html index 2f16157..e69de29 100644 --- a/docs/lalaland-film.html +++ b/docs/lalaland-film.html @@ -1,544 +0,0 @@ - - - - - - 爱乐之城——影评 | 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - -
    - - - - -
    -
    - - -
    - - - - - -

    - 爱乐之城——影评 -

    - - -
    - - -
    - - - - - -

    - -

    我在凌晨三点醒来的夜里,想起已失去的你,曾经说着永远一起,现在却不再联系。如果当时的我们能少一些固执,是否会有更好的结局。

    -

    洛杉矶,华纳兄弟电影厂旁边的咖啡馆,明星来往不息。一身素雅的米娅是这里的收银员。她的梦想就是成为一个知名演员及编剧。所以她经常请假去试镜,跑遍大大小小的片场。虽然每次她都充满希望,但现实却是四处碰壁。这天,又一次遭受打击的米娅垂头丧气回到家中。洗去一身疲态后,她站在镜子面前暗自神伤哼起歌来 。这时室友火急火燎的出现,邀请她一起去参加派对。本来心情极度郁闷的米娅不想去凑热闹。经不住一帮二货室友的游说,精心打扮一番后她们就出发了。

    -

    洛杉矶的月色下,灯红酒绿,觥筹交错。但热闹是属于他们的,安静下来后她却感到愈加落寞。人潮中充斥着过剩的荷尔蒙,但却没有她想要的一双眼睛。世界瞬息万变,她却岿然不动。逃离狂欢派对后,违规停放的车子又被拖走。米娅只能走路回家,在安静的街头上。忽然一阵悠扬的钢琴声传来,如梦似幻,温润缠绵。米娅停下脚步,来到了一个毫不起眼的地下酒吧。一个优雅的男人坐在无人注意的角落里安静的弹奏着。此刻,全世界好像都暗了下来,只有他闪着耀眼的光芒。男人名叫塞巴斯汀,是一个爵士乐钢琴师。他对音乐有着自己独特的追求,不愿弹奏靡靡之音。可一曲弹罢,没有人为他鼓掌,他也被老板炒了鱿鱼。塞巴斯汀愤愤的离开,米娅鼓起勇气迎面走过去,想要认识这个让她着迷的男人。但一句话还没说完,男人就径直的走开了。米娅扑了个空,尴尬的站在那里不知所措。

    -

    生活依然按部就班,米娅依然忙着追逐她的梦想。一次派对上,米娅又遇上了塞巴斯汀。他加入了一个爵士乐队,但他们的演奏依旧没人捧场。为了惩罚这个「严肃」的音乐人,也为了报复上次给她造成的尴尬,米娅点了一首非常不严肃的音乐,她甚至随着音乐舞动起来。而塞巴斯汀却站在那里既尴尬又无奈。米娅的行为让塞巴斯汀想起了那晚的无礼。他向米娅道了歉,两人算是相识了。聚会结束后,米娅又找不到车子,于是两人在夜色下散步。洛杉矶的夜色此刻显得如此迷人,在暧昧的氛围中,他们默契地跳着属于他们的舞蹈。

    -

    第二天塞巴斯汀来到米娅工作的咖啡店,下班后他们一起在片场附近的街头闲聊,塞巴斯汀鼓励米娅给自己写剧本,而不是去演别人的剧本。自己给自己创造角色,说不定会有意想不到的效果。米娅也向塞巴斯汀坦白说,她讨厌爵士乐。于是固执的塞巴斯汀就带米娅来到一个演奏爵士乐的酒吧,他试图改变米娅对爵士乐的看法,向她解释爵士乐的起源。然而米娅还是不能理解,对音乐有执念的塞巴斯汀表示,他不想让爵士乐就此消亡,他想要创建自己的俱乐部,在那里只有纯粹的爵士乐,那是他一直以来的梦想。

    -

    这天又一次试镜失败的米娅心情沮丧,经过电影院门口时,她想起和塞巴斯汀的电影院之约。顿时心情变得愉悦,这时几个月不见一次的男友却来接她一起吃饭。餐桌上米娅心不在焉,男友却把她晾在一边,自顾自的和哥哥聊天。而在电影院门口的塞巴斯汀焦急的等着米娅,此时餐厅传来了熟悉的曲子,那个夜晚塞巴斯汀弹奏的正是这首曲子。米娅随即起身跑了出去,穿过色彩缤纷的霓虹灯,她找到了失落的塞巴斯汀,此时的两个人根本无心观看电影。他们指尖轻触,随后十指紧扣,接着互相靠近……但灯光却忽然打开,两人无奈的相视一笑。之后米娅带着塞巴斯汀来到天文馆,他们在浪漫的氛围中翩翩起舞,魅惑的蓝色星空下,两人仿佛和整个宇宙融为一体。

    -

    金风玉露终于相逢,热恋之吻甘之如饴。随后两人一边热恋,一边为各自的梦想努力。他们一起旅行、一起恶作剧,他们走遍大街小巷,他弹琴、她跳舞,在塞巴斯汀的影响下,米娅渐渐喜欢上了爵士乐。这天早上,塞巴斯汀无意中听到了米娅和她母亲的通话。米娅的母亲对她们的未来很担忧,因为塞巴斯汀没有稳定的工作。寥寥几句话,就将塞巴斯汀从梦中拉回现实。他接受了前乐队主唱的邀请,成为了他们的键盘手。但这就意味着塞巴斯汀必须放弃自己的坚持,跟着乐队的风格走。晚上回家的米娅,听到塞巴斯汀的琴声,感受到了他失落的情绪。无需过多的话语,米娅和着琴声唱着歌,这种默契让他们心照不宣。就这样两人互相鼓励,互相安慰,塞巴斯汀的乐队开始走红。米娅也陆陆续续接到了一些大大小小的角色。看着梦想之门慢慢打开,他们也变得越来越忙碌。乐队巡演时,米娅站在台下看着万众瞩目的塞巴斯汀,喧闹的人群,闪烁的灯光,流行的爵士乐,一切看起来都那么美好……台上的男人意气风发、星光闪耀,米娅却觉得和他有了距离。晚上回到家的米娅得到了一个大大的惊喜。忙碌的他们很久都没有见面了,塞巴斯汀明天一早又要离开,他想要让米娅跟他一起,米娅却问他喜不喜欢现在弹奏的音乐?但此时的塞巴斯汀已经尝到了名利带来的甜头,他放弃了曾经的梦想,也放弃了曾经的坚持。他以为这些是米娅想要的:稳定的生活,不菲的收入,以及聚少离多的爱情。他说以前那些梦想太虚无缥缈,现在他需要成熟起来。最后激动的塞巴斯汀对米娅说,你喜欢以前不堪的我,是因为相比而言,那会让你感觉自我良好。这句伤人的话使得他们关系僵化,接着米娅一声不响的离开。第二天在给乐队拍宣传片的时候,摄影师让塞巴斯汀随便弹,于是他弹起了熟悉的曲子,接着他似乎想起了什么……再一次试镜被嘲笑后,米娅心情降至冰点。她准备返回老家,这个城市再没什么值得她留恋,梦想也好,爱人也罢,终究只是一场梦。面对挽留的塞巴斯汀,她再也无法忍受,哭着说她受够了。米娅回到了自己的家,塞巴斯汀也回到了乐队。

    -

    一段时间后,塞巴斯汀出现在了米娅家门口。一个知名导演正在选角,试镜电话打给了塞巴斯汀,在塞巴斯汀的鼓励下,米娅鼓起勇气决定再试一次。导演让米娅随便讲一个故事,于是她用歌声讲述了自己的梦想。面试过后,他们来到天文馆门口,一起谈论着对未来的打算。他说你的梦想一定会实现的。秋天的洛杉矶,纯净而理性。他们的感情在这里开始,也在这里结束……

    -

    五年后米娅成了知名演员,实现了自己的梦想。她事业有成,结婚生子,生活安稳,家庭美满。晚上米娅和丈夫遭遇堵车,路边散步时发现了一个酒吧。热闹的气氛吸引了米娅的注意,这正是当年塞巴斯汀带她去的酒吧。米娅发现酒吧的名字是她多年前为塞巴斯汀取的。这里只有纯粹的爵士乐,塞巴斯汀的梦想就是拥有这样一个地方。落坐以后,塞巴斯汀看到了台下的米娅,沉默片刻后,他弹起了那首熟悉的音乐。

    -
    -

    就像最初他们相见时那样,他们忘记了全世界。那个夜晚,那次初见,时间仿佛从未流逝。但这次不等她说完一句话,他就热烈的吻上了她唇。他毫无顾忌,她毫无防备,他们痴迷于彼此的味道。他们翩翩起舞,一路走向梦想,走进热恋,相互陪伴,相互成全,一起成长,一起狂欢。然后携手走进那片星空。他眼神温柔,她身姿婀娜。他们打造着自己的小窝,享受着二人世界。爱的结晶来到他们身边,放佛那些美好是和他一起度过的。直到今天这个夜晚,他们始终如一,此志不渝。

    -
    -

    曲终之后,她被拉回现实,然后和丈夫一起离开。在拐角处她转身,回头,两人遥遥相望,然后互相报以微笑。时隔经年,若我遇见你,我该如何与你致意?以眼泪,以沉默!

    -

    我一同学特别喜欢这部电影,我知道那是因为她在电影中看到了自己。她的挚爱,七年长跑,可终究还是没能走到一起。或许这就是所谓的「在别人的故事里,流着自己的眼泪」。你是否也在无人的深夜,想起某个人,然后哭着醒来。看着周围的一切,熟悉又陌生,那个藏在心里的人啊,此时你身在哪里?可知有人还在深爱着你。虽然思念依然刻骨铭心,但你们之间却只剩下曾经。最怕的莫过于,在寂静无声的日子里,莫名其妙的,突然听懂了一首歌,只是你听到的不再是歌曲,而是人生。

    -

    「初识不知曲中意,再听已是曲中人」……就像是做了一场梦,醒来之时万籁俱寂,物是人非事事休,欲语泪先流……年少时我们总想给最爱的TA更多,却忽略了TA最想要的只是真实的你。后来的我们什么都有了,但却没了我们。我还是我,你还是你,我们却不再是我们。……于是你只能在某个深夜,听着歌,流着泪,然后默默的在心里对那个人说,今夜,我不关心世界,今夜,我只想你。

    - -
    - -
    -
    -
    -
    - - - - - - - - - - - -
    -
    - -
    -
    - - - - - - - -
    -
    -
    -
    - -
    -
    - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - - - \ No newline at end of file diff --git a/docs/lib/blog-encrypt.js b/docs/lib/blog-encrypt.js index 1f758fc..e69de29 100644 --- a/docs/lib/blog-encrypt.js +++ b/docs/lib/blog-encrypt.js @@ -1,212 +0,0 @@ -'use strict'; - -function decryptAES (password) { - - try { - - var decryptionError = String(document.getElementById('decryptionError').innerHTML); - var noContentError = String(document.getElementById('noContentError').innerHTML); - - } catch (e) { - - decryptionError = 'Incorrect Password!'; - noContentError = 'No content to display!'; - - } - - try { - - let content = CryptoJS.AES.decrypt(document.getElementById('encrypt-blog').innerHTML.trim(), password); - content = content.toString(CryptoJS.enc.Utf8); - content = decodeBase64(content); - content = unescape(content); - if (content === '') { - - throw new Error(noContentError); // ??? - - } else { - - document.getElementById('encrypt-blog').style.display = 'inline'; - document.getElementById('encrypt-blog').innerHTML = ''; - - // Use jquery to load some js code - try { - - $('#encrypt-blog').html(content); - - // NO Style Change here - - // NO Style Change here - - } catch(e) { - - const errorInfo = '

    ' - + 'Some errors occurred, check the original file please.' - + 'Detailed exceptions are shown in console.' - + '

    '; - console.error(e); - $('#encrypt-blog').html(errorInfo); - - } - - document.getElementById('hbe-security').style.display = 'none'; - if (document.getElementById('toc-div')) { - - document.getElementById('toc-div').style.display = 'inline'; - - } - - } - - // Call MathJax to render - if(typeof MathJax !== 'undefined') { - - try { - - MathJax.Hub.Queue( - ['resetEquationNumbers', MathJax.InputJax.TeX, ], - ['PreProcess', MathJax.Hub, ], - ['Reprocess', MathJax.Hub, ] - ); - - } catch (e) { - - console.log('Can\'t render with MathJax'); - - } - - } - - } catch (e) { - - alert(decryptionError); - console.log(e); - return false; - - } - - return true; - -} - -function htmlDecode (str) { - - let s = ''; - if (str.length == 0) { - - return ''; - - } - - s = str.replace(/>/g, '&'); - s = s.replace(/</g, '<'); - s = s.replace(/>/g, '>'); - s = s.replace(/ /g, ' '); // ??? why not ' ' - s = s.replace(/'/g, '\''); - s = s.replace(/"/g, '"'); - s = s.replace(/
    /g, '\n'); - return s; - -} - -function decodeBase64 (content) { - - content = CryptoJS.enc.Base64.parse(content); - content = CryptoJS.enc.Utf8.stringify(content); - return content; - -} - -function setCookie (cookieName, cookieValue, expireMinutes) { - - const expireTime = new Date(new Date().getTime() + 1000 * 60 * expireMinutes); - document.cookie = `${ cookieName }=${ escape(cookieValue) }${ expireMinutes == null ? '' : `;expires=${ expireTime.toGMTString() }` }`; - -} - -function getCookie (cookieName) { - - if (document.cookie.length > 0) { - - let idx = document.cookie.indexOf(`${ cookieName }=`); - if (idx != -1) { - - idx = idx + cookieName.length + 1; - let idy = document.cookie.indexOf(';', idx); - if (idy == -1) { - - idy = document.cookie.length; - - } - return unescape(document.cookie.substring(idx, idy)); - - } - - } - return ''; - -} - -function GetUrlRelativePath () { - - const url = document.location.toString(); - const arrUrl = url.split('//'); - - const start = arrUrl[1].indexOf('/'); - let relUrl = arrUrl[1].substring(start); - - if(relUrl.indexOf('?') != -1) { - - relUrl = relUrl.split('?')[0]; - - } - return relUrl; - -} - -function GenerateCookieName () { - - const COOKIE_NAME = 'HBE-PASSWORD'; - return COOKIE_NAME + GetUrlRelativePath(); - -} - -// Since you decided to use jQuery. -$(document).ready( - function () { - - - let password = String(getCookie(GenerateCookieName())); - console.log(`Get password from Cookie:${ password}`); - - if (password != '') { - - if(!decryptAES(password)) { - - // Delete cookie - setCookie(COOKIE_NAME, password, -5); - - } - - } - - console.log('Registering Enter for decrypt.'); - document.getElementById('pass').onkeypress = function (keyPressEvent) { - - password = String(document.getElementById('pass').value); - if (keyPressEvent.keyCode === 13) { - - const result = decryptAES(password); - - if (result) { - - setCookie(GenerateCookieName(), password, 30); - - } - - } - - }; - - } -); diff --git a/docs/lib/crypto-js.js b/docs/lib/crypto-js.js index 17f2b11..e69de29 100644 --- a/docs/lib/crypto-js.js +++ b/docs/lib/crypto-js.js @@ -1,5988 +0,0 @@ -;(function (root, factory) { - if (typeof exports === "object") { - // CommonJS - module.exports = exports = factory(); - } - else if (typeof define === "function" && define.amd) { - // AMD - define([], factory); - } - else { - // Global (browser) - root.CryptoJS = factory(); - } -}(this, function () { - - /** - * CryptoJS core components. - */ - var CryptoJS = CryptoJS || (function (Math, undefined) { - /* - * Local polyfil of Object.create - */ - var create = Object.create || (function () { - function F() {}; - - return function (obj) { - var subtype; - - F.prototype = obj; - - subtype = new F(); - - F.prototype = null; - - return subtype; - }; - }()) - - /** - * CryptoJS namespace. - */ - var C = {}; - - /** - * Library namespace. - */ - var C_lib = C.lib = {}; - - /** - * Base object for prototypal inheritance. - */ - var Base = C_lib.Base = (function () { - - - return { - /** - * Creates a new object that inherits from this object. - * - * @param {Object} overrides Properties to copy into the new object. - * - * @return {Object} The new object. - * - * @static - * - * @example - * - * var MyType = CryptoJS.lib.Base.extend({ - * field: 'value', - * - * method: function () { - * } - * }); - */ - extend: function (overrides) { - // Spawn - var subtype = create(this); - - // Augment - if (overrides) { - subtype.mixIn(overrides); - } - - // Create default initializer - if (!subtype.hasOwnProperty('init') || this.init === subtype.init) { - subtype.init = function () { - subtype.$super.init.apply(this, arguments); - }; - } - - // Initializer's prototype is the subtype object - subtype.init.prototype = subtype; - - // Reference supertype - subtype.$super = this; - - return subtype; - }, - - /** - * Extends this object and runs the init method. - * Arguments to create() will be passed to init(). - * - * @return {Object} The new object. - * - * @static - * - * @example - * - * var instance = MyType.create(); - */ - create: function () { - var instance = this.extend(); - instance.init.apply(instance, arguments); - - return instance; - }, - - /** - * Initializes a newly created object. - * Override this method to add some logic when your objects are created. - * - * @example - * - * var MyType = CryptoJS.lib.Base.extend({ - * init: function () { - * // ... - * } - * }); - */ - init: function () { - }, - - /** - * Copies properties into this object. - * - * @param {Object} properties The properties to mix in. - * - * @example - * - * MyType.mixIn({ - * field: 'value' - * }); - */ - mixIn: function (properties) { - for (var propertyName in properties) { - if (properties.hasOwnProperty(propertyName)) { - this[propertyName] = properties[propertyName]; - } - } - - // IE won't copy toString using the loop above - if (properties.hasOwnProperty('toString')) { - this.toString = properties.toString; - } - }, - - /** - * Creates a copy of this object. - * - * @return {Object} The clone. - * - * @example - * - * var clone = instance.clone(); - */ - clone: function () { - return this.init.prototype.extend(this); - } - }; - }()); - - /** - * An array of 32-bit words. - * - * @property {Array} words The array of 32-bit words. - * @property {number} sigBytes The number of significant bytes in this word array. - */ - var WordArray = C_lib.WordArray = Base.extend({ - /** - * Initializes a newly created word array. - * - * @param {Array} words (Optional) An array of 32-bit words. - * @param {number} sigBytes (Optional) The number of significant bytes in the words. - * - * @example - * - * var wordArray = CryptoJS.lib.WordArray.create(); - * var wordArray = CryptoJS.lib.WordArray.create([0x00010203, 0x04050607]); - * var wordArray = CryptoJS.lib.WordArray.create([0x00010203, 0x04050607], 6); - */ - init: function (words, sigBytes) { - words = this.words = words || []; - - if (sigBytes != undefined) { - this.sigBytes = sigBytes; - } else { - this.sigBytes = words.length * 4; - } - }, - - /** - * Converts this word array to a string. - * - * @param {Encoder} encoder (Optional) The encoding strategy to use. Default: CryptoJS.enc.Hex - * - * @return {string} The stringified word array. - * - * @example - * - * var string = wordArray + ''; - * var string = wordArray.toString(); - * var string = wordArray.toString(CryptoJS.enc.Utf8); - */ - toString: function (encoder) { - return (encoder || Hex).stringify(this); - }, - - /** - * Concatenates a word array to this word array. - * - * @param {WordArray} wordArray The word array to append. - * - * @return {WordArray} This word array. - * - * @example - * - * wordArray1.concat(wordArray2); - */ - concat: function (wordArray) { - // Shortcuts - var thisWords = this.words; - var thatWords = wordArray.words; - var thisSigBytes = this.sigBytes; - var thatSigBytes = wordArray.sigBytes; - - // Clamp excess bits - this.clamp(); - - // Concat - if (thisSigBytes % 4) { - // Copy one byte at a time - for (var i = 0; i < thatSigBytes; i++) { - var thatByte = (thatWords[i >>> 2] >>> (24 - (i % 4) * 8)) & 0xff; - thisWords[(thisSigBytes + i) >>> 2] |= thatByte << (24 - ((thisSigBytes + i) % 4) * 8); - } - } else { - // Copy one word at a time - for (var i = 0; i < thatSigBytes; i += 4) { - thisWords[(thisSigBytes + i) >>> 2] = thatWords[i >>> 2]; - } - } - this.sigBytes += thatSigBytes; - - // Chainable - return this; - }, - - /** - * Removes insignificant bits. - * - * @example - * - * wordArray.clamp(); - */ - clamp: function () { - // Shortcuts - var words = this.words; - var sigBytes = this.sigBytes; - - // Clamp - words[sigBytes >>> 2] &= 0xffffffff << (32 - (sigBytes % 4) * 8); - words.length = Math.ceil(sigBytes / 4); - }, - - /** - * Creates a copy of this word array. - * - * @return {WordArray} The clone. - * - * @example - * - * var clone = wordArray.clone(); - */ - clone: function () { - var clone = Base.clone.call(this); - clone.words = this.words.slice(0); - - return clone; - }, - - /** - * Creates a word array filled with random bytes. - * - * @param {number} nBytes The number of random bytes to generate. - * - * @return {WordArray} The random word array. - * - * @static - * - * @example - * - * var wordArray = CryptoJS.lib.WordArray.random(16); - */ - random: function (nBytes) { - var words = []; - - var r = (function (m_w) { - var m_w = m_w; - var m_z = 0x3ade68b1; - var mask = 0xffffffff; - - return function () { - m_z = (0x9069 * (m_z & 0xFFFF) + (m_z >> 0x10)) & mask; - m_w = (0x4650 * (m_w & 0xFFFF) + (m_w >> 0x10)) & mask; - var result = ((m_z << 0x10) + m_w) & mask; - result /= 0x100000000; - result += 0.5; - return result * (Math.random() > .5 ? 1 : -1); - } - }); - - for (var i = 0, rcache; i < nBytes; i += 4) { - var _r = r((rcache || Math.random()) * 0x100000000); - - rcache = _r() * 0x3ade67b7; - words.push((_r() * 0x100000000) | 0); - } - - return new WordArray.init(words, nBytes); - } - }); - - /** - * Encoder namespace. - */ - var C_enc = C.enc = {}; - - /** - * Hex encoding strategy. - */ - var Hex = C_enc.Hex = { - /** - * Converts a word array to a hex string. - * - * @param {WordArray} wordArray The word array. - * - * @return {string} The hex string. - * - * @static - * - * @example - * - * var hexString = CryptoJS.enc.Hex.stringify(wordArray); - */ - stringify: function (wordArray) { - // Shortcuts - var words = wordArray.words; - var sigBytes = wordArray.sigBytes; - - // Convert - var hexChars = []; - for (var i = 0; i < sigBytes; i++) { - var bite = (words[i >>> 2] >>> (24 - (i % 4) * 8)) & 0xff; - hexChars.push((bite >>> 4).toString(16)); - hexChars.push((bite & 0x0f).toString(16)); - } - - return hexChars.join(''); - }, - - /** - * Converts a hex string to a word array. - * - * @param {string} hexStr The hex string. - * - * @return {WordArray} The word array. - * - * @static - * - * @example - * - * var wordArray = CryptoJS.enc.Hex.parse(hexString); - */ - parse: function (hexStr) { - // Shortcut - var hexStrLength = hexStr.length; - - // Convert - var words = []; - for (var i = 0; i < hexStrLength; i += 2) { - words[i >>> 3] |= parseInt(hexStr.substr(i, 2), 16) << (24 - (i % 8) * 4); - } - - return new WordArray.init(words, hexStrLength / 2); - } - }; - - /** - * Latin1 encoding strategy. - */ - var Latin1 = C_enc.Latin1 = { - /** - * Converts a word array to a Latin1 string. - * - * @param {WordArray} wordArray The word array. - * - * @return {string} The Latin1 string. - * - * @static - * - * @example - * - * var latin1String = CryptoJS.enc.Latin1.stringify(wordArray); - */ - stringify: function (wordArray) { - // Shortcuts - var words = wordArray.words; - var sigBytes = wordArray.sigBytes; - - // Convert - var latin1Chars = []; - for (var i = 0; i < sigBytes; i++) { - var bite = (words[i >>> 2] >>> (24 - (i % 4) * 8)) & 0xff; - latin1Chars.push(String.fromCharCode(bite)); - } - - return latin1Chars.join(''); - }, - - /** - * Converts a Latin1 string to a word array. - * - * @param {string} latin1Str The Latin1 string. - * - * @return {WordArray} The word array. - * - * @static - * - * @example - * - * var wordArray = CryptoJS.enc.Latin1.parse(latin1String); - */ - parse: function (latin1Str) { - // Shortcut - var latin1StrLength = latin1Str.length; - - // Convert - var words = []; - for (var i = 0; i < latin1StrLength; i++) { - words[i >>> 2] |= (latin1Str.charCodeAt(i) & 0xff) << (24 - (i % 4) * 8); - } - - return new WordArray.init(words, latin1StrLength); - } - }; - - /** - * UTF-8 encoding strategy. - */ - var Utf8 = C_enc.Utf8 = { - /** - * Converts a word array to a UTF-8 string. - * - * @param {WordArray} wordArray The word array. - * - * @return {string} The UTF-8 string. - * - * @static - * - * @example - * - * var utf8String = CryptoJS.enc.Utf8.stringify(wordArray); - */ - stringify: function (wordArray) { - try { - return decodeURIComponent(escape(Latin1.stringify(wordArray))); - } catch (e) { - throw new Error('Malformed UTF-8 data'); - } - }, - - /** - * Converts a UTF-8 string to a word array. - * - * @param {string} utf8Str The UTF-8 string. - * - * @return {WordArray} The word array. - * - * @static - * - * @example - * - * var wordArray = CryptoJS.enc.Utf8.parse(utf8String); - */ - parse: function (utf8Str) { - return Latin1.parse(unescape(encodeURIComponent(utf8Str))); - } - }; - - /** - * Abstract buffered block algorithm template. - * - * The property blockSize must be implemented in a concrete subtype. - * - * @property {number} _minBufferSize The number of blocks that should be kept unprocessed in the buffer. Default: 0 - */ - var BufferedBlockAlgorithm = C_lib.BufferedBlockAlgorithm = Base.extend({ - /** - * Resets this block algorithm's data buffer to its initial state. - * - * @example - * - * bufferedBlockAlgorithm.reset(); - */ - reset: function () { - // Initial values - this._data = new WordArray.init(); - this._nDataBytes = 0; - }, - - /** - * Adds new data to this block algorithm's buffer. - * - * @param {WordArray|string} data The data to append. Strings are converted to a WordArray using UTF-8. - * - * @example - * - * bufferedBlockAlgorithm._append('data'); - * bufferedBlockAlgorithm._append(wordArray); - */ - _append: function (data) { - // Convert string to WordArray, else assume WordArray already - if (typeof data == 'string') { - data = Utf8.parse(data); - } - - // Append - this._data.concat(data); - this._nDataBytes += data.sigBytes; - }, - - /** - * Processes available data blocks. - * - * This method invokes _doProcessBlock(offset), which must be implemented by a concrete subtype. - * - * @param {boolean} doFlush Whether all blocks and partial blocks should be processed. - * - * @return {WordArray} The processed data. - * - * @example - * - * var processedData = bufferedBlockAlgorithm._process(); - * var processedData = bufferedBlockAlgorithm._process(!!'flush'); - */ - _process: function (doFlush) { - // Shortcuts - var data = this._data; - var dataWords = data.words; - var dataSigBytes = data.sigBytes; - var blockSize = this.blockSize; - var blockSizeBytes = blockSize * 4; - - // Count blocks ready - var nBlocksReady = dataSigBytes / blockSizeBytes; - if (doFlush) { - // Round up to include partial blocks - nBlocksReady = Math.ceil(nBlocksReady); - } else { - // Round down to include only full blocks, - // less the number of blocks that must remain in the buffer - nBlocksReady = Math.max((nBlocksReady | 0) - this._minBufferSize, 0); - } - - // Count words ready - var nWordsReady = nBlocksReady * blockSize; - - // Count bytes ready - var nBytesReady = Math.min(nWordsReady * 4, dataSigBytes); - - // Process blocks - if (nWordsReady) { - for (var offset = 0; offset < nWordsReady; offset += blockSize) { - // Perform concrete-algorithm logic - this._doProcessBlock(dataWords, offset); - } - - // Remove processed words - var processedWords = dataWords.splice(0, nWordsReady); - data.sigBytes -= nBytesReady; - } - - // Return processed words - return new WordArray.init(processedWords, nBytesReady); - }, - - /** - * Creates a copy of this object. - * - * @return {Object} The clone. - * - * @example - * - * var clone = bufferedBlockAlgorithm.clone(); - */ - clone: function () { - var clone = Base.clone.call(this); - clone._data = this._data.clone(); - - return clone; - }, - - _minBufferSize: 0 - }); - - /** - * Abstract hasher template. - * - * @property {number} blockSize The number of 32-bit words this hasher operates on. Default: 16 (512 bits) - */ - var Hasher = C_lib.Hasher = BufferedBlockAlgorithm.extend({ - /** - * Configuration options. - */ - cfg: Base.extend(), - - /** - * Initializes a newly created hasher. - * - * @param {Object} cfg (Optional) The configuration options to use for this hash computation. - * - * @example - * - * var hasher = CryptoJS.algo.SHA256.create(); - */ - init: function (cfg) { - // Apply config defaults - this.cfg = this.cfg.extend(cfg); - - // Set initial values - this.reset(); - }, - - /** - * Resets this hasher to its initial state. - * - * @example - * - * hasher.reset(); - */ - reset: function () { - // Reset data buffer - BufferedBlockAlgorithm.reset.call(this); - - // Perform concrete-hasher logic - this._doReset(); - }, - - /** - * Updates this hasher with a message. - * - * @param {WordArray|string} messageUpdate The message to append. - * - * @return {Hasher} This hasher. - * - * @example - * - * hasher.update('message'); - * hasher.update(wordArray); - */ - update: function (messageUpdate) { - // Append - this._append(messageUpdate); - - // Update the hash - this._process(); - - // Chainable - return this; - }, - - /** - * Finalizes the hash computation. - * Note that the finalize operation is effectively a destructive, read-once operation. - * - * @param {WordArray|string} messageUpdate (Optional) A final message update. - * - * @return {WordArray} The hash. - * - * @example - * - * var hash = hasher.finalize(); - * var hash = hasher.finalize('message'); - * var hash = hasher.finalize(wordArray); - */ - finalize: function (messageUpdate) { - // Final message update - if (messageUpdate) { - this._append(messageUpdate); - } - - // Perform concrete-hasher logic - var hash = this._doFinalize(); - - return hash; - }, - - blockSize: 512/32, - - /** - * Creates a shortcut function to a hasher's object interface. - * - * @param {Hasher} hasher The hasher to create a helper for. - * - * @return {Function} The shortcut function. - * - * @static - * - * @example - * - * var SHA256 = CryptoJS.lib.Hasher._createHelper(CryptoJS.algo.SHA256); - */ - _createHelper: function (hasher) { - return function (message, cfg) { - return new hasher.init(cfg).finalize(message); - }; - }, - - /** - * Creates a shortcut function to the HMAC's object interface. - * - * @param {Hasher} hasher The hasher to use in this HMAC helper. - * - * @return {Function} The shortcut function. - * - * @static - * - * @example - * - * var HmacSHA256 = CryptoJS.lib.Hasher._createHmacHelper(CryptoJS.algo.SHA256); - */ - _createHmacHelper: function (hasher) { - return function (message, key) { - return new C_algo.HMAC.init(hasher, key).finalize(message); - }; - } - }); - - /** - * Algorithm namespace. - */ - var C_algo = C.algo = {}; - - return C; - }(Math)); - - - (function () { - // Shortcuts - var C = CryptoJS; - var C_lib = C.lib; - var WordArray = C_lib.WordArray; - var C_enc = C.enc; - - /** - * Base64 encoding strategy. - */ - var Base64 = C_enc.Base64 = { - /** - * Converts a word array to a Base64 string. - * - * @param {WordArray} wordArray The word array. - * - * @return {string} The Base64 string. - * - * @static - * - * @example - * - * var base64String = CryptoJS.enc.Base64.stringify(wordArray); - */ - stringify: function (wordArray) { - // Shortcuts - var words = wordArray.words; - var sigBytes = wordArray.sigBytes; - var map = this._map; - - // Clamp excess bits - wordArray.clamp(); - - // Convert - var base64Chars = []; - for (var i = 0; i < sigBytes; i += 3) { - var byte1 = (words[i >>> 2] >>> (24 - (i % 4) * 8)) & 0xff; - var byte2 = (words[(i + 1) >>> 2] >>> (24 - ((i + 1) % 4) * 8)) & 0xff; - var byte3 = (words[(i + 2) >>> 2] >>> (24 - ((i + 2) % 4) * 8)) & 0xff; - - var triplet = (byte1 << 16) | (byte2 << 8) | byte3; - - for (var j = 0; (j < 4) && (i + j * 0.75 < sigBytes); j++) { - base64Chars.push(map.charAt((triplet >>> (6 * (3 - j))) & 0x3f)); - } - } - - // Add padding - var paddingChar = map.charAt(64); - if (paddingChar) { - while (base64Chars.length % 4) { - base64Chars.push(paddingChar); - } - } - - return base64Chars.join(''); - }, - - /** - * Converts a Base64 string to a word array. - * - * @param {string} base64Str The Base64 string. - * - * @return {WordArray} The word array. - * - * @static - * - * @example - * - * var wordArray = CryptoJS.enc.Base64.parse(base64String); - */ - parse: function (base64Str) { - // Shortcuts - var base64StrLength = base64Str.length; - var map = this._map; - var reverseMap = this._reverseMap; - - if (!reverseMap) { - reverseMap = this._reverseMap = []; - for (var j = 0; j < map.length; j++) { - reverseMap[map.charCodeAt(j)] = j; - } - } - - // Ignore padding - var paddingChar = map.charAt(64); - if (paddingChar) { - var paddingIndex = base64Str.indexOf(paddingChar); - if (paddingIndex !== -1) { - base64StrLength = paddingIndex; - } - } - - // Convert - return parseLoop(base64Str, base64StrLength, reverseMap); - - }, - - _map: 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=' - }; - - function parseLoop(base64Str, base64StrLength, reverseMap) { - var words = []; - var nBytes = 0; - for (var i = 0; i < base64StrLength; i++) { - if (i % 4) { - var bits1 = reverseMap[base64Str.charCodeAt(i - 1)] << ((i % 4) * 2); - var bits2 = reverseMap[base64Str.charCodeAt(i)] >>> (6 - (i % 4) * 2); - words[nBytes >>> 2] |= (bits1 | bits2) << (24 - (nBytes % 4) * 8); - nBytes++; - } - } - return WordArray.create(words, nBytes); - } - }()); - - - (function (Math) { - // Shortcuts - var C = CryptoJS; - var C_lib = C.lib; - var WordArray = C_lib.WordArray; - var Hasher = C_lib.Hasher; - var C_algo = C.algo; - - // Constants table - var T = []; - - // Compute constants - (function () { - for (var i = 0; i < 64; i++) { - T[i] = (Math.abs(Math.sin(i + 1)) * 0x100000000) | 0; - } - }()); - - /** - * MD5 hash algorithm. - */ - var MD5 = C_algo.MD5 = Hasher.extend({ - _doReset: function () { - this._hash = new WordArray.init([ - 0x67452301, 0xefcdab89, - 0x98badcfe, 0x10325476 - ]); - }, - - _doProcessBlock: function (M, offset) { - // Swap endian - for (var i = 0; i < 16; i++) { - // Shortcuts - var offset_i = offset + i; - var M_offset_i = M[offset_i]; - - M[offset_i] = ( - (((M_offset_i << 8) | (M_offset_i >>> 24)) & 0x00ff00ff) | - (((M_offset_i << 24) | (M_offset_i >>> 8)) & 0xff00ff00) - ); - } - - // Shortcuts - var H = this._hash.words; - - var M_offset_0 = M[offset + 0]; - var M_offset_1 = M[offset + 1]; - var M_offset_2 = M[offset + 2]; - var M_offset_3 = M[offset + 3]; - var M_offset_4 = M[offset + 4]; - var M_offset_5 = M[offset + 5]; - var M_offset_6 = M[offset + 6]; - var M_offset_7 = M[offset + 7]; - var M_offset_8 = M[offset + 8]; - var M_offset_9 = M[offset + 9]; - var M_offset_10 = M[offset + 10]; - var M_offset_11 = M[offset + 11]; - var M_offset_12 = M[offset + 12]; - var M_offset_13 = M[offset + 13]; - var M_offset_14 = M[offset + 14]; - var M_offset_15 = M[offset + 15]; - - // Working varialbes - var a = H[0]; - var b = H[1]; - var c = H[2]; - var d = H[3]; - - // Computation - a = FF(a, b, c, d, M_offset_0, 7, T[0]); - d = FF(d, a, b, c, M_offset_1, 12, T[1]); - c = FF(c, d, a, b, M_offset_2, 17, T[2]); - b = FF(b, c, d, a, M_offset_3, 22, T[3]); - a = FF(a, b, c, d, M_offset_4, 7, T[4]); - d = FF(d, a, b, c, M_offset_5, 12, T[5]); - c = FF(c, d, a, b, M_offset_6, 17, T[6]); - b = FF(b, c, d, a, M_offset_7, 22, T[7]); - a = FF(a, b, c, d, M_offset_8, 7, T[8]); - d = FF(d, a, b, c, M_offset_9, 12, T[9]); - c = FF(c, d, a, b, M_offset_10, 17, T[10]); - b = FF(b, c, d, a, M_offset_11, 22, T[11]); - a = FF(a, b, c, d, M_offset_12, 7, T[12]); - d = FF(d, a, b, c, M_offset_13, 12, T[13]); - c = FF(c, d, a, b, M_offset_14, 17, T[14]); - b = FF(b, c, d, a, M_offset_15, 22, T[15]); - - a = GG(a, b, c, d, M_offset_1, 5, T[16]); - d = GG(d, a, b, c, M_offset_6, 9, T[17]); - c = GG(c, d, a, b, M_offset_11, 14, T[18]); - b = GG(b, c, d, a, M_offset_0, 20, T[19]); - a = GG(a, b, c, d, M_offset_5, 5, T[20]); - d = GG(d, a, b, c, M_offset_10, 9, T[21]); - c = GG(c, d, a, b, M_offset_15, 14, T[22]); - b = GG(b, c, d, a, M_offset_4, 20, T[23]); - a = GG(a, b, c, d, M_offset_9, 5, T[24]); - d = GG(d, a, b, c, M_offset_14, 9, T[25]); - c = GG(c, d, a, b, M_offset_3, 14, T[26]); - b = GG(b, c, d, a, M_offset_8, 20, T[27]); - a = GG(a, b, c, d, M_offset_13, 5, T[28]); - d = GG(d, a, b, c, M_offset_2, 9, T[29]); - c = GG(c, d, a, b, M_offset_7, 14, T[30]); - b = GG(b, c, d, a, M_offset_12, 20, T[31]); - - a = HH(a, b, c, d, M_offset_5, 4, T[32]); - d = HH(d, a, b, c, M_offset_8, 11, T[33]); - c = HH(c, d, a, b, M_offset_11, 16, T[34]); - b = HH(b, c, d, a, M_offset_14, 23, T[35]); - a = HH(a, b, c, d, M_offset_1, 4, T[36]); - d = HH(d, a, b, c, M_offset_4, 11, T[37]); - c = HH(c, d, a, b, M_offset_7, 16, T[38]); - b = HH(b, c, d, a, M_offset_10, 23, T[39]); - a = HH(a, b, c, d, M_offset_13, 4, T[40]); - d = HH(d, a, b, c, M_offset_0, 11, T[41]); - c = HH(c, d, a, b, M_offset_3, 16, T[42]); - b = HH(b, c, d, a, M_offset_6, 23, T[43]); - a = HH(a, b, c, d, M_offset_9, 4, T[44]); - d = HH(d, a, b, c, M_offset_12, 11, T[45]); - c = HH(c, d, a, b, M_offset_15, 16, T[46]); - b = HH(b, c, d, a, M_offset_2, 23, T[47]); - - a = II(a, b, c, d, M_offset_0, 6, T[48]); - d = II(d, a, b, c, M_offset_7, 10, T[49]); - c = II(c, d, a, b, M_offset_14, 15, T[50]); - b = II(b, c, d, a, M_offset_5, 21, T[51]); - a = II(a, b, c, d, M_offset_12, 6, T[52]); - d = II(d, a, b, c, M_offset_3, 10, T[53]); - c = II(c, d, a, b, M_offset_10, 15, T[54]); - b = II(b, c, d, a, M_offset_1, 21, T[55]); - a = II(a, b, c, d, M_offset_8, 6, T[56]); - d = II(d, a, b, c, M_offset_15, 10, T[57]); - c = II(c, d, a, b, M_offset_6, 15, T[58]); - b = II(b, c, d, a, M_offset_13, 21, T[59]); - a = II(a, b, c, d, M_offset_4, 6, T[60]); - d = II(d, a, b, c, M_offset_11, 10, T[61]); - c = II(c, d, a, b, M_offset_2, 15, T[62]); - b = II(b, c, d, a, M_offset_9, 21, T[63]); - - // Intermediate hash value - H[0] = (H[0] + a) | 0; - H[1] = (H[1] + b) | 0; - H[2] = (H[2] + c) | 0; - H[3] = (H[3] + d) | 0; - }, - - _doFinalize: function () { - // Shortcuts - var data = this._data; - var dataWords = data.words; - - var nBitsTotal = this._nDataBytes * 8; - var nBitsLeft = data.sigBytes * 8; - - // Add padding - dataWords[nBitsLeft >>> 5] |= 0x80 << (24 - nBitsLeft % 32); - - var nBitsTotalH = Math.floor(nBitsTotal / 0x100000000); - var nBitsTotalL = nBitsTotal; - dataWords[(((nBitsLeft + 64) >>> 9) << 4) + 15] = ( - (((nBitsTotalH << 8) | (nBitsTotalH >>> 24)) & 0x00ff00ff) | - (((nBitsTotalH << 24) | (nBitsTotalH >>> 8)) & 0xff00ff00) - ); - dataWords[(((nBitsLeft + 64) >>> 9) << 4) + 14] = ( - (((nBitsTotalL << 8) | (nBitsTotalL >>> 24)) & 0x00ff00ff) | - (((nBitsTotalL << 24) | (nBitsTotalL >>> 8)) & 0xff00ff00) - ); - - data.sigBytes = (dataWords.length + 1) * 4; - - // Hash final blocks - this._process(); - - // Shortcuts - var hash = this._hash; - var H = hash.words; - - // Swap endian - for (var i = 0; i < 4; i++) { - // Shortcut - var H_i = H[i]; - - H[i] = (((H_i << 8) | (H_i >>> 24)) & 0x00ff00ff) | - (((H_i << 24) | (H_i >>> 8)) & 0xff00ff00); - } - - // Return final computed hash - return hash; - }, - - clone: function () { - var clone = Hasher.clone.call(this); - clone._hash = this._hash.clone(); - - return clone; - } - }); - - function FF(a, b, c, d, x, s, t) { - var n = a + ((b & c) | (~b & d)) + x + t; - return ((n << s) | (n >>> (32 - s))) + b; - } - - function GG(a, b, c, d, x, s, t) { - var n = a + ((b & d) | (c & ~d)) + x + t; - return ((n << s) | (n >>> (32 - s))) + b; - } - - function HH(a, b, c, d, x, s, t) { - var n = a + (b ^ c ^ d) + x + t; - return ((n << s) | (n >>> (32 - s))) + b; - } - - function II(a, b, c, d, x, s, t) { - var n = a + (c ^ (b | ~d)) + x + t; - return ((n << s) | (n >>> (32 - s))) + b; - } - - /** - * Shortcut function to the hasher's object interface. - * - * @param {WordArray|string} message The message to hash. - * - * @return {WordArray} The hash. - * - * @static - * - * @example - * - * var hash = CryptoJS.MD5('message'); - * var hash = CryptoJS.MD5(wordArray); - */ - C.MD5 = Hasher._createHelper(MD5); - - /** - * Shortcut function to the HMAC's object interface. - * - * @param {WordArray|string} message The message to hash. - * @param {WordArray|string} key The secret key. - * - * @return {WordArray} The HMAC. - * - * @static - * - * @example - * - * var hmac = CryptoJS.HmacMD5(message, key); - */ - C.HmacMD5 = Hasher._createHmacHelper(MD5); - }(Math)); - - - (function () { - // Shortcuts - var C = CryptoJS; - var C_lib = C.lib; - var WordArray = C_lib.WordArray; - var Hasher = C_lib.Hasher; - var C_algo = C.algo; - - // Reusable object - var W = []; - - /** - * SHA-1 hash algorithm. - */ - var SHA1 = C_algo.SHA1 = Hasher.extend({ - _doReset: function () { - this._hash = new WordArray.init([ - 0x67452301, 0xefcdab89, - 0x98badcfe, 0x10325476, - 0xc3d2e1f0 - ]); - }, - - _doProcessBlock: function (M, offset) { - // Shortcut - var H = this._hash.words; - - // Working variables - var a = H[0]; - var b = H[1]; - var c = H[2]; - var d = H[3]; - var e = H[4]; - - // Computation - for (var i = 0; i < 80; i++) { - if (i < 16) { - W[i] = M[offset + i] | 0; - } else { - var n = W[i - 3] ^ W[i - 8] ^ W[i - 14] ^ W[i - 16]; - W[i] = (n << 1) | (n >>> 31); - } - - var t = ((a << 5) | (a >>> 27)) + e + W[i]; - if (i < 20) { - t += ((b & c) | (~b & d)) + 0x5a827999; - } else if (i < 40) { - t += (b ^ c ^ d) + 0x6ed9eba1; - } else if (i < 60) { - t += ((b & c) | (b & d) | (c & d)) - 0x70e44324; - } else /* if (i < 80) */ { - t += (b ^ c ^ d) - 0x359d3e2a; - } - - e = d; - d = c; - c = (b << 30) | (b >>> 2); - b = a; - a = t; - } - - // Intermediate hash value - H[0] = (H[0] + a) | 0; - H[1] = (H[1] + b) | 0; - H[2] = (H[2] + c) | 0; - H[3] = (H[3] + d) | 0; - H[4] = (H[4] + e) | 0; - }, - - _doFinalize: function () { - // Shortcuts - var data = this._data; - var dataWords = data.words; - - var nBitsTotal = this._nDataBytes * 8; - var nBitsLeft = data.sigBytes * 8; - - // Add padding - dataWords[nBitsLeft >>> 5] |= 0x80 << (24 - nBitsLeft % 32); - dataWords[(((nBitsLeft + 64) >>> 9) << 4) + 14] = Math.floor(nBitsTotal / 0x100000000); - dataWords[(((nBitsLeft + 64) >>> 9) << 4) + 15] = nBitsTotal; - data.sigBytes = dataWords.length * 4; - - // Hash final blocks - this._process(); - - // Return final computed hash - return this._hash; - }, - - clone: function () { - var clone = Hasher.clone.call(this); - clone._hash = this._hash.clone(); - - return clone; - } - }); - - /** - * Shortcut function to the hasher's object interface. - * - * @param {WordArray|string} message The message to hash. - * - * @return {WordArray} The hash. - * - * @static - * - * @example - * - * var hash = CryptoJS.SHA1('message'); - * var hash = CryptoJS.SHA1(wordArray); - */ - C.SHA1 = Hasher._createHelper(SHA1); - - /** - * Shortcut function to the HMAC's object interface. - * - * @param {WordArray|string} message The message to hash. - * @param {WordArray|string} key The secret key. - * - * @return {WordArray} The HMAC. - * - * @static - * - * @example - * - * var hmac = CryptoJS.HmacSHA1(message, key); - */ - C.HmacSHA1 = Hasher._createHmacHelper(SHA1); - }()); - - - (function (Math) { - // Shortcuts - var C = CryptoJS; - var C_lib = C.lib; - var WordArray = C_lib.WordArray; - var Hasher = C_lib.Hasher; - var C_algo = C.algo; - - // Initialization and round constants tables - var H = []; - var K = []; - - // Compute constants - (function () { - function isPrime(n) { - var sqrtN = Math.sqrt(n); - for (var factor = 2; factor <= sqrtN; factor++) { - if (!(n % factor)) { - return false; - } - } - - return true; - } - - function getFractionalBits(n) { - return ((n - (n | 0)) * 0x100000000) | 0; - } - - var n = 2; - var nPrime = 0; - while (nPrime < 64) { - if (isPrime(n)) { - if (nPrime < 8) { - H[nPrime] = getFractionalBits(Math.pow(n, 1 / 2)); - } - K[nPrime] = getFractionalBits(Math.pow(n, 1 / 3)); - - nPrime++; - } - - n++; - } - }()); - - // Reusable object - var W = []; - - /** - * SHA-256 hash algorithm. - */ - var SHA256 = C_algo.SHA256 = Hasher.extend({ - _doReset: function () { - this._hash = new WordArray.init(H.slice(0)); - }, - - _doProcessBlock: function (M, offset) { - // Shortcut - var H = this._hash.words; - - // Working variables - var a = H[0]; - var b = H[1]; - var c = H[2]; - var d = H[3]; - var e = H[4]; - var f = H[5]; - var g = H[6]; - var h = H[7]; - - // Computation - for (var i = 0; i < 64; i++) { - if (i < 16) { - W[i] = M[offset + i] | 0; - } else { - var gamma0x = W[i - 15]; - var gamma0 = ((gamma0x << 25) | (gamma0x >>> 7)) ^ - ((gamma0x << 14) | (gamma0x >>> 18)) ^ - (gamma0x >>> 3); - - var gamma1x = W[i - 2]; - var gamma1 = ((gamma1x << 15) | (gamma1x >>> 17)) ^ - ((gamma1x << 13) | (gamma1x >>> 19)) ^ - (gamma1x >>> 10); - - W[i] = gamma0 + W[i - 7] + gamma1 + W[i - 16]; - } - - var ch = (e & f) ^ (~e & g); - var maj = (a & b) ^ (a & c) ^ (b & c); - - var sigma0 = ((a << 30) | (a >>> 2)) ^ ((a << 19) | (a >>> 13)) ^ ((a << 10) | (a >>> 22)); - var sigma1 = ((e << 26) | (e >>> 6)) ^ ((e << 21) | (e >>> 11)) ^ ((e << 7) | (e >>> 25)); - - var t1 = h + sigma1 + ch + K[i] + W[i]; - var t2 = sigma0 + maj; - - h = g; - g = f; - f = e; - e = (d + t1) | 0; - d = c; - c = b; - b = a; - a = (t1 + t2) | 0; - } - - // Intermediate hash value - H[0] = (H[0] + a) | 0; - H[1] = (H[1] + b) | 0; - H[2] = (H[2] + c) | 0; - H[3] = (H[3] + d) | 0; - H[4] = (H[4] + e) | 0; - H[5] = (H[5] + f) | 0; - H[6] = (H[6] + g) | 0; - H[7] = (H[7] + h) | 0; - }, - - _doFinalize: function () { - // Shortcuts - var data = this._data; - var dataWords = data.words; - - var nBitsTotal = this._nDataBytes * 8; - var nBitsLeft = data.sigBytes * 8; - - // Add padding - dataWords[nBitsLeft >>> 5] |= 0x80 << (24 - nBitsLeft % 32); - dataWords[(((nBitsLeft + 64) >>> 9) << 4) + 14] = Math.floor(nBitsTotal / 0x100000000); - dataWords[(((nBitsLeft + 64) >>> 9) << 4) + 15] = nBitsTotal; - data.sigBytes = dataWords.length * 4; - - // Hash final blocks - this._process(); - - // Return final computed hash - return this._hash; - }, - - clone: function () { - var clone = Hasher.clone.call(this); - clone._hash = this._hash.clone(); - - return clone; - } - }); - - /** - * Shortcut function to the hasher's object interface. - * - * @param {WordArray|string} message The message to hash. - * - * @return {WordArray} The hash. - * - * @static - * - * @example - * - * var hash = CryptoJS.SHA256('message'); - * var hash = CryptoJS.SHA256(wordArray); - */ - C.SHA256 = Hasher._createHelper(SHA256); - - /** - * Shortcut function to the HMAC's object interface. - * - * @param {WordArray|string} message The message to hash. - * @param {WordArray|string} key The secret key. - * - * @return {WordArray} The HMAC. - * - * @static - * - * @example - * - * var hmac = CryptoJS.HmacSHA256(message, key); - */ - C.HmacSHA256 = Hasher._createHmacHelper(SHA256); - }(Math)); - - - (function () { - // Shortcuts - var C = CryptoJS; - var C_lib = C.lib; - var WordArray = C_lib.WordArray; - var C_enc = C.enc; - - /** - * UTF-16 BE encoding strategy. - */ - var Utf16BE = C_enc.Utf16 = C_enc.Utf16BE = { - /** - * Converts a word array to a UTF-16 BE string. - * - * @param {WordArray} wordArray The word array. - * - * @return {string} The UTF-16 BE string. - * - * @static - * - * @example - * - * var utf16String = CryptoJS.enc.Utf16.stringify(wordArray); - */ - stringify: function (wordArray) { - // Shortcuts - var words = wordArray.words; - var sigBytes = wordArray.sigBytes; - - // Convert - var utf16Chars = []; - for (var i = 0; i < sigBytes; i += 2) { - var codePoint = (words[i >>> 2] >>> (16 - (i % 4) * 8)) & 0xffff; - utf16Chars.push(String.fromCharCode(codePoint)); - } - - return utf16Chars.join(''); - }, - - /** - * Converts a UTF-16 BE string to a word array. - * - * @param {string} utf16Str The UTF-16 BE string. - * - * @return {WordArray} The word array. - * - * @static - * - * @example - * - * var wordArray = CryptoJS.enc.Utf16.parse(utf16String); - */ - parse: function (utf16Str) { - // Shortcut - var utf16StrLength = utf16Str.length; - - // Convert - var words = []; - for (var i = 0; i < utf16StrLength; i++) { - words[i >>> 1] |= utf16Str.charCodeAt(i) << (16 - (i % 2) * 16); - } - - return WordArray.create(words, utf16StrLength * 2); - } - }; - - /** - * UTF-16 LE encoding strategy. - */ - C_enc.Utf16LE = { - /** - * Converts a word array to a UTF-16 LE string. - * - * @param {WordArray} wordArray The word array. - * - * @return {string} The UTF-16 LE string. - * - * @static - * - * @example - * - * var utf16Str = CryptoJS.enc.Utf16LE.stringify(wordArray); - */ - stringify: function (wordArray) { - // Shortcuts - var words = wordArray.words; - var sigBytes = wordArray.sigBytes; - - // Convert - var utf16Chars = []; - for (var i = 0; i < sigBytes; i += 2) { - var codePoint = swapEndian((words[i >>> 2] >>> (16 - (i % 4) * 8)) & 0xffff); - utf16Chars.push(String.fromCharCode(codePoint)); - } - - return utf16Chars.join(''); - }, - - /** - * Converts a UTF-16 LE string to a word array. - * - * @param {string} utf16Str The UTF-16 LE string. - * - * @return {WordArray} The word array. - * - * @static - * - * @example - * - * var wordArray = CryptoJS.enc.Utf16LE.parse(utf16Str); - */ - parse: function (utf16Str) { - // Shortcut - var utf16StrLength = utf16Str.length; - - // Convert - var words = []; - for (var i = 0; i < utf16StrLength; i++) { - words[i >>> 1] |= swapEndian(utf16Str.charCodeAt(i) << (16 - (i % 2) * 16)); - } - - return WordArray.create(words, utf16StrLength * 2); - } - }; - - function swapEndian(word) { - return ((word << 8) & 0xff00ff00) | ((word >>> 8) & 0x00ff00ff); - } - }()); - - - (function () { - // Check if typed arrays are supported - if (typeof ArrayBuffer != 'function') { - return; - } - - // Shortcuts - var C = CryptoJS; - var C_lib = C.lib; - var WordArray = C_lib.WordArray; - - // Reference original init - var superInit = WordArray.init; - - // Augment WordArray.init to handle typed arrays - var subInit = WordArray.init = function (typedArray) { - // Convert buffers to uint8 - if (typedArray instanceof ArrayBuffer) { - typedArray = new Uint8Array(typedArray); - } - - // Convert other array views to uint8 - if ( - typedArray instanceof Int8Array || - (typeof Uint8ClampedArray !== "undefined" && typedArray instanceof Uint8ClampedArray) || - typedArray instanceof Int16Array || - typedArray instanceof Uint16Array || - typedArray instanceof Int32Array || - typedArray instanceof Uint32Array || - typedArray instanceof Float32Array || - typedArray instanceof Float64Array - ) { - typedArray = new Uint8Array(typedArray.buffer, typedArray.byteOffset, typedArray.byteLength); - } - - // Handle Uint8Array - if (typedArray instanceof Uint8Array) { - // Shortcut - var typedArrayByteLength = typedArray.byteLength; - - // Extract bytes - var words = []; - for (var i = 0; i < typedArrayByteLength; i++) { - words[i >>> 2] |= typedArray[i] << (24 - (i % 4) * 8); - } - - // Initialize this word array - superInit.call(this, words, typedArrayByteLength); - } else { - // Else call normal init - superInit.apply(this, arguments); - } - }; - - subInit.prototype = WordArray; - }()); - - - /** @preserve - (c) 2012 by Cédric Mesnil. All rights reserved. - - Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met: - - - Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer. - - Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution. - - THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - */ - - (function (Math) { - // Shortcuts - var C = CryptoJS; - var C_lib = C.lib; - var WordArray = C_lib.WordArray; - var Hasher = C_lib.Hasher; - var C_algo = C.algo; - - // Constants table - var _zl = WordArray.create([ - 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, - 7, 4, 13, 1, 10, 6, 15, 3, 12, 0, 9, 5, 2, 14, 11, 8, - 3, 10, 14, 4, 9, 15, 8, 1, 2, 7, 0, 6, 13, 11, 5, 12, - 1, 9, 11, 10, 0, 8, 12, 4, 13, 3, 7, 15, 14, 5, 6, 2, - 4, 0, 5, 9, 7, 12, 2, 10, 14, 1, 3, 8, 11, 6, 15, 13]); - var _zr = WordArray.create([ - 5, 14, 7, 0, 9, 2, 11, 4, 13, 6, 15, 8, 1, 10, 3, 12, - 6, 11, 3, 7, 0, 13, 5, 10, 14, 15, 8, 12, 4, 9, 1, 2, - 15, 5, 1, 3, 7, 14, 6, 9, 11, 8, 12, 2, 10, 0, 4, 13, - 8, 6, 4, 1, 3, 11, 15, 0, 5, 12, 2, 13, 9, 7, 10, 14, - 12, 15, 10, 4, 1, 5, 8, 7, 6, 2, 13, 14, 0, 3, 9, 11]); - var _sl = WordArray.create([ - 11, 14, 15, 12, 5, 8, 7, 9, 11, 13, 14, 15, 6, 7, 9, 8, - 7, 6, 8, 13, 11, 9, 7, 15, 7, 12, 15, 9, 11, 7, 13, 12, - 11, 13, 6, 7, 14, 9, 13, 15, 14, 8, 13, 6, 5, 12, 7, 5, - 11, 12, 14, 15, 14, 15, 9, 8, 9, 14, 5, 6, 8, 6, 5, 12, - 9, 15, 5, 11, 6, 8, 13, 12, 5, 12, 13, 14, 11, 8, 5, 6 ]); - var _sr = WordArray.create([ - 8, 9, 9, 11, 13, 15, 15, 5, 7, 7, 8, 11, 14, 14, 12, 6, - 9, 13, 15, 7, 12, 8, 9, 11, 7, 7, 12, 7, 6, 15, 13, 11, - 9, 7, 15, 11, 8, 6, 6, 14, 12, 13, 5, 14, 13, 13, 7, 5, - 15, 5, 8, 11, 14, 14, 6, 14, 6, 9, 12, 9, 12, 5, 15, 8, - 8, 5, 12, 9, 12, 5, 14, 6, 8, 13, 6, 5, 15, 13, 11, 11 ]); - - var _hl = WordArray.create([ 0x00000000, 0x5A827999, 0x6ED9EBA1, 0x8F1BBCDC, 0xA953FD4E]); - var _hr = WordArray.create([ 0x50A28BE6, 0x5C4DD124, 0x6D703EF3, 0x7A6D76E9, 0x00000000]); - - /** - * RIPEMD160 hash algorithm. - */ - var RIPEMD160 = C_algo.RIPEMD160 = Hasher.extend({ - _doReset: function () { - this._hash = WordArray.create([0x67452301, 0xEFCDAB89, 0x98BADCFE, 0x10325476, 0xC3D2E1F0]); - }, - - _doProcessBlock: function (M, offset) { - - // Swap endian - for (var i = 0; i < 16; i++) { - // Shortcuts - var offset_i = offset + i; - var M_offset_i = M[offset_i]; - - // Swap - M[offset_i] = ( - (((M_offset_i << 8) | (M_offset_i >>> 24)) & 0x00ff00ff) | - (((M_offset_i << 24) | (M_offset_i >>> 8)) & 0xff00ff00) - ); - } - // Shortcut - var H = this._hash.words; - var hl = _hl.words; - var hr = _hr.words; - var zl = _zl.words; - var zr = _zr.words; - var sl = _sl.words; - var sr = _sr.words; - - // Working variables - var al, bl, cl, dl, el; - var ar, br, cr, dr, er; - - ar = al = H[0]; - br = bl = H[1]; - cr = cl = H[2]; - dr = dl = H[3]; - er = el = H[4]; - // Computation - var t; - for (var i = 0; i < 80; i += 1) { - t = (al + M[offset+zl[i]])|0; - if (i<16){ - t += f1(bl,cl,dl) + hl[0]; - } else if (i<32) { - t += f2(bl,cl,dl) + hl[1]; - } else if (i<48) { - t += f3(bl,cl,dl) + hl[2]; - } else if (i<64) { - t += f4(bl,cl,dl) + hl[3]; - } else {// if (i<80) { - t += f5(bl,cl,dl) + hl[4]; - } - t = t|0; - t = rotl(t,sl[i]); - t = (t+el)|0; - al = el; - el = dl; - dl = rotl(cl, 10); - cl = bl; - bl = t; - - t = (ar + M[offset+zr[i]])|0; - if (i<16){ - t += f5(br,cr,dr) + hr[0]; - } else if (i<32) { - t += f4(br,cr,dr) + hr[1]; - } else if (i<48) { - t += f3(br,cr,dr) + hr[2]; - } else if (i<64) { - t += f2(br,cr,dr) + hr[3]; - } else {// if (i<80) { - t += f1(br,cr,dr) + hr[4]; - } - t = t|0; - t = rotl(t,sr[i]) ; - t = (t+er)|0; - ar = er; - er = dr; - dr = rotl(cr, 10); - cr = br; - br = t; - } - // Intermediate hash value - t = (H[1] + cl + dr)|0; - H[1] = (H[2] + dl + er)|0; - H[2] = (H[3] + el + ar)|0; - H[3] = (H[4] + al + br)|0; - H[4] = (H[0] + bl + cr)|0; - H[0] = t; - }, - - _doFinalize: function () { - // Shortcuts - var data = this._data; - var dataWords = data.words; - - var nBitsTotal = this._nDataBytes * 8; - var nBitsLeft = data.sigBytes * 8; - - // Add padding - dataWords[nBitsLeft >>> 5] |= 0x80 << (24 - nBitsLeft % 32); - dataWords[(((nBitsLeft + 64) >>> 9) << 4) + 14] = ( - (((nBitsTotal << 8) | (nBitsTotal >>> 24)) & 0x00ff00ff) | - (((nBitsTotal << 24) | (nBitsTotal >>> 8)) & 0xff00ff00) - ); - data.sigBytes = (dataWords.length + 1) * 4; - - // Hash final blocks - this._process(); - - // Shortcuts - var hash = this._hash; - var H = hash.words; - - // Swap endian - for (var i = 0; i < 5; i++) { - // Shortcut - var H_i = H[i]; - - // Swap - H[i] = (((H_i << 8) | (H_i >>> 24)) & 0x00ff00ff) | - (((H_i << 24) | (H_i >>> 8)) & 0xff00ff00); - } - - // Return final computed hash - return hash; - }, - - clone: function () { - var clone = Hasher.clone.call(this); - clone._hash = this._hash.clone(); - - return clone; - } - }); - - - function f1(x, y, z) { - return ((x) ^ (y) ^ (z)); - - } - - function f2(x, y, z) { - return (((x)&(y)) | ((~x)&(z))); - } - - function f3(x, y, z) { - return (((x) | (~(y))) ^ (z)); - } - - function f4(x, y, z) { - return (((x) & (z)) | ((y)&(~(z)))); - } - - function f5(x, y, z) { - return ((x) ^ ((y) |(~(z)))); - - } - - function rotl(x,n) { - return (x<>>(32-n)); - } - - - /** - * Shortcut function to the hasher's object interface. - * - * @param {WordArray|string} message The message to hash. - * - * @return {WordArray} The hash. - * - * @static - * - * @example - * - * var hash = CryptoJS.RIPEMD160('message'); - * var hash = CryptoJS.RIPEMD160(wordArray); - */ - C.RIPEMD160 = Hasher._createHelper(RIPEMD160); - - /** - * Shortcut function to the HMAC's object interface. - * - * @param {WordArray|string} message The message to hash. - * @param {WordArray|string} key The secret key. - * - * @return {WordArray} The HMAC. - * - * @static - * - * @example - * - * var hmac = CryptoJS.HmacRIPEMD160(message, key); - */ - C.HmacRIPEMD160 = Hasher._createHmacHelper(RIPEMD160); - }(Math)); - - - (function () { - // Shortcuts - var C = CryptoJS; - var C_lib = C.lib; - var Base = C_lib.Base; - var C_enc = C.enc; - var Utf8 = C_enc.Utf8; - var C_algo = C.algo; - - /** - * HMAC algorithm. - */ - var HMAC = C_algo.HMAC = Base.extend({ - /** - * Initializes a newly created HMAC. - * - * @param {Hasher} hasher The hash algorithm to use. - * @param {WordArray|string} key The secret key. - * - * @example - * - * var hmacHasher = CryptoJS.algo.HMAC.create(CryptoJS.algo.SHA256, key); - */ - init: function (hasher, key) { - // Init hasher - hasher = this._hasher = new hasher.init(); - - // Convert string to WordArray, else assume WordArray already - if (typeof key == 'string') { - key = Utf8.parse(key); - } - - // Shortcuts - var hasherBlockSize = hasher.blockSize; - var hasherBlockSizeBytes = hasherBlockSize * 4; - - // Allow arbitrary length keys - if (key.sigBytes > hasherBlockSizeBytes) { - key = hasher.finalize(key); - } - - // Clamp excess bits - key.clamp(); - - // Clone key for inner and outer pads - var oKey = this._oKey = key.clone(); - var iKey = this._iKey = key.clone(); - - // Shortcuts - var oKeyWords = oKey.words; - var iKeyWords = iKey.words; - - // XOR keys with pad constants - for (var i = 0; i < hasherBlockSize; i++) { - oKeyWords[i] ^= 0x5c5c5c5c; - iKeyWords[i] ^= 0x36363636; - } - oKey.sigBytes = iKey.sigBytes = hasherBlockSizeBytes; - - // Set initial values - this.reset(); - }, - - /** - * Resets this HMAC to its initial state. - * - * @example - * - * hmacHasher.reset(); - */ - reset: function () { - // Shortcut - var hasher = this._hasher; - - // Reset - hasher.reset(); - hasher.update(this._iKey); - }, - - /** - * Updates this HMAC with a message. - * - * @param {WordArray|string} messageUpdate The message to append. - * - * @return {HMAC} This HMAC instance. - * - * @example - * - * hmacHasher.update('message'); - * hmacHasher.update(wordArray); - */ - update: function (messageUpdate) { - this._hasher.update(messageUpdate); - - // Chainable - return this; - }, - - /** - * Finalizes the HMAC computation. - * Note that the finalize operation is effectively a destructive, read-once operation. - * - * @param {WordArray|string} messageUpdate (Optional) A final message update. - * - * @return {WordArray} The HMAC. - * - * @example - * - * var hmac = hmacHasher.finalize(); - * var hmac = hmacHasher.finalize('message'); - * var hmac = hmacHasher.finalize(wordArray); - */ - finalize: function (messageUpdate) { - // Shortcut - var hasher = this._hasher; - - // Compute HMAC - var innerHash = hasher.finalize(messageUpdate); - hasher.reset(); - var hmac = hasher.finalize(this._oKey.clone().concat(innerHash)); - - return hmac; - } - }); - }()); - - - (function () { - // Shortcuts - var C = CryptoJS; - var C_lib = C.lib; - var Base = C_lib.Base; - var WordArray = C_lib.WordArray; - var C_algo = C.algo; - var SHA1 = C_algo.SHA1; - var HMAC = C_algo.HMAC; - - /** - * Password-Based Key Derivation Function 2 algorithm. - */ - var PBKDF2 = C_algo.PBKDF2 = Base.extend({ - /** - * Configuration options. - * - * @property {number} keySize The key size in words to generate. Default: 4 (128 bits) - * @property {Hasher} hasher The hasher to use. Default: SHA1 - * @property {number} iterations The number of iterations to perform. Default: 1 - */ - cfg: Base.extend({ - keySize: 128/32, - hasher: SHA1, - iterations: 1 - }), - - /** - * Initializes a newly created key derivation function. - * - * @param {Object} cfg (Optional) The configuration options to use for the derivation. - * - * @example - * - * var kdf = CryptoJS.algo.PBKDF2.create(); - * var kdf = CryptoJS.algo.PBKDF2.create({ keySize: 8 }); - * var kdf = CryptoJS.algo.PBKDF2.create({ keySize: 8, iterations: 1000 }); - */ - init: function (cfg) { - this.cfg = this.cfg.extend(cfg); - }, - - /** - * Computes the Password-Based Key Derivation Function 2. - * - * @param {WordArray|string} password The password. - * @param {WordArray|string} salt A salt. - * - * @return {WordArray} The derived key. - * - * @example - * - * var key = kdf.compute(password, salt); - */ - compute: function (password, salt) { - // Shortcut - var cfg = this.cfg; - - // Init HMAC - var hmac = HMAC.create(cfg.hasher, password); - - // Initial values - var derivedKey = WordArray.create(); - var blockIndex = WordArray.create([0x00000001]); - - // Shortcuts - var derivedKeyWords = derivedKey.words; - var blockIndexWords = blockIndex.words; - var keySize = cfg.keySize; - var iterations = cfg.iterations; - - // Generate key - while (derivedKeyWords.length < keySize) { - var block = hmac.update(salt).finalize(blockIndex); - hmac.reset(); - - // Shortcuts - var blockWords = block.words; - var blockWordsLength = blockWords.length; - - // Iterations - var intermediate = block; - for (var i = 1; i < iterations; i++) { - intermediate = hmac.finalize(intermediate); - hmac.reset(); - - // Shortcut - var intermediateWords = intermediate.words; - - // XOR intermediate with block - for (var j = 0; j < blockWordsLength; j++) { - blockWords[j] ^= intermediateWords[j]; - } - } - - derivedKey.concat(block); - blockIndexWords[0]++; - } - derivedKey.sigBytes = keySize * 4; - - return derivedKey; - } - }); - - /** - * Computes the Password-Based Key Derivation Function 2. - * - * @param {WordArray|string} password The password. - * @param {WordArray|string} salt A salt. - * @param {Object} cfg (Optional) The configuration options to use for this computation. - * - * @return {WordArray} The derived key. - * - * @static - * - * @example - * - * var key = CryptoJS.PBKDF2(password, salt); - * var key = CryptoJS.PBKDF2(password, salt, { keySize: 8 }); - * var key = CryptoJS.PBKDF2(password, salt, { keySize: 8, iterations: 1000 }); - */ - C.PBKDF2 = function (password, salt, cfg) { - return PBKDF2.create(cfg).compute(password, salt); - }; - }()); - - - (function () { - // Shortcuts - var C = CryptoJS; - var C_lib = C.lib; - var Base = C_lib.Base; - var WordArray = C_lib.WordArray; - var C_algo = C.algo; - var MD5 = C_algo.MD5; - - /** - * This key derivation function is meant to conform with EVP_BytesToKey. - * www.openssl.org/docs/crypto/EVP_BytesToKey.html - */ - var EvpKDF = C_algo.EvpKDF = Base.extend({ - /** - * Configuration options. - * - * @property {number} keySize The key size in words to generate. Default: 4 (128 bits) - * @property {Hasher} hasher The hash algorithm to use. Default: MD5 - * @property {number} iterations The number of iterations to perform. Default: 1 - */ - cfg: Base.extend({ - keySize: 128/32, - hasher: MD5, - iterations: 1 - }), - - /** - * Initializes a newly created key derivation function. - * - * @param {Object} cfg (Optional) The configuration options to use for the derivation. - * - * @example - * - * var kdf = CryptoJS.algo.EvpKDF.create(); - * var kdf = CryptoJS.algo.EvpKDF.create({ keySize: 8 }); - * var kdf = CryptoJS.algo.EvpKDF.create({ keySize: 8, iterations: 1000 }); - */ - init: function (cfg) { - this.cfg = this.cfg.extend(cfg); - }, - - /** - * Derives a key from a password. - * - * @param {WordArray|string} password The password. - * @param {WordArray|string} salt A salt. - * - * @return {WordArray} The derived key. - * - * @example - * - * var key = kdf.compute(password, salt); - */ - compute: function (password, salt) { - // Shortcut - var cfg = this.cfg; - - // Init hasher - var hasher = cfg.hasher.create(); - - // Initial values - var derivedKey = WordArray.create(); - - // Shortcuts - var derivedKeyWords = derivedKey.words; - var keySize = cfg.keySize; - var iterations = cfg.iterations; - - // Generate key - while (derivedKeyWords.length < keySize) { - if (block) { - hasher.update(block); - } - var block = hasher.update(password).finalize(salt); - hasher.reset(); - - // Iterations - for (var i = 1; i < iterations; i++) { - block = hasher.finalize(block); - hasher.reset(); - } - - derivedKey.concat(block); - } - derivedKey.sigBytes = keySize * 4; - - return derivedKey; - } - }); - - /** - * Derives a key from a password. - * - * @param {WordArray|string} password The password. - * @param {WordArray|string} salt A salt. - * @param {Object} cfg (Optional) The configuration options to use for this computation. - * - * @return {WordArray} The derived key. - * - * @static - * - * @example - * - * var key = CryptoJS.EvpKDF(password, salt); - * var key = CryptoJS.EvpKDF(password, salt, { keySize: 8 }); - * var key = CryptoJS.EvpKDF(password, salt, { keySize: 8, iterations: 1000 }); - */ - C.EvpKDF = function (password, salt, cfg) { - return EvpKDF.create(cfg).compute(password, salt); - }; - }()); - - - (function () { - // Shortcuts - var C = CryptoJS; - var C_lib = C.lib; - var WordArray = C_lib.WordArray; - var C_algo = C.algo; - var SHA256 = C_algo.SHA256; - - /** - * SHA-224 hash algorithm. - */ - var SHA224 = C_algo.SHA224 = SHA256.extend({ - _doReset: function () { - this._hash = new WordArray.init([ - 0xc1059ed8, 0x367cd507, 0x3070dd17, 0xf70e5939, - 0xffc00b31, 0x68581511, 0x64f98fa7, 0xbefa4fa4 - ]); - }, - - _doFinalize: function () { - var hash = SHA256._doFinalize.call(this); - - hash.sigBytes -= 4; - - return hash; - } - }); - - /** - * Shortcut function to the hasher's object interface. - * - * @param {WordArray|string} message The message to hash. - * - * @return {WordArray} The hash. - * - * @static - * - * @example - * - * var hash = CryptoJS.SHA224('message'); - * var hash = CryptoJS.SHA224(wordArray); - */ - C.SHA224 = SHA256._createHelper(SHA224); - - /** - * Shortcut function to the HMAC's object interface. - * - * @param {WordArray|string} message The message to hash. - * @param {WordArray|string} key The secret key. - * - * @return {WordArray} The HMAC. - * - * @static - * - * @example - * - * var hmac = CryptoJS.HmacSHA224(message, key); - */ - C.HmacSHA224 = SHA256._createHmacHelper(SHA224); - }()); - - - (function (undefined) { - // Shortcuts - var C = CryptoJS; - var C_lib = C.lib; - var Base = C_lib.Base; - var X32WordArray = C_lib.WordArray; - - /** - * x64 namespace. - */ - var C_x64 = C.x64 = {}; - - /** - * A 64-bit word. - */ - var X64Word = C_x64.Word = Base.extend({ - /** - * Initializes a newly created 64-bit word. - * - * @param {number} high The high 32 bits. - * @param {number} low The low 32 bits. - * - * @example - * - * var x64Word = CryptoJS.x64.Word.create(0x00010203, 0x04050607); - */ - init: function (high, low) { - this.high = high; - this.low = low; - } - - /** - * Bitwise NOTs this word. - * - * @return {X64Word} A new x64-Word object after negating. - * - * @example - * - * var negated = x64Word.not(); - */ - // not: function () { - // var high = ~this.high; - // var low = ~this.low; - - // return X64Word.create(high, low); - // }, - - /** - * Bitwise ANDs this word with the passed word. - * - * @param {X64Word} word The x64-Word to AND with this word. - * - * @return {X64Word} A new x64-Word object after ANDing. - * - * @example - * - * var anded = x64Word.and(anotherX64Word); - */ - // and: function (word) { - // var high = this.high & word.high; - // var low = this.low & word.low; - - // return X64Word.create(high, low); - // }, - - /** - * Bitwise ORs this word with the passed word. - * - * @param {X64Word} word The x64-Word to OR with this word. - * - * @return {X64Word} A new x64-Word object after ORing. - * - * @example - * - * var ored = x64Word.or(anotherX64Word); - */ - // or: function (word) { - // var high = this.high | word.high; - // var low = this.low | word.low; - - // return X64Word.create(high, low); - // }, - - /** - * Bitwise XORs this word with the passed word. - * - * @param {X64Word} word The x64-Word to XOR with this word. - * - * @return {X64Word} A new x64-Word object after XORing. - * - * @example - * - * var xored = x64Word.xor(anotherX64Word); - */ - // xor: function (word) { - // var high = this.high ^ word.high; - // var low = this.low ^ word.low; - - // return X64Word.create(high, low); - // }, - - /** - * Shifts this word n bits to the left. - * - * @param {number} n The number of bits to shift. - * - * @return {X64Word} A new x64-Word object after shifting. - * - * @example - * - * var shifted = x64Word.shiftL(25); - */ - // shiftL: function (n) { - // if (n < 32) { - // var high = (this.high << n) | (this.low >>> (32 - n)); - // var low = this.low << n; - // } else { - // var high = this.low << (n - 32); - // var low = 0; - // } - - // return X64Word.create(high, low); - // }, - - /** - * Shifts this word n bits to the right. - * - * @param {number} n The number of bits to shift. - * - * @return {X64Word} A new x64-Word object after shifting. - * - * @example - * - * var shifted = x64Word.shiftR(7); - */ - // shiftR: function (n) { - // if (n < 32) { - // var low = (this.low >>> n) | (this.high << (32 - n)); - // var high = this.high >>> n; - // } else { - // var low = this.high >>> (n - 32); - // var high = 0; - // } - - // return X64Word.create(high, low); - // }, - - /** - * Rotates this word n bits to the left. - * - * @param {number} n The number of bits to rotate. - * - * @return {X64Word} A new x64-Word object after rotating. - * - * @example - * - * var rotated = x64Word.rotL(25); - */ - // rotL: function (n) { - // return this.shiftL(n).or(this.shiftR(64 - n)); - // }, - - /** - * Rotates this word n bits to the right. - * - * @param {number} n The number of bits to rotate. - * - * @return {X64Word} A new x64-Word object after rotating. - * - * @example - * - * var rotated = x64Word.rotR(7); - */ - // rotR: function (n) { - // return this.shiftR(n).or(this.shiftL(64 - n)); - // }, - - /** - * Adds this word with the passed word. - * - * @param {X64Word} word The x64-Word to add with this word. - * - * @return {X64Word} A new x64-Word object after adding. - * - * @example - * - * var added = x64Word.add(anotherX64Word); - */ - // add: function (word) { - // var low = (this.low + word.low) | 0; - // var carry = (low >>> 0) < (this.low >>> 0) ? 1 : 0; - // var high = (this.high + word.high + carry) | 0; - - // return X64Word.create(high, low); - // } - }); - - /** - * An array of 64-bit words. - * - * @property {Array} words The array of CryptoJS.x64.Word objects. - * @property {number} sigBytes The number of significant bytes in this word array. - */ - var X64WordArray = C_x64.WordArray = Base.extend({ - /** - * Initializes a newly created word array. - * - * @param {Array} words (Optional) An array of CryptoJS.x64.Word objects. - * @param {number} sigBytes (Optional) The number of significant bytes in the words. - * - * @example - * - * var wordArray = CryptoJS.x64.WordArray.create(); - * - * var wordArray = CryptoJS.x64.WordArray.create([ - * CryptoJS.x64.Word.create(0x00010203, 0x04050607), - * CryptoJS.x64.Word.create(0x18191a1b, 0x1c1d1e1f) - * ]); - * - * var wordArray = CryptoJS.x64.WordArray.create([ - * CryptoJS.x64.Word.create(0x00010203, 0x04050607), - * CryptoJS.x64.Word.create(0x18191a1b, 0x1c1d1e1f) - * ], 10); - */ - init: function (words, sigBytes) { - words = this.words = words || []; - - if (sigBytes != undefined) { - this.sigBytes = sigBytes; - } else { - this.sigBytes = words.length * 8; - } - }, - - /** - * Converts this 64-bit word array to a 32-bit word array. - * - * @return {CryptoJS.lib.WordArray} This word array's data as a 32-bit word array. - * - * @example - * - * var x32WordArray = x64WordArray.toX32(); - */ - toX32: function () { - // Shortcuts - var x64Words = this.words; - var x64WordsLength = x64Words.length; - - // Convert - var x32Words = []; - for (var i = 0; i < x64WordsLength; i++) { - var x64Word = x64Words[i]; - x32Words.push(x64Word.high); - x32Words.push(x64Word.low); - } - - return X32WordArray.create(x32Words, this.sigBytes); - }, - - /** - * Creates a copy of this word array. - * - * @return {X64WordArray} The clone. - * - * @example - * - * var clone = x64WordArray.clone(); - */ - clone: function () { - var clone = Base.clone.call(this); - - // Clone "words" array - var words = clone.words = this.words.slice(0); - - // Clone each X64Word object - var wordsLength = words.length; - for (var i = 0; i < wordsLength; i++) { - words[i] = words[i].clone(); - } - - return clone; - } - }); - }()); - - - (function (Math) { - // Shortcuts - var C = CryptoJS; - var C_lib = C.lib; - var WordArray = C_lib.WordArray; - var Hasher = C_lib.Hasher; - var C_x64 = C.x64; - var X64Word = C_x64.Word; - var C_algo = C.algo; - - // Constants tables - var RHO_OFFSETS = []; - var PI_INDEXES = []; - var ROUND_CONSTANTS = []; - - // Compute Constants - (function () { - // Compute rho offset constants - var x = 1, y = 0; - for (var t = 0; t < 24; t++) { - RHO_OFFSETS[x + 5 * y] = ((t + 1) * (t + 2) / 2) % 64; - - var newX = y % 5; - var newY = (2 * x + 3 * y) % 5; - x = newX; - y = newY; - } - - // Compute pi index constants - for (var x = 0; x < 5; x++) { - for (var y = 0; y < 5; y++) { - PI_INDEXES[x + 5 * y] = y + ((2 * x + 3 * y) % 5) * 5; - } - } - - // Compute round constants - var LFSR = 0x01; - for (var i = 0; i < 24; i++) { - var roundConstantMsw = 0; - var roundConstantLsw = 0; - - for (var j = 0; j < 7; j++) { - if (LFSR & 0x01) { - var bitPosition = (1 << j) - 1; - if (bitPosition < 32) { - roundConstantLsw ^= 1 << bitPosition; - } else /* if (bitPosition >= 32) */ { - roundConstantMsw ^= 1 << (bitPosition - 32); - } - } - - // Compute next LFSR - if (LFSR & 0x80) { - // Primitive polynomial over GF(2): x^8 + x^6 + x^5 + x^4 + 1 - LFSR = (LFSR << 1) ^ 0x71; - } else { - LFSR <<= 1; - } - } - - ROUND_CONSTANTS[i] = X64Word.create(roundConstantMsw, roundConstantLsw); - } - }()); - - // Reusable objects for temporary values - var T = []; - (function () { - for (var i = 0; i < 25; i++) { - T[i] = X64Word.create(); - } - }()); - - /** - * SHA-3 hash algorithm. - */ - var SHA3 = C_algo.SHA3 = Hasher.extend({ - /** - * Configuration options. - * - * @property {number} outputLength - * The desired number of bits in the output hash. - * Only values permitted are: 224, 256, 384, 512. - * Default: 512 - */ - cfg: Hasher.cfg.extend({ - outputLength: 512 - }), - - _doReset: function () { - var state = this._state = [] - for (var i = 0; i < 25; i++) { - state[i] = new X64Word.init(); - } - - this.blockSize = (1600 - 2 * this.cfg.outputLength) / 32; - }, - - _doProcessBlock: function (M, offset) { - // Shortcuts - var state = this._state; - var nBlockSizeLanes = this.blockSize / 2; - - // Absorb - for (var i = 0; i < nBlockSizeLanes; i++) { - // Shortcuts - var M2i = M[offset + 2 * i]; - var M2i1 = M[offset + 2 * i + 1]; - - // Swap endian - M2i = ( - (((M2i << 8) | (M2i >>> 24)) & 0x00ff00ff) | - (((M2i << 24) | (M2i >>> 8)) & 0xff00ff00) - ); - M2i1 = ( - (((M2i1 << 8) | (M2i1 >>> 24)) & 0x00ff00ff) | - (((M2i1 << 24) | (M2i1 >>> 8)) & 0xff00ff00) - ); - - // Absorb message into state - var lane = state[i]; - lane.high ^= M2i1; - lane.low ^= M2i; - } - - // Rounds - for (var round = 0; round < 24; round++) { - // Theta - for (var x = 0; x < 5; x++) { - // Mix column lanes - var tMsw = 0, tLsw = 0; - for (var y = 0; y < 5; y++) { - var lane = state[x + 5 * y]; - tMsw ^= lane.high; - tLsw ^= lane.low; - } - - // Temporary values - var Tx = T[x]; - Tx.high = tMsw; - Tx.low = tLsw; - } - for (var x = 0; x < 5; x++) { - // Shortcuts - var Tx4 = T[(x + 4) % 5]; - var Tx1 = T[(x + 1) % 5]; - var Tx1Msw = Tx1.high; - var Tx1Lsw = Tx1.low; - - // Mix surrounding columns - var tMsw = Tx4.high ^ ((Tx1Msw << 1) | (Tx1Lsw >>> 31)); - var tLsw = Tx4.low ^ ((Tx1Lsw << 1) | (Tx1Msw >>> 31)); - for (var y = 0; y < 5; y++) { - var lane = state[x + 5 * y]; - lane.high ^= tMsw; - lane.low ^= tLsw; - } - } - - // Rho Pi - for (var laneIndex = 1; laneIndex < 25; laneIndex++) { - // Shortcuts - var lane = state[laneIndex]; - var laneMsw = lane.high; - var laneLsw = lane.low; - var rhoOffset = RHO_OFFSETS[laneIndex]; - - // Rotate lanes - if (rhoOffset < 32) { - var tMsw = (laneMsw << rhoOffset) | (laneLsw >>> (32 - rhoOffset)); - var tLsw = (laneLsw << rhoOffset) | (laneMsw >>> (32 - rhoOffset)); - } else /* if (rhoOffset >= 32) */ { - var tMsw = (laneLsw << (rhoOffset - 32)) | (laneMsw >>> (64 - rhoOffset)); - var tLsw = (laneMsw << (rhoOffset - 32)) | (laneLsw >>> (64 - rhoOffset)); - } - - // Transpose lanes - var TPiLane = T[PI_INDEXES[laneIndex]]; - TPiLane.high = tMsw; - TPiLane.low = tLsw; - } - - // Rho pi at x = y = 0 - var T0 = T[0]; - var state0 = state[0]; - T0.high = state0.high; - T0.low = state0.low; - - // Chi - for (var x = 0; x < 5; x++) { - for (var y = 0; y < 5; y++) { - // Shortcuts - var laneIndex = x + 5 * y; - var lane = state[laneIndex]; - var TLane = T[laneIndex]; - var Tx1Lane = T[((x + 1) % 5) + 5 * y]; - var Tx2Lane = T[((x + 2) % 5) + 5 * y]; - - // Mix rows - lane.high = TLane.high ^ (~Tx1Lane.high & Tx2Lane.high); - lane.low = TLane.low ^ (~Tx1Lane.low & Tx2Lane.low); - } - } - - // Iota - var lane = state[0]; - var roundConstant = ROUND_CONSTANTS[round]; - lane.high ^= roundConstant.high; - lane.low ^= roundConstant.low;; - } - }, - - _doFinalize: function () { - // Shortcuts - var data = this._data; - var dataWords = data.words; - var nBitsTotal = this._nDataBytes * 8; - var nBitsLeft = data.sigBytes * 8; - var blockSizeBits = this.blockSize * 32; - - // Add padding - dataWords[nBitsLeft >>> 5] |= 0x1 << (24 - nBitsLeft % 32); - dataWords[((Math.ceil((nBitsLeft + 1) / blockSizeBits) * blockSizeBits) >>> 5) - 1] |= 0x80; - data.sigBytes = dataWords.length * 4; - - // Hash final blocks - this._process(); - - // Shortcuts - var state = this._state; - var outputLengthBytes = this.cfg.outputLength / 8; - var outputLengthLanes = outputLengthBytes / 8; - - // Squeeze - var hashWords = []; - for (var i = 0; i < outputLengthLanes; i++) { - // Shortcuts - var lane = state[i]; - var laneMsw = lane.high; - var laneLsw = lane.low; - - // Swap endian - laneMsw = ( - (((laneMsw << 8) | (laneMsw >>> 24)) & 0x00ff00ff) | - (((laneMsw << 24) | (laneMsw >>> 8)) & 0xff00ff00) - ); - laneLsw = ( - (((laneLsw << 8) | (laneLsw >>> 24)) & 0x00ff00ff) | - (((laneLsw << 24) | (laneLsw >>> 8)) & 0xff00ff00) - ); - - // Squeeze state to retrieve hash - hashWords.push(laneLsw); - hashWords.push(laneMsw); - } - - // Return final computed hash - return new WordArray.init(hashWords, outputLengthBytes); - }, - - clone: function () { - var clone = Hasher.clone.call(this); - - var state = clone._state = this._state.slice(0); - for (var i = 0; i < 25; i++) { - state[i] = state[i].clone(); - } - - return clone; - } - }); - - /** - * Shortcut function to the hasher's object interface. - * - * @param {WordArray|string} message The message to hash. - * - * @return {WordArray} The hash. - * - * @static - * - * @example - * - * var hash = CryptoJS.SHA3('message'); - * var hash = CryptoJS.SHA3(wordArray); - */ - C.SHA3 = Hasher._createHelper(SHA3); - - /** - * Shortcut function to the HMAC's object interface. - * - * @param {WordArray|string} message The message to hash. - * @param {WordArray|string} key The secret key. - * - * @return {WordArray} The HMAC. - * - * @static - * - * @example - * - * var hmac = CryptoJS.HmacSHA3(message, key); - */ - C.HmacSHA3 = Hasher._createHmacHelper(SHA3); - }(Math)); - - - (function () { - // Shortcuts - var C = CryptoJS; - var C_lib = C.lib; - var Hasher = C_lib.Hasher; - var C_x64 = C.x64; - var X64Word = C_x64.Word; - var X64WordArray = C_x64.WordArray; - var C_algo = C.algo; - - function X64Word_create() { - return X64Word.create.apply(X64Word, arguments); - } - - // Constants - var K = [ - X64Word_create(0x428a2f98, 0xd728ae22), X64Word_create(0x71374491, 0x23ef65cd), - X64Word_create(0xb5c0fbcf, 0xec4d3b2f), X64Word_create(0xe9b5dba5, 0x8189dbbc), - X64Word_create(0x3956c25b, 0xf348b538), X64Word_create(0x59f111f1, 0xb605d019), - X64Word_create(0x923f82a4, 0xaf194f9b), X64Word_create(0xab1c5ed5, 0xda6d8118), - X64Word_create(0xd807aa98, 0xa3030242), X64Word_create(0x12835b01, 0x45706fbe), - X64Word_create(0x243185be, 0x4ee4b28c), X64Word_create(0x550c7dc3, 0xd5ffb4e2), - X64Word_create(0x72be5d74, 0xf27b896f), X64Word_create(0x80deb1fe, 0x3b1696b1), - X64Word_create(0x9bdc06a7, 0x25c71235), X64Word_create(0xc19bf174, 0xcf692694), - X64Word_create(0xe49b69c1, 0x9ef14ad2), X64Word_create(0xefbe4786, 0x384f25e3), - X64Word_create(0x0fc19dc6, 0x8b8cd5b5), X64Word_create(0x240ca1cc, 0x77ac9c65), - X64Word_create(0x2de92c6f, 0x592b0275), X64Word_create(0x4a7484aa, 0x6ea6e483), - X64Word_create(0x5cb0a9dc, 0xbd41fbd4), X64Word_create(0x76f988da, 0x831153b5), - X64Word_create(0x983e5152, 0xee66dfab), X64Word_create(0xa831c66d, 0x2db43210), - X64Word_create(0xb00327c8, 0x98fb213f), X64Word_create(0xbf597fc7, 0xbeef0ee4), - X64Word_create(0xc6e00bf3, 0x3da88fc2), X64Word_create(0xd5a79147, 0x930aa725), - X64Word_create(0x06ca6351, 0xe003826f), X64Word_create(0x14292967, 0x0a0e6e70), - X64Word_create(0x27b70a85, 0x46d22ffc), X64Word_create(0x2e1b2138, 0x5c26c926), - X64Word_create(0x4d2c6dfc, 0x5ac42aed), X64Word_create(0x53380d13, 0x9d95b3df), - X64Word_create(0x650a7354, 0x8baf63de), X64Word_create(0x766a0abb, 0x3c77b2a8), - X64Word_create(0x81c2c92e, 0x47edaee6), X64Word_create(0x92722c85, 0x1482353b), - X64Word_create(0xa2bfe8a1, 0x4cf10364), X64Word_create(0xa81a664b, 0xbc423001), - X64Word_create(0xc24b8b70, 0xd0f89791), X64Word_create(0xc76c51a3, 0x0654be30), - X64Word_create(0xd192e819, 0xd6ef5218), X64Word_create(0xd6990624, 0x5565a910), - X64Word_create(0xf40e3585, 0x5771202a), X64Word_create(0x106aa070, 0x32bbd1b8), - X64Word_create(0x19a4c116, 0xb8d2d0c8), X64Word_create(0x1e376c08, 0x5141ab53), - X64Word_create(0x2748774c, 0xdf8eeb99), X64Word_create(0x34b0bcb5, 0xe19b48a8), - X64Word_create(0x391c0cb3, 0xc5c95a63), X64Word_create(0x4ed8aa4a, 0xe3418acb), - X64Word_create(0x5b9cca4f, 0x7763e373), X64Word_create(0x682e6ff3, 0xd6b2b8a3), - X64Word_create(0x748f82ee, 0x5defb2fc), X64Word_create(0x78a5636f, 0x43172f60), - X64Word_create(0x84c87814, 0xa1f0ab72), X64Word_create(0x8cc70208, 0x1a6439ec), - X64Word_create(0x90befffa, 0x23631e28), X64Word_create(0xa4506ceb, 0xde82bde9), - X64Word_create(0xbef9a3f7, 0xb2c67915), X64Word_create(0xc67178f2, 0xe372532b), - X64Word_create(0xca273ece, 0xea26619c), X64Word_create(0xd186b8c7, 0x21c0c207), - X64Word_create(0xeada7dd6, 0xcde0eb1e), X64Word_create(0xf57d4f7f, 0xee6ed178), - X64Word_create(0x06f067aa, 0x72176fba), X64Word_create(0x0a637dc5, 0xa2c898a6), - X64Word_create(0x113f9804, 0xbef90dae), X64Word_create(0x1b710b35, 0x131c471b), - X64Word_create(0x28db77f5, 0x23047d84), X64Word_create(0x32caab7b, 0x40c72493), - X64Word_create(0x3c9ebe0a, 0x15c9bebc), X64Word_create(0x431d67c4, 0x9c100d4c), - X64Word_create(0x4cc5d4be, 0xcb3e42b6), X64Word_create(0x597f299c, 0xfc657e2a), - X64Word_create(0x5fcb6fab, 0x3ad6faec), X64Word_create(0x6c44198c, 0x4a475817) - ]; - - // Reusable objects - var W = []; - (function () { - for (var i = 0; i < 80; i++) { - W[i] = X64Word_create(); - } - }()); - - /** - * SHA-512 hash algorithm. - */ - var SHA512 = C_algo.SHA512 = Hasher.extend({ - _doReset: function () { - this._hash = new X64WordArray.init([ - new X64Word.init(0x6a09e667, 0xf3bcc908), new X64Word.init(0xbb67ae85, 0x84caa73b), - new X64Word.init(0x3c6ef372, 0xfe94f82b), new X64Word.init(0xa54ff53a, 0x5f1d36f1), - new X64Word.init(0x510e527f, 0xade682d1), new X64Word.init(0x9b05688c, 0x2b3e6c1f), - new X64Word.init(0x1f83d9ab, 0xfb41bd6b), new X64Word.init(0x5be0cd19, 0x137e2179) - ]); - }, - - _doProcessBlock: function (M, offset) { - // Shortcuts - var H = this._hash.words; - - var H0 = H[0]; - var H1 = H[1]; - var H2 = H[2]; - var H3 = H[3]; - var H4 = H[4]; - var H5 = H[5]; - var H6 = H[6]; - var H7 = H[7]; - - var H0h = H0.high; - var H0l = H0.low; - var H1h = H1.high; - var H1l = H1.low; - var H2h = H2.high; - var H2l = H2.low; - var H3h = H3.high; - var H3l = H3.low; - var H4h = H4.high; - var H4l = H4.low; - var H5h = H5.high; - var H5l = H5.low; - var H6h = H6.high; - var H6l = H6.low; - var H7h = H7.high; - var H7l = H7.low; - - // Working variables - var ah = H0h; - var al = H0l; - var bh = H1h; - var bl = H1l; - var ch = H2h; - var cl = H2l; - var dh = H3h; - var dl = H3l; - var eh = H4h; - var el = H4l; - var fh = H5h; - var fl = H5l; - var gh = H6h; - var gl = H6l; - var hh = H7h; - var hl = H7l; - - // Rounds - for (var i = 0; i < 80; i++) { - // Shortcut - var Wi = W[i]; - - // Extend message - if (i < 16) { - var Wih = Wi.high = M[offset + i * 2] | 0; - var Wil = Wi.low = M[offset + i * 2 + 1] | 0; - } else { - // Gamma0 - var gamma0x = W[i - 15]; - var gamma0xh = gamma0x.high; - var gamma0xl = gamma0x.low; - var gamma0h = ((gamma0xh >>> 1) | (gamma0xl << 31)) ^ ((gamma0xh >>> 8) | (gamma0xl << 24)) ^ (gamma0xh >>> 7); - var gamma0l = ((gamma0xl >>> 1) | (gamma0xh << 31)) ^ ((gamma0xl >>> 8) | (gamma0xh << 24)) ^ ((gamma0xl >>> 7) | (gamma0xh << 25)); - - // Gamma1 - var gamma1x = W[i - 2]; - var gamma1xh = gamma1x.high; - var gamma1xl = gamma1x.low; - var gamma1h = ((gamma1xh >>> 19) | (gamma1xl << 13)) ^ ((gamma1xh << 3) | (gamma1xl >>> 29)) ^ (gamma1xh >>> 6); - var gamma1l = ((gamma1xl >>> 19) | (gamma1xh << 13)) ^ ((gamma1xl << 3) | (gamma1xh >>> 29)) ^ ((gamma1xl >>> 6) | (gamma1xh << 26)); - - // W[i] = gamma0 + W[i - 7] + gamma1 + W[i - 16] - var Wi7 = W[i - 7]; - var Wi7h = Wi7.high; - var Wi7l = Wi7.low; - - var Wi16 = W[i - 16]; - var Wi16h = Wi16.high; - var Wi16l = Wi16.low; - - var Wil = gamma0l + Wi7l; - var Wih = gamma0h + Wi7h + ((Wil >>> 0) < (gamma0l >>> 0) ? 1 : 0); - var Wil = Wil + gamma1l; - var Wih = Wih + gamma1h + ((Wil >>> 0) < (gamma1l >>> 0) ? 1 : 0); - var Wil = Wil + Wi16l; - var Wih = Wih + Wi16h + ((Wil >>> 0) < (Wi16l >>> 0) ? 1 : 0); - - Wi.high = Wih; - Wi.low = Wil; - } - - var chh = (eh & fh) ^ (~eh & gh); - var chl = (el & fl) ^ (~el & gl); - var majh = (ah & bh) ^ (ah & ch) ^ (bh & ch); - var majl = (al & bl) ^ (al & cl) ^ (bl & cl); - - var sigma0h = ((ah >>> 28) | (al << 4)) ^ ((ah << 30) | (al >>> 2)) ^ ((ah << 25) | (al >>> 7)); - var sigma0l = ((al >>> 28) | (ah << 4)) ^ ((al << 30) | (ah >>> 2)) ^ ((al << 25) | (ah >>> 7)); - var sigma1h = ((eh >>> 14) | (el << 18)) ^ ((eh >>> 18) | (el << 14)) ^ ((eh << 23) | (el >>> 9)); - var sigma1l = ((el >>> 14) | (eh << 18)) ^ ((el >>> 18) | (eh << 14)) ^ ((el << 23) | (eh >>> 9)); - - // t1 = h + sigma1 + ch + K[i] + W[i] - var Ki = K[i]; - var Kih = Ki.high; - var Kil = Ki.low; - - var t1l = hl + sigma1l; - var t1h = hh + sigma1h + ((t1l >>> 0) < (hl >>> 0) ? 1 : 0); - var t1l = t1l + chl; - var t1h = t1h + chh + ((t1l >>> 0) < (chl >>> 0) ? 1 : 0); - var t1l = t1l + Kil; - var t1h = t1h + Kih + ((t1l >>> 0) < (Kil >>> 0) ? 1 : 0); - var t1l = t1l + Wil; - var t1h = t1h + Wih + ((t1l >>> 0) < (Wil >>> 0) ? 1 : 0); - - // t2 = sigma0 + maj - var t2l = sigma0l + majl; - var t2h = sigma0h + majh + ((t2l >>> 0) < (sigma0l >>> 0) ? 1 : 0); - - // Update working variables - hh = gh; - hl = gl; - gh = fh; - gl = fl; - fh = eh; - fl = el; - el = (dl + t1l) | 0; - eh = (dh + t1h + ((el >>> 0) < (dl >>> 0) ? 1 : 0)) | 0; - dh = ch; - dl = cl; - ch = bh; - cl = bl; - bh = ah; - bl = al; - al = (t1l + t2l) | 0; - ah = (t1h + t2h + ((al >>> 0) < (t1l >>> 0) ? 1 : 0)) | 0; - } - - // Intermediate hash value - H0l = H0.low = (H0l + al); - H0.high = (H0h + ah + ((H0l >>> 0) < (al >>> 0) ? 1 : 0)); - H1l = H1.low = (H1l + bl); - H1.high = (H1h + bh + ((H1l >>> 0) < (bl >>> 0) ? 1 : 0)); - H2l = H2.low = (H2l + cl); - H2.high = (H2h + ch + ((H2l >>> 0) < (cl >>> 0) ? 1 : 0)); - H3l = H3.low = (H3l + dl); - H3.high = (H3h + dh + ((H3l >>> 0) < (dl >>> 0) ? 1 : 0)); - H4l = H4.low = (H4l + el); - H4.high = (H4h + eh + ((H4l >>> 0) < (el >>> 0) ? 1 : 0)); - H5l = H5.low = (H5l + fl); - H5.high = (H5h + fh + ((H5l >>> 0) < (fl >>> 0) ? 1 : 0)); - H6l = H6.low = (H6l + gl); - H6.high = (H6h + gh + ((H6l >>> 0) < (gl >>> 0) ? 1 : 0)); - H7l = H7.low = (H7l + hl); - H7.high = (H7h + hh + ((H7l >>> 0) < (hl >>> 0) ? 1 : 0)); - }, - - _doFinalize: function () { - // Shortcuts - var data = this._data; - var dataWords = data.words; - - var nBitsTotal = this._nDataBytes * 8; - var nBitsLeft = data.sigBytes * 8; - - // Add padding - dataWords[nBitsLeft >>> 5] |= 0x80 << (24 - nBitsLeft % 32); - dataWords[(((nBitsLeft + 128) >>> 10) << 5) + 30] = Math.floor(nBitsTotal / 0x100000000); - dataWords[(((nBitsLeft + 128) >>> 10) << 5) + 31] = nBitsTotal; - data.sigBytes = dataWords.length * 4; - - // Hash final blocks - this._process(); - - // Convert hash to 32-bit word array before returning - var hash = this._hash.toX32(); - - // Return final computed hash - return hash; - }, - - clone: function () { - var clone = Hasher.clone.call(this); - clone._hash = this._hash.clone(); - - return clone; - }, - - blockSize: 1024/32 - }); - - /** - * Shortcut function to the hasher's object interface. - * - * @param {WordArray|string} message The message to hash. - * - * @return {WordArray} The hash. - * - * @static - * - * @example - * - * var hash = CryptoJS.SHA512('message'); - * var hash = CryptoJS.SHA512(wordArray); - */ - C.SHA512 = Hasher._createHelper(SHA512); - - /** - * Shortcut function to the HMAC's object interface. - * - * @param {WordArray|string} message The message to hash. - * @param {WordArray|string} key The secret key. - * - * @return {WordArray} The HMAC. - * - * @static - * - * @example - * - * var hmac = CryptoJS.HmacSHA512(message, key); - */ - C.HmacSHA512 = Hasher._createHmacHelper(SHA512); - }()); - - - (function () { - // Shortcuts - var C = CryptoJS; - var C_x64 = C.x64; - var X64Word = C_x64.Word; - var X64WordArray = C_x64.WordArray; - var C_algo = C.algo; - var SHA512 = C_algo.SHA512; - - /** - * SHA-384 hash algorithm. - */ - var SHA384 = C_algo.SHA384 = SHA512.extend({ - _doReset: function () { - this._hash = new X64WordArray.init([ - new X64Word.init(0xcbbb9d5d, 0xc1059ed8), new X64Word.init(0x629a292a, 0x367cd507), - new X64Word.init(0x9159015a, 0x3070dd17), new X64Word.init(0x152fecd8, 0xf70e5939), - new X64Word.init(0x67332667, 0xffc00b31), new X64Word.init(0x8eb44a87, 0x68581511), - new X64Word.init(0xdb0c2e0d, 0x64f98fa7), new X64Word.init(0x47b5481d, 0xbefa4fa4) - ]); - }, - - _doFinalize: function () { - var hash = SHA512._doFinalize.call(this); - - hash.sigBytes -= 16; - - return hash; - } - }); - - /** - * Shortcut function to the hasher's object interface. - * - * @param {WordArray|string} message The message to hash. - * - * @return {WordArray} The hash. - * - * @static - * - * @example - * - * var hash = CryptoJS.SHA384('message'); - * var hash = CryptoJS.SHA384(wordArray); - */ - C.SHA384 = SHA512._createHelper(SHA384); - - /** - * Shortcut function to the HMAC's object interface. - * - * @param {WordArray|string} message The message to hash. - * @param {WordArray|string} key The secret key. - * - * @return {WordArray} The HMAC. - * - * @static - * - * @example - * - * var hmac = CryptoJS.HmacSHA384(message, key); - */ - C.HmacSHA384 = SHA512._createHmacHelper(SHA384); - }()); - - - /** - * Cipher core components. - */ - CryptoJS.lib.Cipher || (function (undefined) { - // Shortcuts - var C = CryptoJS; - var C_lib = C.lib; - var Base = C_lib.Base; - var WordArray = C_lib.WordArray; - var BufferedBlockAlgorithm = C_lib.BufferedBlockAlgorithm; - var C_enc = C.enc; - var Utf8 = C_enc.Utf8; - var Base64 = C_enc.Base64; - var C_algo = C.algo; - var EvpKDF = C_algo.EvpKDF; - - /** - * Abstract base cipher template. - * - * @property {number} keySize This cipher's key size. Default: 4 (128 bits) - * @property {number} ivSize This cipher's IV size. Default: 4 (128 bits) - * @property {number} _ENC_XFORM_MODE A constant representing encryption mode. - * @property {number} _DEC_XFORM_MODE A constant representing decryption mode. - */ - var Cipher = C_lib.Cipher = BufferedBlockAlgorithm.extend({ - /** - * Configuration options. - * - * @property {WordArray} iv The IV to use for this operation. - */ - cfg: Base.extend(), - - /** - * Creates this cipher in encryption mode. - * - * @param {WordArray} key The key. - * @param {Object} cfg (Optional) The configuration options to use for this operation. - * - * @return {Cipher} A cipher instance. - * - * @static - * - * @example - * - * var cipher = CryptoJS.algo.AES.createEncryptor(keyWordArray, { iv: ivWordArray }); - */ - createEncryptor: function (key, cfg) { - return this.create(this._ENC_XFORM_MODE, key, cfg); - }, - - /** - * Creates this cipher in decryption mode. - * - * @param {WordArray} key The key. - * @param {Object} cfg (Optional) The configuration options to use for this operation. - * - * @return {Cipher} A cipher instance. - * - * @static - * - * @example - * - * var cipher = CryptoJS.algo.AES.createDecryptor(keyWordArray, { iv: ivWordArray }); - */ - createDecryptor: function (key, cfg) { - return this.create(this._DEC_XFORM_MODE, key, cfg); - }, - - /** - * Initializes a newly created cipher. - * - * @param {number} xformMode Either the encryption or decryption transormation mode constant. - * @param {WordArray} key The key. - * @param {Object} cfg (Optional) The configuration options to use for this operation. - * - * @example - * - * var cipher = CryptoJS.algo.AES.create(CryptoJS.algo.AES._ENC_XFORM_MODE, keyWordArray, { iv: ivWordArray }); - */ - init: function (xformMode, key, cfg) { - // Apply config defaults - this.cfg = this.cfg.extend(cfg); - - // Store transform mode and key - this._xformMode = xformMode; - this._key = key; - - // Set initial values - this.reset(); - }, - - /** - * Resets this cipher to its initial state. - * - * @example - * - * cipher.reset(); - */ - reset: function () { - // Reset data buffer - BufferedBlockAlgorithm.reset.call(this); - - // Perform concrete-cipher logic - this._doReset(); - }, - - /** - * Adds data to be encrypted or decrypted. - * - * @param {WordArray|string} dataUpdate The data to encrypt or decrypt. - * - * @return {WordArray} The data after processing. - * - * @example - * - * var encrypted = cipher.process('data'); - * var encrypted = cipher.process(wordArray); - */ - process: function (dataUpdate) { - // Append - this._append(dataUpdate); - - // Process available blocks - return this._process(); - }, - - /** - * Finalizes the encryption or decryption process. - * Note that the finalize operation is effectively a destructive, read-once operation. - * - * @param {WordArray|string} dataUpdate The final data to encrypt or decrypt. - * - * @return {WordArray} The data after final processing. - * - * @example - * - * var encrypted = cipher.finalize(); - * var encrypted = cipher.finalize('data'); - * var encrypted = cipher.finalize(wordArray); - */ - finalize: function (dataUpdate) { - // Final data update - if (dataUpdate) { - this._append(dataUpdate); - } - - // Perform concrete-cipher logic - var finalProcessedData = this._doFinalize(); - - return finalProcessedData; - }, - - keySize: 128/32, - - ivSize: 128/32, - - _ENC_XFORM_MODE: 1, - - _DEC_XFORM_MODE: 2, - - /** - * Creates shortcut functions to a cipher's object interface. - * - * @param {Cipher} cipher The cipher to create a helper for. - * - * @return {Object} An object with encrypt and decrypt shortcut functions. - * - * @static - * - * @example - * - * var AES = CryptoJS.lib.Cipher._createHelper(CryptoJS.algo.AES); - */ - _createHelper: (function () { - function selectCipherStrategy(key) { - if (typeof key == 'string') { - return PasswordBasedCipher; - } else { - return SerializableCipher; - } - } - - return function (cipher) { - return { - encrypt: function (message, key, cfg) { - return selectCipherStrategy(key).encrypt(cipher, message, key, cfg); - }, - - decrypt: function (ciphertext, key, cfg) { - return selectCipherStrategy(key).decrypt(cipher, ciphertext, key, cfg); - } - }; - }; - }()) - }); - - /** - * Abstract base stream cipher template. - * - * @property {number} blockSize The number of 32-bit words this cipher operates on. Default: 1 (32 bits) - */ - var StreamCipher = C_lib.StreamCipher = Cipher.extend({ - _doFinalize: function () { - // Process partial blocks - var finalProcessedBlocks = this._process(!!'flush'); - - return finalProcessedBlocks; - }, - - blockSize: 1 - }); - - /** - * Mode namespace. - */ - var C_mode = C.mode = {}; - - /** - * Abstract base block cipher mode template. - */ - var BlockCipherMode = C_lib.BlockCipherMode = Base.extend({ - /** - * Creates this mode for encryption. - * - * @param {Cipher} cipher A block cipher instance. - * @param {Array} iv The IV words. - * - * @static - * - * @example - * - * var mode = CryptoJS.mode.CBC.createEncryptor(cipher, iv.words); - */ - createEncryptor: function (cipher, iv) { - return this.Encryptor.create(cipher, iv); - }, - - /** - * Creates this mode for decryption. - * - * @param {Cipher} cipher A block cipher instance. - * @param {Array} iv The IV words. - * - * @static - * - * @example - * - * var mode = CryptoJS.mode.CBC.createDecryptor(cipher, iv.words); - */ - createDecryptor: function (cipher, iv) { - return this.Decryptor.create(cipher, iv); - }, - - /** - * Initializes a newly created mode. - * - * @param {Cipher} cipher A block cipher instance. - * @param {Array} iv The IV words. - * - * @example - * - * var mode = CryptoJS.mode.CBC.Encryptor.create(cipher, iv.words); - */ - init: function (cipher, iv) { - this._cipher = cipher; - this._iv = iv; - } - }); - - /** - * Cipher Block Chaining mode. - */ - var CBC = C_mode.CBC = (function () { - /** - * Abstract base CBC mode. - */ - var CBC = BlockCipherMode.extend(); - - /** - * CBC encryptor. - */ - CBC.Encryptor = CBC.extend({ - /** - * Processes the data block at offset. - * - * @param {Array} words The data words to operate on. - * @param {number} offset The offset where the block starts. - * - * @example - * - * mode.processBlock(data.words, offset); - */ - processBlock: function (words, offset) { - // Shortcuts - var cipher = this._cipher; - var blockSize = cipher.blockSize; - - // XOR and encrypt - xorBlock.call(this, words, offset, blockSize); - cipher.encryptBlock(words, offset); - - // Remember this block to use with next block - this._prevBlock = words.slice(offset, offset + blockSize); - } - }); - - /** - * CBC decryptor. - */ - CBC.Decryptor = CBC.extend({ - /** - * Processes the data block at offset. - * - * @param {Array} words The data words to operate on. - * @param {number} offset The offset where the block starts. - * - * @example - * - * mode.processBlock(data.words, offset); - */ - processBlock: function (words, offset) { - // Shortcuts - var cipher = this._cipher; - var blockSize = cipher.blockSize; - - // Remember this block to use with next block - var thisBlock = words.slice(offset, offset + blockSize); - - // Decrypt and XOR - cipher.decryptBlock(words, offset); - xorBlock.call(this, words, offset, blockSize); - - // This block becomes the previous block - this._prevBlock = thisBlock; - } - }); - - function xorBlock(words, offset, blockSize) { - // Shortcut - var iv = this._iv; - - // Choose mixing block - if (iv) { - var block = iv; - - // Remove IV for subsequent blocks - this._iv = undefined; - } else { - var block = this._prevBlock; - } - - // XOR blocks - for (var i = 0; i < blockSize; i++) { - words[offset + i] ^= block[i]; - } - } - - return CBC; - }()); - - /** - * Padding namespace. - */ - var C_pad = C.pad = {}; - - /** - * PKCS #5/7 padding strategy. - */ - var Pkcs7 = C_pad.Pkcs7 = { - /** - * Pads data using the algorithm defined in PKCS #5/7. - * - * @param {WordArray} data The data to pad. - * @param {number} blockSize The multiple that the data should be padded to. - * - * @static - * - * @example - * - * CryptoJS.pad.Pkcs7.pad(wordArray, 4); - */ - pad: function (data, blockSize) { - // Shortcut - var blockSizeBytes = blockSize * 4; - - // Count padding bytes - var nPaddingBytes = blockSizeBytes - data.sigBytes % blockSizeBytes; - - // Create padding word - var paddingWord = (nPaddingBytes << 24) | (nPaddingBytes << 16) | (nPaddingBytes << 8) | nPaddingBytes; - - // Create padding - var paddingWords = []; - for (var i = 0; i < nPaddingBytes; i += 4) { - paddingWords.push(paddingWord); - } - var padding = WordArray.create(paddingWords, nPaddingBytes); - - // Add padding - data.concat(padding); - }, - - /** - * Unpads data that had been padded using the algorithm defined in PKCS #5/7. - * - * @param {WordArray} data The data to unpad. - * - * @static - * - * @example - * - * CryptoJS.pad.Pkcs7.unpad(wordArray); - */ - unpad: function (data) { - // Get number of padding bytes from last byte - var nPaddingBytes = data.words[(data.sigBytes - 1) >>> 2] & 0xff; - - // Remove padding - data.sigBytes -= nPaddingBytes; - } - }; - - /** - * Abstract base block cipher template. - * - * @property {number} blockSize The number of 32-bit words this cipher operates on. Default: 4 (128 bits) - */ - var BlockCipher = C_lib.BlockCipher = Cipher.extend({ - /** - * Configuration options. - * - * @property {Mode} mode The block mode to use. Default: CBC - * @property {Padding} padding The padding strategy to use. Default: Pkcs7 - */ - cfg: Cipher.cfg.extend({ - mode: CBC, - padding: Pkcs7 - }), - - reset: function () { - // Reset cipher - Cipher.reset.call(this); - - // Shortcuts - var cfg = this.cfg; - var iv = cfg.iv; - var mode = cfg.mode; - - // Reset block mode - if (this._xformMode == this._ENC_XFORM_MODE) { - var modeCreator = mode.createEncryptor; - } else /* if (this._xformMode == this._DEC_XFORM_MODE) */ { - var modeCreator = mode.createDecryptor; - // Keep at least one block in the buffer for unpadding - this._minBufferSize = 1; - } - - if (this._mode && this._mode.__creator == modeCreator) { - this._mode.init(this, iv && iv.words); - } else { - this._mode = modeCreator.call(mode, this, iv && iv.words); - this._mode.__creator = modeCreator; - } - }, - - _doProcessBlock: function (words, offset) { - this._mode.processBlock(words, offset); - }, - - _doFinalize: function () { - // Shortcut - var padding = this.cfg.padding; - - // Finalize - if (this._xformMode == this._ENC_XFORM_MODE) { - // Pad data - padding.pad(this._data, this.blockSize); - - // Process final blocks - var finalProcessedBlocks = this._process(!!'flush'); - } else /* if (this._xformMode == this._DEC_XFORM_MODE) */ { - // Process final blocks - var finalProcessedBlocks = this._process(!!'flush'); - - // Unpad data - padding.unpad(finalProcessedBlocks); - } - - return finalProcessedBlocks; - }, - - blockSize: 128/32 - }); - - /** - * A collection of cipher parameters. - * - * @property {WordArray} ciphertext The raw ciphertext. - * @property {WordArray} key The key to this ciphertext. - * @property {WordArray} iv The IV used in the ciphering operation. - * @property {WordArray} salt The salt used with a key derivation function. - * @property {Cipher} algorithm The cipher algorithm. - * @property {Mode} mode The block mode used in the ciphering operation. - * @property {Padding} padding The padding scheme used in the ciphering operation. - * @property {number} blockSize The block size of the cipher. - * @property {Format} formatter The default formatting strategy to convert this cipher params object to a string. - */ - var CipherParams = C_lib.CipherParams = Base.extend({ - /** - * Initializes a newly created cipher params object. - * - * @param {Object} cipherParams An object with any of the possible cipher parameters. - * - * @example - * - * var cipherParams = CryptoJS.lib.CipherParams.create({ - * ciphertext: ciphertextWordArray, - * key: keyWordArray, - * iv: ivWordArray, - * salt: saltWordArray, - * algorithm: CryptoJS.algo.AES, - * mode: CryptoJS.mode.CBC, - * padding: CryptoJS.pad.PKCS7, - * blockSize: 4, - * formatter: CryptoJS.format.OpenSSL - * }); - */ - init: function (cipherParams) { - this.mixIn(cipherParams); - }, - - /** - * Converts this cipher params object to a string. - * - * @param {Format} formatter (Optional) The formatting strategy to use. - * - * @return {string} The stringified cipher params. - * - * @throws Error If neither the formatter nor the default formatter is set. - * - * @example - * - * var string = cipherParams + ''; - * var string = cipherParams.toString(); - * var string = cipherParams.toString(CryptoJS.format.OpenSSL); - */ - toString: function (formatter) { - return (formatter || this.formatter).stringify(this); - } - }); - - /** - * Format namespace. - */ - var C_format = C.format = {}; - - /** - * OpenSSL formatting strategy. - */ - var OpenSSLFormatter = C_format.OpenSSL = { - /** - * Converts a cipher params object to an OpenSSL-compatible string. - * - * @param {CipherParams} cipherParams The cipher params object. - * - * @return {string} The OpenSSL-compatible string. - * - * @static - * - * @example - * - * var openSSLString = CryptoJS.format.OpenSSL.stringify(cipherParams); - */ - stringify: function (cipherParams) { - // Shortcuts - var ciphertext = cipherParams.ciphertext; - var salt = cipherParams.salt; - - // Format - if (salt) { - var wordArray = WordArray.create([0x53616c74, 0x65645f5f]).concat(salt).concat(ciphertext); - } else { - var wordArray = ciphertext; - } - - return wordArray.toString(Base64); - }, - - /** - * Converts an OpenSSL-compatible string to a cipher params object. - * - * @param {string} openSSLStr The OpenSSL-compatible string. - * - * @return {CipherParams} The cipher params object. - * - * @static - * - * @example - * - * var cipherParams = CryptoJS.format.OpenSSL.parse(openSSLString); - */ - parse: function (openSSLStr) { - // Parse base64 - var ciphertext = Base64.parse(openSSLStr); - - // Shortcut - var ciphertextWords = ciphertext.words; - - // Test for salt - if (ciphertextWords[0] == 0x53616c74 && ciphertextWords[1] == 0x65645f5f) { - // Extract salt - var salt = WordArray.create(ciphertextWords.slice(2, 4)); - - // Remove salt from ciphertext - ciphertextWords.splice(0, 4); - ciphertext.sigBytes -= 16; - } - - return CipherParams.create({ ciphertext: ciphertext, salt: salt }); - } - }; - - /** - * A cipher wrapper that returns ciphertext as a serializable cipher params object. - */ - var SerializableCipher = C_lib.SerializableCipher = Base.extend({ - /** - * Configuration options. - * - * @property {Formatter} format The formatting strategy to convert cipher param objects to and from a string. Default: OpenSSL - */ - cfg: Base.extend({ - format: OpenSSLFormatter - }), - - /** - * Encrypts a message. - * - * @param {Cipher} cipher The cipher algorithm to use. - * @param {WordArray|string} message The message to encrypt. - * @param {WordArray} key The key. - * @param {Object} cfg (Optional) The configuration options to use for this operation. - * - * @return {CipherParams} A cipher params object. - * - * @static - * - * @example - * - * var ciphertextParams = CryptoJS.lib.SerializableCipher.encrypt(CryptoJS.algo.AES, message, key); - * var ciphertextParams = CryptoJS.lib.SerializableCipher.encrypt(CryptoJS.algo.AES, message, key, { iv: iv }); - * var ciphertextParams = CryptoJS.lib.SerializableCipher.encrypt(CryptoJS.algo.AES, message, key, { iv: iv, format: CryptoJS.format.OpenSSL }); - */ - encrypt: function (cipher, message, key, cfg) { - // Apply config defaults - cfg = this.cfg.extend(cfg); - - // Encrypt - var encryptor = cipher.createEncryptor(key, cfg); - var ciphertext = encryptor.finalize(message); - - // Shortcut - var cipherCfg = encryptor.cfg; - - // Create and return serializable cipher params - return CipherParams.create({ - ciphertext: ciphertext, - key: key, - iv: cipherCfg.iv, - algorithm: cipher, - mode: cipherCfg.mode, - padding: cipherCfg.padding, - blockSize: cipher.blockSize, - formatter: cfg.format - }); - }, - - /** - * Decrypts serialized ciphertext. - * - * @param {Cipher} cipher The cipher algorithm to use. - * @param {CipherParams|string} ciphertext The ciphertext to decrypt. - * @param {WordArray} key The key. - * @param {Object} cfg (Optional) The configuration options to use for this operation. - * - * @return {WordArray} The plaintext. - * - * @static - * - * @example - * - * var plaintext = CryptoJS.lib.SerializableCipher.decrypt(CryptoJS.algo.AES, formattedCiphertext, key, { iv: iv, format: CryptoJS.format.OpenSSL }); - * var plaintext = CryptoJS.lib.SerializableCipher.decrypt(CryptoJS.algo.AES, ciphertextParams, key, { iv: iv, format: CryptoJS.format.OpenSSL }); - */ - decrypt: function (cipher, ciphertext, key, cfg) { - // Apply config defaults - cfg = this.cfg.extend(cfg); - - // Convert string to CipherParams - ciphertext = this._parse(ciphertext, cfg.format); - - // Decrypt - var plaintext = cipher.createDecryptor(key, cfg).finalize(ciphertext.ciphertext); - - return plaintext; - }, - - /** - * Converts serialized ciphertext to CipherParams, - * else assumed CipherParams already and returns ciphertext unchanged. - * - * @param {CipherParams|string} ciphertext The ciphertext. - * @param {Formatter} format The formatting strategy to use to parse serialized ciphertext. - * - * @return {CipherParams} The unserialized ciphertext. - * - * @static - * - * @example - * - * var ciphertextParams = CryptoJS.lib.SerializableCipher._parse(ciphertextStringOrParams, format); - */ - _parse: function (ciphertext, format) { - if (typeof ciphertext == 'string') { - return format.parse(ciphertext, this); - } else { - return ciphertext; - } - } - }); - - /** - * Key derivation function namespace. - */ - var C_kdf = C.kdf = {}; - - /** - * OpenSSL key derivation function. - */ - var OpenSSLKdf = C_kdf.OpenSSL = { - /** - * Derives a key and IV from a password. - * - * @param {string} password The password to derive from. - * @param {number} keySize The size in words of the key to generate. - * @param {number} ivSize The size in words of the IV to generate. - * @param {WordArray|string} salt (Optional) A 64-bit salt to use. If omitted, a salt will be generated randomly. - * - * @return {CipherParams} A cipher params object with the key, IV, and salt. - * - * @static - * - * @example - * - * var derivedParams = CryptoJS.kdf.OpenSSL.execute('Password', 256/32, 128/32); - * var derivedParams = CryptoJS.kdf.OpenSSL.execute('Password', 256/32, 128/32, 'saltsalt'); - */ - execute: function (password, keySize, ivSize, salt) { - // Generate random salt - if (!salt) { - salt = WordArray.random(64/8); - } - - // Derive key and IV - var key = EvpKDF.create({ keySize: keySize + ivSize }).compute(password, salt); - - // Separate key and IV - var iv = WordArray.create(key.words.slice(keySize), ivSize * 4); - key.sigBytes = keySize * 4; - - // Return params - return CipherParams.create({ key: key, iv: iv, salt: salt }); - } - }; - - /** - * A serializable cipher wrapper that derives the key from a password, - * and returns ciphertext as a serializable cipher params object. - */ - var PasswordBasedCipher = C_lib.PasswordBasedCipher = SerializableCipher.extend({ - /** - * Configuration options. - * - * @property {KDF} kdf The key derivation function to use to generate a key and IV from a password. Default: OpenSSL - */ - cfg: SerializableCipher.cfg.extend({ - kdf: OpenSSLKdf - }), - - /** - * Encrypts a message using a password. - * - * @param {Cipher} cipher The cipher algorithm to use. - * @param {WordArray|string} message The message to encrypt. - * @param {string} password The password. - * @param {Object} cfg (Optional) The configuration options to use for this operation. - * - * @return {CipherParams} A cipher params object. - * - * @static - * - * @example - * - * var ciphertextParams = CryptoJS.lib.PasswordBasedCipher.encrypt(CryptoJS.algo.AES, message, 'password'); - * var ciphertextParams = CryptoJS.lib.PasswordBasedCipher.encrypt(CryptoJS.algo.AES, message, 'password', { format: CryptoJS.format.OpenSSL }); - */ - encrypt: function (cipher, message, password, cfg) { - // Apply config defaults - cfg = this.cfg.extend(cfg); - - // Derive key and other params - var derivedParams = cfg.kdf.execute(password, cipher.keySize, cipher.ivSize); - - // Add IV to config - cfg.iv = derivedParams.iv; - - // Encrypt - var ciphertext = SerializableCipher.encrypt.call(this, cipher, message, derivedParams.key, cfg); - - // Mix in derived params - ciphertext.mixIn(derivedParams); - - return ciphertext; - }, - - /** - * Decrypts serialized ciphertext using a password. - * - * @param {Cipher} cipher The cipher algorithm to use. - * @param {CipherParams|string} ciphertext The ciphertext to decrypt. - * @param {string} password The password. - * @param {Object} cfg (Optional) The configuration options to use for this operation. - * - * @return {WordArray} The plaintext. - * - * @static - * - * @example - * - * var plaintext = CryptoJS.lib.PasswordBasedCipher.decrypt(CryptoJS.algo.AES, formattedCiphertext, 'password', { format: CryptoJS.format.OpenSSL }); - * var plaintext = CryptoJS.lib.PasswordBasedCipher.decrypt(CryptoJS.algo.AES, ciphertextParams, 'password', { format: CryptoJS.format.OpenSSL }); - */ - decrypt: function (cipher, ciphertext, password, cfg) { - // Apply config defaults - cfg = this.cfg.extend(cfg); - - // Convert string to CipherParams - ciphertext = this._parse(ciphertext, cfg.format); - - // Derive key and other params - var derivedParams = cfg.kdf.execute(password, cipher.keySize, cipher.ivSize, ciphertext.salt); - - // Add IV to config - cfg.iv = derivedParams.iv; - - // Decrypt - var plaintext = SerializableCipher.decrypt.call(this, cipher, ciphertext, derivedParams.key, cfg); - - return plaintext; - } - }); - }()); - - - /** - * Cipher Feedback block mode. - */ - CryptoJS.mode.CFB = (function () { - var CFB = CryptoJS.lib.BlockCipherMode.extend(); - - CFB.Encryptor = CFB.extend({ - processBlock: function (words, offset) { - // Shortcuts - var cipher = this._cipher; - var blockSize = cipher.blockSize; - - generateKeystreamAndEncrypt.call(this, words, offset, blockSize, cipher); - - // Remember this block to use with next block - this._prevBlock = words.slice(offset, offset + blockSize); - } - }); - - CFB.Decryptor = CFB.extend({ - processBlock: function (words, offset) { - // Shortcuts - var cipher = this._cipher; - var blockSize = cipher.blockSize; - - // Remember this block to use with next block - var thisBlock = words.slice(offset, offset + blockSize); - - generateKeystreamAndEncrypt.call(this, words, offset, blockSize, cipher); - - // This block becomes the previous block - this._prevBlock = thisBlock; - } - }); - - function generateKeystreamAndEncrypt(words, offset, blockSize, cipher) { - // Shortcut - var iv = this._iv; - - // Generate keystream - if (iv) { - var keystream = iv.slice(0); - - // Remove IV for subsequent blocks - this._iv = undefined; - } else { - var keystream = this._prevBlock; - } - cipher.encryptBlock(keystream, 0); - - // Encrypt - for (var i = 0; i < blockSize; i++) { - words[offset + i] ^= keystream[i]; - } - } - - return CFB; - }()); - - - /** - * Electronic Codebook block mode. - */ - CryptoJS.mode.ECB = (function () { - var ECB = CryptoJS.lib.BlockCipherMode.extend(); - - ECB.Encryptor = ECB.extend({ - processBlock: function (words, offset) { - this._cipher.encryptBlock(words, offset); - } - }); - - ECB.Decryptor = ECB.extend({ - processBlock: function (words, offset) { - this._cipher.decryptBlock(words, offset); - } - }); - - return ECB; - }()); - - - /** - * ANSI X.923 padding strategy. - */ - CryptoJS.pad.AnsiX923 = { - pad: function (data, blockSize) { - // Shortcuts - var dataSigBytes = data.sigBytes; - var blockSizeBytes = blockSize * 4; - - // Count padding bytes - var nPaddingBytes = blockSizeBytes - dataSigBytes % blockSizeBytes; - - // Compute last byte position - var lastBytePos = dataSigBytes + nPaddingBytes - 1; - - // Pad - data.clamp(); - data.words[lastBytePos >>> 2] |= nPaddingBytes << (24 - (lastBytePos % 4) * 8); - data.sigBytes += nPaddingBytes; - }, - - unpad: function (data) { - // Get number of padding bytes from last byte - var nPaddingBytes = data.words[(data.sigBytes - 1) >>> 2] & 0xff; - - // Remove padding - data.sigBytes -= nPaddingBytes; - } - }; - - - /** - * ISO 10126 padding strategy. - */ - CryptoJS.pad.Iso10126 = { - pad: function (data, blockSize) { - // Shortcut - var blockSizeBytes = blockSize * 4; - - // Count padding bytes - var nPaddingBytes = blockSizeBytes - data.sigBytes % blockSizeBytes; - - // Pad - data.concat(CryptoJS.lib.WordArray.random(nPaddingBytes - 1)). - concat(CryptoJS.lib.WordArray.create([nPaddingBytes << 24], 1)); - }, - - unpad: function (data) { - // Get number of padding bytes from last byte - var nPaddingBytes = data.words[(data.sigBytes - 1) >>> 2] & 0xff; - - // Remove padding - data.sigBytes -= nPaddingBytes; - } - }; - - - /** - * ISO/IEC 9797-1 Padding Method 2. - */ - CryptoJS.pad.Iso97971 = { - pad: function (data, blockSize) { - // Add 0x80 byte - data.concat(CryptoJS.lib.WordArray.create([0x80000000], 1)); - - // Zero pad the rest - CryptoJS.pad.ZeroPadding.pad(data, blockSize); - }, - - unpad: function (data) { - // Remove zero padding - CryptoJS.pad.ZeroPadding.unpad(data); - - // Remove one more byte -- the 0x80 byte - data.sigBytes--; - } - }; - - - /** - * Output Feedback block mode. - */ - CryptoJS.mode.OFB = (function () { - var OFB = CryptoJS.lib.BlockCipherMode.extend(); - - var Encryptor = OFB.Encryptor = OFB.extend({ - processBlock: function (words, offset) { - // Shortcuts - var cipher = this._cipher - var blockSize = cipher.blockSize; - var iv = this._iv; - var keystream = this._keystream; - - // Generate keystream - if (iv) { - keystream = this._keystream = iv.slice(0); - - // Remove IV for subsequent blocks - this._iv = undefined; - } - cipher.encryptBlock(keystream, 0); - - // Encrypt - for (var i = 0; i < blockSize; i++) { - words[offset + i] ^= keystream[i]; - } - } - }); - - OFB.Decryptor = Encryptor; - - return OFB; - }()); - - - /** - * A noop padding strategy. - */ - CryptoJS.pad.NoPadding = { - pad: function () { - }, - - unpad: function () { - } - }; - - - (function (undefined) { - // Shortcuts - var C = CryptoJS; - var C_lib = C.lib; - var CipherParams = C_lib.CipherParams; - var C_enc = C.enc; - var Hex = C_enc.Hex; - var C_format = C.format; - - var HexFormatter = C_format.Hex = { - /** - * Converts the ciphertext of a cipher params object to a hexadecimally encoded string. - * - * @param {CipherParams} cipherParams The cipher params object. - * - * @return {string} The hexadecimally encoded string. - * - * @static - * - * @example - * - * var hexString = CryptoJS.format.Hex.stringify(cipherParams); - */ - stringify: function (cipherParams) { - return cipherParams.ciphertext.toString(Hex); - }, - - /** - * Converts a hexadecimally encoded ciphertext string to a cipher params object. - * - * @param {string} input The hexadecimally encoded string. - * - * @return {CipherParams} The cipher params object. - * - * @static - * - * @example - * - * var cipherParams = CryptoJS.format.Hex.parse(hexString); - */ - parse: function (input) { - var ciphertext = Hex.parse(input); - return CipherParams.create({ ciphertext: ciphertext }); - } - }; - }()); - - - (function () { - // Shortcuts - var C = CryptoJS; - var C_lib = C.lib; - var BlockCipher = C_lib.BlockCipher; - var C_algo = C.algo; - - // Lookup tables - var SBOX = []; - var INV_SBOX = []; - var SUB_MIX_0 = []; - var SUB_MIX_1 = []; - var SUB_MIX_2 = []; - var SUB_MIX_3 = []; - var INV_SUB_MIX_0 = []; - var INV_SUB_MIX_1 = []; - var INV_SUB_MIX_2 = []; - var INV_SUB_MIX_3 = []; - - // Compute lookup tables - (function () { - // Compute double table - var d = []; - for (var i = 0; i < 256; i++) { - if (i < 128) { - d[i] = i << 1; - } else { - d[i] = (i << 1) ^ 0x11b; - } - } - - // Walk GF(2^8) - var x = 0; - var xi = 0; - for (var i = 0; i < 256; i++) { - // Compute sbox - var sx = xi ^ (xi << 1) ^ (xi << 2) ^ (xi << 3) ^ (xi << 4); - sx = (sx >>> 8) ^ (sx & 0xff) ^ 0x63; - SBOX[x] = sx; - INV_SBOX[sx] = x; - - // Compute multiplication - var x2 = d[x]; - var x4 = d[x2]; - var x8 = d[x4]; - - // Compute sub bytes, mix columns tables - var t = (d[sx] * 0x101) ^ (sx * 0x1010100); - SUB_MIX_0[x] = (t << 24) | (t >>> 8); - SUB_MIX_1[x] = (t << 16) | (t >>> 16); - SUB_MIX_2[x] = (t << 8) | (t >>> 24); - SUB_MIX_3[x] = t; - - // Compute inv sub bytes, inv mix columns tables - var t = (x8 * 0x1010101) ^ (x4 * 0x10001) ^ (x2 * 0x101) ^ (x * 0x1010100); - INV_SUB_MIX_0[sx] = (t << 24) | (t >>> 8); - INV_SUB_MIX_1[sx] = (t << 16) | (t >>> 16); - INV_SUB_MIX_2[sx] = (t << 8) | (t >>> 24); - INV_SUB_MIX_3[sx] = t; - - // Compute next counter - if (!x) { - x = xi = 1; - } else { - x = x2 ^ d[d[d[x8 ^ x2]]]; - xi ^= d[d[xi]]; - } - } - }()); - - // Precomputed Rcon lookup - var RCON = [0x00, 0x01, 0x02, 0x04, 0x08, 0x10, 0x20, 0x40, 0x80, 0x1b, 0x36]; - - /** - * AES block cipher algorithm. - */ - var AES = C_algo.AES = BlockCipher.extend({ - _doReset: function () { - // Skip reset of nRounds has been set before and key did not change - if (this._nRounds && this._keyPriorReset === this._key) { - return; - } - - // Shortcuts - var key = this._keyPriorReset = this._key; - var keyWords = key.words; - var keySize = key.sigBytes / 4; - - // Compute number of rounds - var nRounds = this._nRounds = keySize + 6; - - // Compute number of key schedule rows - var ksRows = (nRounds + 1) * 4; - - // Compute key schedule - var keySchedule = this._keySchedule = []; - for (var ksRow = 0; ksRow < ksRows; ksRow++) { - if (ksRow < keySize) { - keySchedule[ksRow] = keyWords[ksRow]; - } else { - var t = keySchedule[ksRow - 1]; - - if (!(ksRow % keySize)) { - // Rot word - t = (t << 8) | (t >>> 24); - - // Sub word - t = (SBOX[t >>> 24] << 24) | (SBOX[(t >>> 16) & 0xff] << 16) | (SBOX[(t >>> 8) & 0xff] << 8) | SBOX[t & 0xff]; - - // Mix Rcon - t ^= RCON[(ksRow / keySize) | 0] << 24; - } else if (keySize > 6 && ksRow % keySize == 4) { - // Sub word - t = (SBOX[t >>> 24] << 24) | (SBOX[(t >>> 16) & 0xff] << 16) | (SBOX[(t >>> 8) & 0xff] << 8) | SBOX[t & 0xff]; - } - - keySchedule[ksRow] = keySchedule[ksRow - keySize] ^ t; - } - } - - // Compute inv key schedule - var invKeySchedule = this._invKeySchedule = []; - for (var invKsRow = 0; invKsRow < ksRows; invKsRow++) { - var ksRow = ksRows - invKsRow; - - if (invKsRow % 4) { - var t = keySchedule[ksRow]; - } else { - var t = keySchedule[ksRow - 4]; - } - - if (invKsRow < 4 || ksRow <= 4) { - invKeySchedule[invKsRow] = t; - } else { - invKeySchedule[invKsRow] = INV_SUB_MIX_0[SBOX[t >>> 24]] ^ INV_SUB_MIX_1[SBOX[(t >>> 16) & 0xff]] ^ - INV_SUB_MIX_2[SBOX[(t >>> 8) & 0xff]] ^ INV_SUB_MIX_3[SBOX[t & 0xff]]; - } - } - }, - - encryptBlock: function (M, offset) { - this._doCryptBlock(M, offset, this._keySchedule, SUB_MIX_0, SUB_MIX_1, SUB_MIX_2, SUB_MIX_3, SBOX); - }, - - decryptBlock: function (M, offset) { - // Swap 2nd and 4th rows - var t = M[offset + 1]; - M[offset + 1] = M[offset + 3]; - M[offset + 3] = t; - - this._doCryptBlock(M, offset, this._invKeySchedule, INV_SUB_MIX_0, INV_SUB_MIX_1, INV_SUB_MIX_2, INV_SUB_MIX_3, INV_SBOX); - - // Inv swap 2nd and 4th rows - var t = M[offset + 1]; - M[offset + 1] = M[offset + 3]; - M[offset + 3] = t; - }, - - _doCryptBlock: function (M, offset, keySchedule, SUB_MIX_0, SUB_MIX_1, SUB_MIX_2, SUB_MIX_3, SBOX) { - // Shortcut - var nRounds = this._nRounds; - - // Get input, add round key - var s0 = M[offset] ^ keySchedule[0]; - var s1 = M[offset + 1] ^ keySchedule[1]; - var s2 = M[offset + 2] ^ keySchedule[2]; - var s3 = M[offset + 3] ^ keySchedule[3]; - - // Key schedule row counter - var ksRow = 4; - - // Rounds - for (var round = 1; round < nRounds; round++) { - // Shift rows, sub bytes, mix columns, add round key - var t0 = SUB_MIX_0[s0 >>> 24] ^ SUB_MIX_1[(s1 >>> 16) & 0xff] ^ SUB_MIX_2[(s2 >>> 8) & 0xff] ^ SUB_MIX_3[s3 & 0xff] ^ keySchedule[ksRow++]; - var t1 = SUB_MIX_0[s1 >>> 24] ^ SUB_MIX_1[(s2 >>> 16) & 0xff] ^ SUB_MIX_2[(s3 >>> 8) & 0xff] ^ SUB_MIX_3[s0 & 0xff] ^ keySchedule[ksRow++]; - var t2 = SUB_MIX_0[s2 >>> 24] ^ SUB_MIX_1[(s3 >>> 16) & 0xff] ^ SUB_MIX_2[(s0 >>> 8) & 0xff] ^ SUB_MIX_3[s1 & 0xff] ^ keySchedule[ksRow++]; - var t3 = SUB_MIX_0[s3 >>> 24] ^ SUB_MIX_1[(s0 >>> 16) & 0xff] ^ SUB_MIX_2[(s1 >>> 8) & 0xff] ^ SUB_MIX_3[s2 & 0xff] ^ keySchedule[ksRow++]; - - // Update state - s0 = t0; - s1 = t1; - s2 = t2; - s3 = t3; - } - - // Shift rows, sub bytes, add round key - var t0 = ((SBOX[s0 >>> 24] << 24) | (SBOX[(s1 >>> 16) & 0xff] << 16) | (SBOX[(s2 >>> 8) & 0xff] << 8) | SBOX[s3 & 0xff]) ^ keySchedule[ksRow++]; - var t1 = ((SBOX[s1 >>> 24] << 24) | (SBOX[(s2 >>> 16) & 0xff] << 16) | (SBOX[(s3 >>> 8) & 0xff] << 8) | SBOX[s0 & 0xff]) ^ keySchedule[ksRow++]; - var t2 = ((SBOX[s2 >>> 24] << 24) | (SBOX[(s3 >>> 16) & 0xff] << 16) | (SBOX[(s0 >>> 8) & 0xff] << 8) | SBOX[s1 & 0xff]) ^ keySchedule[ksRow++]; - var t3 = ((SBOX[s3 >>> 24] << 24) | (SBOX[(s0 >>> 16) & 0xff] << 16) | (SBOX[(s1 >>> 8) & 0xff] << 8) | SBOX[s2 & 0xff]) ^ keySchedule[ksRow++]; - - // Set output - M[offset] = t0; - M[offset + 1] = t1; - M[offset + 2] = t2; - M[offset + 3] = t3; - }, - - keySize: 256/32 - }); - - /** - * Shortcut functions to the cipher's object interface. - * - * @example - * - * var ciphertext = CryptoJS.AES.encrypt(message, key, cfg); - * var plaintext = CryptoJS.AES.decrypt(ciphertext, key, cfg); - */ - C.AES = BlockCipher._createHelper(AES); - }()); - - - (function () { - // Shortcuts - var C = CryptoJS; - var C_lib = C.lib; - var WordArray = C_lib.WordArray; - var BlockCipher = C_lib.BlockCipher; - var C_algo = C.algo; - - // Permuted Choice 1 constants - var PC1 = [ - 57, 49, 41, 33, 25, 17, 9, 1, - 58, 50, 42, 34, 26, 18, 10, 2, - 59, 51, 43, 35, 27, 19, 11, 3, - 60, 52, 44, 36, 63, 55, 47, 39, - 31, 23, 15, 7, 62, 54, 46, 38, - 30, 22, 14, 6, 61, 53, 45, 37, - 29, 21, 13, 5, 28, 20, 12, 4 - ]; - - // Permuted Choice 2 constants - var PC2 = [ - 14, 17, 11, 24, 1, 5, - 3, 28, 15, 6, 21, 10, - 23, 19, 12, 4, 26, 8, - 16, 7, 27, 20, 13, 2, - 41, 52, 31, 37, 47, 55, - 30, 40, 51, 45, 33, 48, - 44, 49, 39, 56, 34, 53, - 46, 42, 50, 36, 29, 32 - ]; - - // Cumulative bit shift constants - var BIT_SHIFTS = [1, 2, 4, 6, 8, 10, 12, 14, 15, 17, 19, 21, 23, 25, 27, 28]; - - // SBOXes and round permutation constants - var SBOX_P = [ - { - 0x0: 0x808200, - 0x10000000: 0x8000, - 0x20000000: 0x808002, - 0x30000000: 0x2, - 0x40000000: 0x200, - 0x50000000: 0x808202, - 0x60000000: 0x800202, - 0x70000000: 0x800000, - 0x80000000: 0x202, - 0x90000000: 0x800200, - 0xa0000000: 0x8200, - 0xb0000000: 0x808000, - 0xc0000000: 0x8002, - 0xd0000000: 0x800002, - 0xe0000000: 0x0, - 0xf0000000: 0x8202, - 0x8000000: 0x0, - 0x18000000: 0x808202, - 0x28000000: 0x8202, - 0x38000000: 0x8000, - 0x48000000: 0x808200, - 0x58000000: 0x200, - 0x68000000: 0x808002, - 0x78000000: 0x2, - 0x88000000: 0x800200, - 0x98000000: 0x8200, - 0xa8000000: 0x808000, - 0xb8000000: 0x800202, - 0xc8000000: 0x800002, - 0xd8000000: 0x8002, - 0xe8000000: 0x202, - 0xf8000000: 0x800000, - 0x1: 0x8000, - 0x10000001: 0x2, - 0x20000001: 0x808200, - 0x30000001: 0x800000, - 0x40000001: 0x808002, - 0x50000001: 0x8200, - 0x60000001: 0x200, - 0x70000001: 0x800202, - 0x80000001: 0x808202, - 0x90000001: 0x808000, - 0xa0000001: 0x800002, - 0xb0000001: 0x8202, - 0xc0000001: 0x202, - 0xd0000001: 0x800200, - 0xe0000001: 0x8002, - 0xf0000001: 0x0, - 0x8000001: 0x808202, - 0x18000001: 0x808000, - 0x28000001: 0x800000, - 0x38000001: 0x200, - 0x48000001: 0x8000, - 0x58000001: 0x800002, - 0x68000001: 0x2, - 0x78000001: 0x8202, - 0x88000001: 0x8002, - 0x98000001: 0x800202, - 0xa8000001: 0x202, - 0xb8000001: 0x808200, - 0xc8000001: 0x800200, - 0xd8000001: 0x0, - 0xe8000001: 0x8200, - 0xf8000001: 0x808002 - }, - { - 0x0: 0x40084010, - 0x1000000: 0x4000, - 0x2000000: 0x80000, - 0x3000000: 0x40080010, - 0x4000000: 0x40000010, - 0x5000000: 0x40084000, - 0x6000000: 0x40004000, - 0x7000000: 0x10, - 0x8000000: 0x84000, - 0x9000000: 0x40004010, - 0xa000000: 0x40000000, - 0xb000000: 0x84010, - 0xc000000: 0x80010, - 0xd000000: 0x0, - 0xe000000: 0x4010, - 0xf000000: 0x40080000, - 0x800000: 0x40004000, - 0x1800000: 0x84010, - 0x2800000: 0x10, - 0x3800000: 0x40004010, - 0x4800000: 0x40084010, - 0x5800000: 0x40000000, - 0x6800000: 0x80000, - 0x7800000: 0x40080010, - 0x8800000: 0x80010, - 0x9800000: 0x0, - 0xa800000: 0x4000, - 0xb800000: 0x40080000, - 0xc800000: 0x40000010, - 0xd800000: 0x84000, - 0xe800000: 0x40084000, - 0xf800000: 0x4010, - 0x10000000: 0x0, - 0x11000000: 0x40080010, - 0x12000000: 0x40004010, - 0x13000000: 0x40084000, - 0x14000000: 0x40080000, - 0x15000000: 0x10, - 0x16000000: 0x84010, - 0x17000000: 0x4000, - 0x18000000: 0x4010, - 0x19000000: 0x80000, - 0x1a000000: 0x80010, - 0x1b000000: 0x40000010, - 0x1c000000: 0x84000, - 0x1d000000: 0x40004000, - 0x1e000000: 0x40000000, - 0x1f000000: 0x40084010, - 0x10800000: 0x84010, - 0x11800000: 0x80000, - 0x12800000: 0x40080000, - 0x13800000: 0x4000, - 0x14800000: 0x40004000, - 0x15800000: 0x40084010, - 0x16800000: 0x10, - 0x17800000: 0x40000000, - 0x18800000: 0x40084000, - 0x19800000: 0x40000010, - 0x1a800000: 0x40004010, - 0x1b800000: 0x80010, - 0x1c800000: 0x0, - 0x1d800000: 0x4010, - 0x1e800000: 0x40080010, - 0x1f800000: 0x84000 - }, - { - 0x0: 0x104, - 0x100000: 0x0, - 0x200000: 0x4000100, - 0x300000: 0x10104, - 0x400000: 0x10004, - 0x500000: 0x4000004, - 0x600000: 0x4010104, - 0x700000: 0x4010000, - 0x800000: 0x4000000, - 0x900000: 0x4010100, - 0xa00000: 0x10100, - 0xb00000: 0x4010004, - 0xc00000: 0x4000104, - 0xd00000: 0x10000, - 0xe00000: 0x4, - 0xf00000: 0x100, - 0x80000: 0x4010100, - 0x180000: 0x4010004, - 0x280000: 0x0, - 0x380000: 0x4000100, - 0x480000: 0x4000004, - 0x580000: 0x10000, - 0x680000: 0x10004, - 0x780000: 0x104, - 0x880000: 0x4, - 0x980000: 0x100, - 0xa80000: 0x4010000, - 0xb80000: 0x10104, - 0xc80000: 0x10100, - 0xd80000: 0x4000104, - 0xe80000: 0x4010104, - 0xf80000: 0x4000000, - 0x1000000: 0x4010100, - 0x1100000: 0x10004, - 0x1200000: 0x10000, - 0x1300000: 0x4000100, - 0x1400000: 0x100, - 0x1500000: 0x4010104, - 0x1600000: 0x4000004, - 0x1700000: 0x0, - 0x1800000: 0x4000104, - 0x1900000: 0x4000000, - 0x1a00000: 0x4, - 0x1b00000: 0x10100, - 0x1c00000: 0x4010000, - 0x1d00000: 0x104, - 0x1e00000: 0x10104, - 0x1f00000: 0x4010004, - 0x1080000: 0x4000000, - 0x1180000: 0x104, - 0x1280000: 0x4010100, - 0x1380000: 0x0, - 0x1480000: 0x10004, - 0x1580000: 0x4000100, - 0x1680000: 0x100, - 0x1780000: 0x4010004, - 0x1880000: 0x10000, - 0x1980000: 0x4010104, - 0x1a80000: 0x10104, - 0x1b80000: 0x4000004, - 0x1c80000: 0x4000104, - 0x1d80000: 0x4010000, - 0x1e80000: 0x4, - 0x1f80000: 0x10100 - }, - { - 0x0: 0x80401000, - 0x10000: 0x80001040, - 0x20000: 0x401040, - 0x30000: 0x80400000, - 0x40000: 0x0, - 0x50000: 0x401000, - 0x60000: 0x80000040, - 0x70000: 0x400040, - 0x80000: 0x80000000, - 0x90000: 0x400000, - 0xa0000: 0x40, - 0xb0000: 0x80001000, - 0xc0000: 0x80400040, - 0xd0000: 0x1040, - 0xe0000: 0x1000, - 0xf0000: 0x80401040, - 0x8000: 0x80001040, - 0x18000: 0x40, - 0x28000: 0x80400040, - 0x38000: 0x80001000, - 0x48000: 0x401000, - 0x58000: 0x80401040, - 0x68000: 0x0, - 0x78000: 0x80400000, - 0x88000: 0x1000, - 0x98000: 0x80401000, - 0xa8000: 0x400000, - 0xb8000: 0x1040, - 0xc8000: 0x80000000, - 0xd8000: 0x400040, - 0xe8000: 0x401040, - 0xf8000: 0x80000040, - 0x100000: 0x400040, - 0x110000: 0x401000, - 0x120000: 0x80000040, - 0x130000: 0x0, - 0x140000: 0x1040, - 0x150000: 0x80400040, - 0x160000: 0x80401000, - 0x170000: 0x80001040, - 0x180000: 0x80401040, - 0x190000: 0x80000000, - 0x1a0000: 0x80400000, - 0x1b0000: 0x401040, - 0x1c0000: 0x80001000, - 0x1d0000: 0x400000, - 0x1e0000: 0x40, - 0x1f0000: 0x1000, - 0x108000: 0x80400000, - 0x118000: 0x80401040, - 0x128000: 0x0, - 0x138000: 0x401000, - 0x148000: 0x400040, - 0x158000: 0x80000000, - 0x168000: 0x80001040, - 0x178000: 0x40, - 0x188000: 0x80000040, - 0x198000: 0x1000, - 0x1a8000: 0x80001000, - 0x1b8000: 0x80400040, - 0x1c8000: 0x1040, - 0x1d8000: 0x80401000, - 0x1e8000: 0x400000, - 0x1f8000: 0x401040 - }, - { - 0x0: 0x80, - 0x1000: 0x1040000, - 0x2000: 0x40000, - 0x3000: 0x20000000, - 0x4000: 0x20040080, - 0x5000: 0x1000080, - 0x6000: 0x21000080, - 0x7000: 0x40080, - 0x8000: 0x1000000, - 0x9000: 0x20040000, - 0xa000: 0x20000080, - 0xb000: 0x21040080, - 0xc000: 0x21040000, - 0xd000: 0x0, - 0xe000: 0x1040080, - 0xf000: 0x21000000, - 0x800: 0x1040080, - 0x1800: 0x21000080, - 0x2800: 0x80, - 0x3800: 0x1040000, - 0x4800: 0x40000, - 0x5800: 0x20040080, - 0x6800: 0x21040000, - 0x7800: 0x20000000, - 0x8800: 0x20040000, - 0x9800: 0x0, - 0xa800: 0x21040080, - 0xb800: 0x1000080, - 0xc800: 0x20000080, - 0xd800: 0x21000000, - 0xe800: 0x1000000, - 0xf800: 0x40080, - 0x10000: 0x40000, - 0x11000: 0x80, - 0x12000: 0x20000000, - 0x13000: 0x21000080, - 0x14000: 0x1000080, - 0x15000: 0x21040000, - 0x16000: 0x20040080, - 0x17000: 0x1000000, - 0x18000: 0x21040080, - 0x19000: 0x21000000, - 0x1a000: 0x1040000, - 0x1b000: 0x20040000, - 0x1c000: 0x40080, - 0x1d000: 0x20000080, - 0x1e000: 0x0, - 0x1f000: 0x1040080, - 0x10800: 0x21000080, - 0x11800: 0x1000000, - 0x12800: 0x1040000, - 0x13800: 0x20040080, - 0x14800: 0x20000000, - 0x15800: 0x1040080, - 0x16800: 0x80, - 0x17800: 0x21040000, - 0x18800: 0x40080, - 0x19800: 0x21040080, - 0x1a800: 0x0, - 0x1b800: 0x21000000, - 0x1c800: 0x1000080, - 0x1d800: 0x40000, - 0x1e800: 0x20040000, - 0x1f800: 0x20000080 - }, - { - 0x0: 0x10000008, - 0x100: 0x2000, - 0x200: 0x10200000, - 0x300: 0x10202008, - 0x400: 0x10002000, - 0x500: 0x200000, - 0x600: 0x200008, - 0x700: 0x10000000, - 0x800: 0x0, - 0x900: 0x10002008, - 0xa00: 0x202000, - 0xb00: 0x8, - 0xc00: 0x10200008, - 0xd00: 0x202008, - 0xe00: 0x2008, - 0xf00: 0x10202000, - 0x80: 0x10200000, - 0x180: 0x10202008, - 0x280: 0x8, - 0x380: 0x200000, - 0x480: 0x202008, - 0x580: 0x10000008, - 0x680: 0x10002000, - 0x780: 0x2008, - 0x880: 0x200008, - 0x980: 0x2000, - 0xa80: 0x10002008, - 0xb80: 0x10200008, - 0xc80: 0x0, - 0xd80: 0x10202000, - 0xe80: 0x202000, - 0xf80: 0x10000000, - 0x1000: 0x10002000, - 0x1100: 0x10200008, - 0x1200: 0x10202008, - 0x1300: 0x2008, - 0x1400: 0x200000, - 0x1500: 0x10000000, - 0x1600: 0x10000008, - 0x1700: 0x202000, - 0x1800: 0x202008, - 0x1900: 0x0, - 0x1a00: 0x8, - 0x1b00: 0x10200000, - 0x1c00: 0x2000, - 0x1d00: 0x10002008, - 0x1e00: 0x10202000, - 0x1f00: 0x200008, - 0x1080: 0x8, - 0x1180: 0x202000, - 0x1280: 0x200000, - 0x1380: 0x10000008, - 0x1480: 0x10002000, - 0x1580: 0x2008, - 0x1680: 0x10202008, - 0x1780: 0x10200000, - 0x1880: 0x10202000, - 0x1980: 0x10200008, - 0x1a80: 0x2000, - 0x1b80: 0x202008, - 0x1c80: 0x200008, - 0x1d80: 0x0, - 0x1e80: 0x10000000, - 0x1f80: 0x10002008 - }, - { - 0x0: 0x100000, - 0x10: 0x2000401, - 0x20: 0x400, - 0x30: 0x100401, - 0x40: 0x2100401, - 0x50: 0x0, - 0x60: 0x1, - 0x70: 0x2100001, - 0x80: 0x2000400, - 0x90: 0x100001, - 0xa0: 0x2000001, - 0xb0: 0x2100400, - 0xc0: 0x2100000, - 0xd0: 0x401, - 0xe0: 0x100400, - 0xf0: 0x2000000, - 0x8: 0x2100001, - 0x18: 0x0, - 0x28: 0x2000401, - 0x38: 0x2100400, - 0x48: 0x100000, - 0x58: 0x2000001, - 0x68: 0x2000000, - 0x78: 0x401, - 0x88: 0x100401, - 0x98: 0x2000400, - 0xa8: 0x2100000, - 0xb8: 0x100001, - 0xc8: 0x400, - 0xd8: 0x2100401, - 0xe8: 0x1, - 0xf8: 0x100400, - 0x100: 0x2000000, - 0x110: 0x100000, - 0x120: 0x2000401, - 0x130: 0x2100001, - 0x140: 0x100001, - 0x150: 0x2000400, - 0x160: 0x2100400, - 0x170: 0x100401, - 0x180: 0x401, - 0x190: 0x2100401, - 0x1a0: 0x100400, - 0x1b0: 0x1, - 0x1c0: 0x0, - 0x1d0: 0x2100000, - 0x1e0: 0x2000001, - 0x1f0: 0x400, - 0x108: 0x100400, - 0x118: 0x2000401, - 0x128: 0x2100001, - 0x138: 0x1, - 0x148: 0x2000000, - 0x158: 0x100000, - 0x168: 0x401, - 0x178: 0x2100400, - 0x188: 0x2000001, - 0x198: 0x2100000, - 0x1a8: 0x0, - 0x1b8: 0x2100401, - 0x1c8: 0x100401, - 0x1d8: 0x400, - 0x1e8: 0x2000400, - 0x1f8: 0x100001 - }, - { - 0x0: 0x8000820, - 0x1: 0x20000, - 0x2: 0x8000000, - 0x3: 0x20, - 0x4: 0x20020, - 0x5: 0x8020820, - 0x6: 0x8020800, - 0x7: 0x800, - 0x8: 0x8020000, - 0x9: 0x8000800, - 0xa: 0x20800, - 0xb: 0x8020020, - 0xc: 0x820, - 0xd: 0x0, - 0xe: 0x8000020, - 0xf: 0x20820, - 0x80000000: 0x800, - 0x80000001: 0x8020820, - 0x80000002: 0x8000820, - 0x80000003: 0x8000000, - 0x80000004: 0x8020000, - 0x80000005: 0x20800, - 0x80000006: 0x20820, - 0x80000007: 0x20, - 0x80000008: 0x8000020, - 0x80000009: 0x820, - 0x8000000a: 0x20020, - 0x8000000b: 0x8020800, - 0x8000000c: 0x0, - 0x8000000d: 0x8020020, - 0x8000000e: 0x8000800, - 0x8000000f: 0x20000, - 0x10: 0x20820, - 0x11: 0x8020800, - 0x12: 0x20, - 0x13: 0x800, - 0x14: 0x8000800, - 0x15: 0x8000020, - 0x16: 0x8020020, - 0x17: 0x20000, - 0x18: 0x0, - 0x19: 0x20020, - 0x1a: 0x8020000, - 0x1b: 0x8000820, - 0x1c: 0x8020820, - 0x1d: 0x20800, - 0x1e: 0x820, - 0x1f: 0x8000000, - 0x80000010: 0x20000, - 0x80000011: 0x800, - 0x80000012: 0x8020020, - 0x80000013: 0x20820, - 0x80000014: 0x20, - 0x80000015: 0x8020000, - 0x80000016: 0x8000000, - 0x80000017: 0x8000820, - 0x80000018: 0x8020820, - 0x80000019: 0x8000020, - 0x8000001a: 0x8000800, - 0x8000001b: 0x0, - 0x8000001c: 0x20800, - 0x8000001d: 0x820, - 0x8000001e: 0x20020, - 0x8000001f: 0x8020800 - } - ]; - - // Masks that select the SBOX input - var SBOX_MASK = [ - 0xf8000001, 0x1f800000, 0x01f80000, 0x001f8000, - 0x0001f800, 0x00001f80, 0x000001f8, 0x8000001f - ]; - - /** - * DES block cipher algorithm. - */ - var DES = C_algo.DES = BlockCipher.extend({ - _doReset: function () { - // Shortcuts - var key = this._key; - var keyWords = key.words; - - // Select 56 bits according to PC1 - var keyBits = []; - for (var i = 0; i < 56; i++) { - var keyBitPos = PC1[i] - 1; - keyBits[i] = (keyWords[keyBitPos >>> 5] >>> (31 - keyBitPos % 32)) & 1; - } - - // Assemble 16 subkeys - var subKeys = this._subKeys = []; - for (var nSubKey = 0; nSubKey < 16; nSubKey++) { - // Create subkey - var subKey = subKeys[nSubKey] = []; - - // Shortcut - var bitShift = BIT_SHIFTS[nSubKey]; - - // Select 48 bits according to PC2 - for (var i = 0; i < 24; i++) { - // Select from the left 28 key bits - subKey[(i / 6) | 0] |= keyBits[((PC2[i] - 1) + bitShift) % 28] << (31 - i % 6); - - // Select from the right 28 key bits - subKey[4 + ((i / 6) | 0)] |= keyBits[28 + (((PC2[i + 24] - 1) + bitShift) % 28)] << (31 - i % 6); - } - - // Since each subkey is applied to an expanded 32-bit input, - // the subkey can be broken into 8 values scaled to 32-bits, - // which allows the key to be used without expansion - subKey[0] = (subKey[0] << 1) | (subKey[0] >>> 31); - for (var i = 1; i < 7; i++) { - subKey[i] = subKey[i] >>> ((i - 1) * 4 + 3); - } - subKey[7] = (subKey[7] << 5) | (subKey[7] >>> 27); - } - - // Compute inverse subkeys - var invSubKeys = this._invSubKeys = []; - for (var i = 0; i < 16; i++) { - invSubKeys[i] = subKeys[15 - i]; - } - }, - - encryptBlock: function (M, offset) { - this._doCryptBlock(M, offset, this._subKeys); - }, - - decryptBlock: function (M, offset) { - this._doCryptBlock(M, offset, this._invSubKeys); - }, - - _doCryptBlock: function (M, offset, subKeys) { - // Get input - this._lBlock = M[offset]; - this._rBlock = M[offset + 1]; - - // Initial permutation - exchangeLR.call(this, 4, 0x0f0f0f0f); - exchangeLR.call(this, 16, 0x0000ffff); - exchangeRL.call(this, 2, 0x33333333); - exchangeRL.call(this, 8, 0x00ff00ff); - exchangeLR.call(this, 1, 0x55555555); - - // Rounds - for (var round = 0; round < 16; round++) { - // Shortcuts - var subKey = subKeys[round]; - var lBlock = this._lBlock; - var rBlock = this._rBlock; - - // Feistel function - var f = 0; - for (var i = 0; i < 8; i++) { - f |= SBOX_P[i][((rBlock ^ subKey[i]) & SBOX_MASK[i]) >>> 0]; - } - this._lBlock = rBlock; - this._rBlock = lBlock ^ f; - } - - // Undo swap from last round - var t = this._lBlock; - this._lBlock = this._rBlock; - this._rBlock = t; - - // Final permutation - exchangeLR.call(this, 1, 0x55555555); - exchangeRL.call(this, 8, 0x00ff00ff); - exchangeRL.call(this, 2, 0x33333333); - exchangeLR.call(this, 16, 0x0000ffff); - exchangeLR.call(this, 4, 0x0f0f0f0f); - - // Set output - M[offset] = this._lBlock; - M[offset + 1] = this._rBlock; - }, - - keySize: 64/32, - - ivSize: 64/32, - - blockSize: 64/32 - }); - - // Swap bits across the left and right words - function exchangeLR(offset, mask) { - var t = ((this._lBlock >>> offset) ^ this._rBlock) & mask; - this._rBlock ^= t; - this._lBlock ^= t << offset; - } - - function exchangeRL(offset, mask) { - var t = ((this._rBlock >>> offset) ^ this._lBlock) & mask; - this._lBlock ^= t; - this._rBlock ^= t << offset; - } - - /** - * Shortcut functions to the cipher's object interface. - * - * @example - * - * var ciphertext = CryptoJS.DES.encrypt(message, key, cfg); - * var plaintext = CryptoJS.DES.decrypt(ciphertext, key, cfg); - */ - C.DES = BlockCipher._createHelper(DES); - - /** - * Triple-DES block cipher algorithm. - */ - var TripleDES = C_algo.TripleDES = BlockCipher.extend({ - _doReset: function () { - // Shortcuts - var key = this._key; - var keyWords = key.words; - - // Create DES instances - this._des1 = DES.createEncryptor(WordArray.create(keyWords.slice(0, 2))); - this._des2 = DES.createEncryptor(WordArray.create(keyWords.slice(2, 4))); - this._des3 = DES.createEncryptor(WordArray.create(keyWords.slice(4, 6))); - }, - - encryptBlock: function (M, offset) { - this._des1.encryptBlock(M, offset); - this._des2.decryptBlock(M, offset); - this._des3.encryptBlock(M, offset); - }, - - decryptBlock: function (M, offset) { - this._des3.decryptBlock(M, offset); - this._des2.encryptBlock(M, offset); - this._des1.decryptBlock(M, offset); - }, - - keySize: 192/32, - - ivSize: 64/32, - - blockSize: 64/32 - }); - - /** - * Shortcut functions to the cipher's object interface. - * - * @example - * - * var ciphertext = CryptoJS.TripleDES.encrypt(message, key, cfg); - * var plaintext = CryptoJS.TripleDES.decrypt(ciphertext, key, cfg); - */ - C.TripleDES = BlockCipher._createHelper(TripleDES); - }()); - - - (function () { - // Shortcuts - var C = CryptoJS; - var C_lib = C.lib; - var StreamCipher = C_lib.StreamCipher; - var C_algo = C.algo; - - /** - * RC4 stream cipher algorithm. - */ - var RC4 = C_algo.RC4 = StreamCipher.extend({ - _doReset: function () { - // Shortcuts - var key = this._key; - var keyWords = key.words; - var keySigBytes = key.sigBytes; - - // Init sbox - var S = this._S = []; - for (var i = 0; i < 256; i++) { - S[i] = i; - } - - // Key setup - for (var i = 0, j = 0; i < 256; i++) { - var keyByteIndex = i % keySigBytes; - var keyByte = (keyWords[keyByteIndex >>> 2] >>> (24 - (keyByteIndex % 4) * 8)) & 0xff; - - j = (j + S[i] + keyByte) % 256; - - // Swap - var t = S[i]; - S[i] = S[j]; - S[j] = t; - } - - // Counters - this._i = this._j = 0; - }, - - _doProcessBlock: function (M, offset) { - M[offset] ^= generateKeystreamWord.call(this); - }, - - keySize: 256/32, - - ivSize: 0 - }); - - function generateKeystreamWord() { - // Shortcuts - var S = this._S; - var i = this._i; - var j = this._j; - - // Generate keystream word - var keystreamWord = 0; - for (var n = 0; n < 4; n++) { - i = (i + 1) % 256; - j = (j + S[i]) % 256; - - // Swap - var t = S[i]; - S[i] = S[j]; - S[j] = t; - - keystreamWord |= S[(S[i] + S[j]) % 256] << (24 - n * 8); - } - - // Update counters - this._i = i; - this._j = j; - - return keystreamWord; - } - - /** - * Shortcut functions to the cipher's object interface. - * - * @example - * - * var ciphertext = CryptoJS.RC4.encrypt(message, key, cfg); - * var plaintext = CryptoJS.RC4.decrypt(ciphertext, key, cfg); - */ - C.RC4 = StreamCipher._createHelper(RC4); - - /** - * Modified RC4 stream cipher algorithm. - */ - var RC4Drop = C_algo.RC4Drop = RC4.extend({ - /** - * Configuration options. - * - * @property {number} drop The number of keystream words to drop. Default 192 - */ - cfg: RC4.cfg.extend({ - drop: 192 - }), - - _doReset: function () { - RC4._doReset.call(this); - - // Drop - for (var i = this.cfg.drop; i > 0; i--) { - generateKeystreamWord.call(this); - } - } - }); - - /** - * Shortcut functions to the cipher's object interface. - * - * @example - * - * var ciphertext = CryptoJS.RC4Drop.encrypt(message, key, cfg); - * var plaintext = CryptoJS.RC4Drop.decrypt(ciphertext, key, cfg); - */ - C.RC4Drop = StreamCipher._createHelper(RC4Drop); - }()); - - - /** @preserve - * Counter block mode compatible with Dr Brian Gladman fileenc.c - * derived from CryptoJS.mode.CTR - * Jan Hruby jhruby.web@gmail.com - */ - CryptoJS.mode.CTRGladman = (function () { - var CTRGladman = CryptoJS.lib.BlockCipherMode.extend(); - - function incWord(word) - { - if (((word >> 24) & 0xff) === 0xff) { //overflow - var b1 = (word >> 16)&0xff; - var b2 = (word >> 8)&0xff; - var b3 = word & 0xff; - - if (b1 === 0xff) // overflow b1 - { - b1 = 0; - if (b2 === 0xff) - { - b2 = 0; - if (b3 === 0xff) - { - b3 = 0; - } - else - { - ++b3; - } - } - else - { - ++b2; - } - } - else - { - ++b1; - } - - word = 0; - word += (b1 << 16); - word += (b2 << 8); - word += b3; - } - else - { - word += (0x01 << 24); - } - return word; - } - - function incCounter(counter) - { - if ((counter[0] = incWord(counter[0])) === 0) - { - // encr_data in fileenc.c from Dr Brian Gladman's counts only with DWORD j < 8 - counter[1] = incWord(counter[1]); - } - return counter; - } - - var Encryptor = CTRGladman.Encryptor = CTRGladman.extend({ - processBlock: function (words, offset) { - // Shortcuts - var cipher = this._cipher - var blockSize = cipher.blockSize; - var iv = this._iv; - var counter = this._counter; - - // Generate keystream - if (iv) { - counter = this._counter = iv.slice(0); - - // Remove IV for subsequent blocks - this._iv = undefined; - } - - incCounter(counter); - - var keystream = counter.slice(0); - cipher.encryptBlock(keystream, 0); - - // Encrypt - for (var i = 0; i < blockSize; i++) { - words[offset + i] ^= keystream[i]; - } - } - }); - - CTRGladman.Decryptor = Encryptor; - - return CTRGladman; - }()); - - - - - (function () { - // Shortcuts - var C = CryptoJS; - var C_lib = C.lib; - var StreamCipher = C_lib.StreamCipher; - var C_algo = C.algo; - - // Reusable objects - var S = []; - var C_ = []; - var G = []; - - /** - * Rabbit stream cipher algorithm - */ - var Rabbit = C_algo.Rabbit = StreamCipher.extend({ - _doReset: function () { - // Shortcuts - var K = this._key.words; - var iv = this.cfg.iv; - - // Swap endian - for (var i = 0; i < 4; i++) { - K[i] = (((K[i] << 8) | (K[i] >>> 24)) & 0x00ff00ff) | - (((K[i] << 24) | (K[i] >>> 8)) & 0xff00ff00); - } - - // Generate initial state values - var X = this._X = [ - K[0], (K[3] << 16) | (K[2] >>> 16), - K[1], (K[0] << 16) | (K[3] >>> 16), - K[2], (K[1] << 16) | (K[0] >>> 16), - K[3], (K[2] << 16) | (K[1] >>> 16) - ]; - - // Generate initial counter values - var C = this._C = [ - (K[2] << 16) | (K[2] >>> 16), (K[0] & 0xffff0000) | (K[1] & 0x0000ffff), - (K[3] << 16) | (K[3] >>> 16), (K[1] & 0xffff0000) | (K[2] & 0x0000ffff), - (K[0] << 16) | (K[0] >>> 16), (K[2] & 0xffff0000) | (K[3] & 0x0000ffff), - (K[1] << 16) | (K[1] >>> 16), (K[3] & 0xffff0000) | (K[0] & 0x0000ffff) - ]; - - // Carry bit - this._b = 0; - - // Iterate the system four times - for (var i = 0; i < 4; i++) { - nextState.call(this); - } - - // Modify the counters - for (var i = 0; i < 8; i++) { - C[i] ^= X[(i + 4) & 7]; - } - - // IV setup - if (iv) { - // Shortcuts - var IV = iv.words; - var IV_0 = IV[0]; - var IV_1 = IV[1]; - - // Generate four subvectors - var i0 = (((IV_0 << 8) | (IV_0 >>> 24)) & 0x00ff00ff) | (((IV_0 << 24) | (IV_0 >>> 8)) & 0xff00ff00); - var i2 = (((IV_1 << 8) | (IV_1 >>> 24)) & 0x00ff00ff) | (((IV_1 << 24) | (IV_1 >>> 8)) & 0xff00ff00); - var i1 = (i0 >>> 16) | (i2 & 0xffff0000); - var i3 = (i2 << 16) | (i0 & 0x0000ffff); - - // Modify counter values - C[0] ^= i0; - C[1] ^= i1; - C[2] ^= i2; - C[3] ^= i3; - C[4] ^= i0; - C[5] ^= i1; - C[6] ^= i2; - C[7] ^= i3; - - // Iterate the system four times - for (var i = 0; i < 4; i++) { - nextState.call(this); - } - } - }, - - _doProcessBlock: function (M, offset) { - // Shortcut - var X = this._X; - - // Iterate the system - nextState.call(this); - - // Generate four keystream words - S[0] = X[0] ^ (X[5] >>> 16) ^ (X[3] << 16); - S[1] = X[2] ^ (X[7] >>> 16) ^ (X[5] << 16); - S[2] = X[4] ^ (X[1] >>> 16) ^ (X[7] << 16); - S[3] = X[6] ^ (X[3] >>> 16) ^ (X[1] << 16); - - for (var i = 0; i < 4; i++) { - // Swap endian - S[i] = (((S[i] << 8) | (S[i] >>> 24)) & 0x00ff00ff) | - (((S[i] << 24) | (S[i] >>> 8)) & 0xff00ff00); - - // Encrypt - M[offset + i] ^= S[i]; - } - }, - - blockSize: 128/32, - - ivSize: 64/32 - }); - - function nextState() { - // Shortcuts - var X = this._X; - var C = this._C; - - // Save old counter values - for (var i = 0; i < 8; i++) { - C_[i] = C[i]; - } - - // Calculate new counter values - C[0] = (C[0] + 0x4d34d34d + this._b) | 0; - C[1] = (C[1] + 0xd34d34d3 + ((C[0] >>> 0) < (C_[0] >>> 0) ? 1 : 0)) | 0; - C[2] = (C[2] + 0x34d34d34 + ((C[1] >>> 0) < (C_[1] >>> 0) ? 1 : 0)) | 0; - C[3] = (C[3] + 0x4d34d34d + ((C[2] >>> 0) < (C_[2] >>> 0) ? 1 : 0)) | 0; - C[4] = (C[4] + 0xd34d34d3 + ((C[3] >>> 0) < (C_[3] >>> 0) ? 1 : 0)) | 0; - C[5] = (C[5] + 0x34d34d34 + ((C[4] >>> 0) < (C_[4] >>> 0) ? 1 : 0)) | 0; - C[6] = (C[6] + 0x4d34d34d + ((C[5] >>> 0) < (C_[5] >>> 0) ? 1 : 0)) | 0; - C[7] = (C[7] + 0xd34d34d3 + ((C[6] >>> 0) < (C_[6] >>> 0) ? 1 : 0)) | 0; - this._b = (C[7] >>> 0) < (C_[7] >>> 0) ? 1 : 0; - - // Calculate the g-values - for (var i = 0; i < 8; i++) { - var gx = X[i] + C[i]; - - // Construct high and low argument for squaring - var ga = gx & 0xffff; - var gb = gx >>> 16; - - // Calculate high and low result of squaring - var gh = ((((ga * ga) >>> 17) + ga * gb) >>> 15) + gb * gb; - var gl = (((gx & 0xffff0000) * gx) | 0) + (((gx & 0x0000ffff) * gx) | 0); - - // High XOR low - G[i] = gh ^ gl; - } - - // Calculate new state values - X[0] = (G[0] + ((G[7] << 16) | (G[7] >>> 16)) + ((G[6] << 16) | (G[6] >>> 16))) | 0; - X[1] = (G[1] + ((G[0] << 8) | (G[0] >>> 24)) + G[7]) | 0; - X[2] = (G[2] + ((G[1] << 16) | (G[1] >>> 16)) + ((G[0] << 16) | (G[0] >>> 16))) | 0; - X[3] = (G[3] + ((G[2] << 8) | (G[2] >>> 24)) + G[1]) | 0; - X[4] = (G[4] + ((G[3] << 16) | (G[3] >>> 16)) + ((G[2] << 16) | (G[2] >>> 16))) | 0; - X[5] = (G[5] + ((G[4] << 8) | (G[4] >>> 24)) + G[3]) | 0; - X[6] = (G[6] + ((G[5] << 16) | (G[5] >>> 16)) + ((G[4] << 16) | (G[4] >>> 16))) | 0; - X[7] = (G[7] + ((G[6] << 8) | (G[6] >>> 24)) + G[5]) | 0; - } - - /** - * Shortcut functions to the cipher's object interface. - * - * @example - * - * var ciphertext = CryptoJS.Rabbit.encrypt(message, key, cfg); - * var plaintext = CryptoJS.Rabbit.decrypt(ciphertext, key, cfg); - */ - C.Rabbit = StreamCipher._createHelper(Rabbit); - }()); - - - /** - * Counter block mode. - */ - CryptoJS.mode.CTR = (function () { - var CTR = CryptoJS.lib.BlockCipherMode.extend(); - - var Encryptor = CTR.Encryptor = CTR.extend({ - processBlock: function (words, offset) { - // Shortcuts - var cipher = this._cipher - var blockSize = cipher.blockSize; - var iv = this._iv; - var counter = this._counter; - - // Generate keystream - if (iv) { - counter = this._counter = iv.slice(0); - - // Remove IV for subsequent blocks - this._iv = undefined; - } - var keystream = counter.slice(0); - cipher.encryptBlock(keystream, 0); - - // Increment counter - counter[blockSize - 1] = (counter[blockSize - 1] + 1) | 0 - - // Encrypt - for (var i = 0; i < blockSize; i++) { - words[offset + i] ^= keystream[i]; - } - } - }); - - CTR.Decryptor = Encryptor; - - return CTR; - }()); - - - (function () { - // Shortcuts - var C = CryptoJS; - var C_lib = C.lib; - var StreamCipher = C_lib.StreamCipher; - var C_algo = C.algo; - - // Reusable objects - var S = []; - var C_ = []; - var G = []; - - /** - * Rabbit stream cipher algorithm. - * - * This is a legacy version that neglected to convert the key to little-endian. - * This error doesn't affect the cipher's security, - * but it does affect its compatibility with other implementations. - */ - var RabbitLegacy = C_algo.RabbitLegacy = StreamCipher.extend({ - _doReset: function () { - // Shortcuts - var K = this._key.words; - var iv = this.cfg.iv; - - // Generate initial state values - var X = this._X = [ - K[0], (K[3] << 16) | (K[2] >>> 16), - K[1], (K[0] << 16) | (K[3] >>> 16), - K[2], (K[1] << 16) | (K[0] >>> 16), - K[3], (K[2] << 16) | (K[1] >>> 16) - ]; - - // Generate initial counter values - var C = this._C = [ - (K[2] << 16) | (K[2] >>> 16), (K[0] & 0xffff0000) | (K[1] & 0x0000ffff), - (K[3] << 16) | (K[3] >>> 16), (K[1] & 0xffff0000) | (K[2] & 0x0000ffff), - (K[0] << 16) | (K[0] >>> 16), (K[2] & 0xffff0000) | (K[3] & 0x0000ffff), - (K[1] << 16) | (K[1] >>> 16), (K[3] & 0xffff0000) | (K[0] & 0x0000ffff) - ]; - - // Carry bit - this._b = 0; - - // Iterate the system four times - for (var i = 0; i < 4; i++) { - nextState.call(this); - } - - // Modify the counters - for (var i = 0; i < 8; i++) { - C[i] ^= X[(i + 4) & 7]; - } - - // IV setup - if (iv) { - // Shortcuts - var IV = iv.words; - var IV_0 = IV[0]; - var IV_1 = IV[1]; - - // Generate four subvectors - var i0 = (((IV_0 << 8) | (IV_0 >>> 24)) & 0x00ff00ff) | (((IV_0 << 24) | (IV_0 >>> 8)) & 0xff00ff00); - var i2 = (((IV_1 << 8) | (IV_1 >>> 24)) & 0x00ff00ff) | (((IV_1 << 24) | (IV_1 >>> 8)) & 0xff00ff00); - var i1 = (i0 >>> 16) | (i2 & 0xffff0000); - var i3 = (i2 << 16) | (i0 & 0x0000ffff); - - // Modify counter values - C[0] ^= i0; - C[1] ^= i1; - C[2] ^= i2; - C[3] ^= i3; - C[4] ^= i0; - C[5] ^= i1; - C[6] ^= i2; - C[7] ^= i3; - - // Iterate the system four times - for (var i = 0; i < 4; i++) { - nextState.call(this); - } - } - }, - - _doProcessBlock: function (M, offset) { - // Shortcut - var X = this._X; - - // Iterate the system - nextState.call(this); - - // Generate four keystream words - S[0] = X[0] ^ (X[5] >>> 16) ^ (X[3] << 16); - S[1] = X[2] ^ (X[7] >>> 16) ^ (X[5] << 16); - S[2] = X[4] ^ (X[1] >>> 16) ^ (X[7] << 16); - S[3] = X[6] ^ (X[3] >>> 16) ^ (X[1] << 16); - - for (var i = 0; i < 4; i++) { - // Swap endian - S[i] = (((S[i] << 8) | (S[i] >>> 24)) & 0x00ff00ff) | - (((S[i] << 24) | (S[i] >>> 8)) & 0xff00ff00); - - // Encrypt - M[offset + i] ^= S[i]; - } - }, - - blockSize: 128/32, - - ivSize: 64/32 - }); - - function nextState() { - // Shortcuts - var X = this._X; - var C = this._C; - - // Save old counter values - for (var i = 0; i < 8; i++) { - C_[i] = C[i]; - } - - // Calculate new counter values - C[0] = (C[0] + 0x4d34d34d + this._b) | 0; - C[1] = (C[1] + 0xd34d34d3 + ((C[0] >>> 0) < (C_[0] >>> 0) ? 1 : 0)) | 0; - C[2] = (C[2] + 0x34d34d34 + ((C[1] >>> 0) < (C_[1] >>> 0) ? 1 : 0)) | 0; - C[3] = (C[3] + 0x4d34d34d + ((C[2] >>> 0) < (C_[2] >>> 0) ? 1 : 0)) | 0; - C[4] = (C[4] + 0xd34d34d3 + ((C[3] >>> 0) < (C_[3] >>> 0) ? 1 : 0)) | 0; - C[5] = (C[5] + 0x34d34d34 + ((C[4] >>> 0) < (C_[4] >>> 0) ? 1 : 0)) | 0; - C[6] = (C[6] + 0x4d34d34d + ((C[5] >>> 0) < (C_[5] >>> 0) ? 1 : 0)) | 0; - C[7] = (C[7] + 0xd34d34d3 + ((C[6] >>> 0) < (C_[6] >>> 0) ? 1 : 0)) | 0; - this._b = (C[7] >>> 0) < (C_[7] >>> 0) ? 1 : 0; - - // Calculate the g-values - for (var i = 0; i < 8; i++) { - var gx = X[i] + C[i]; - - // Construct high and low argument for squaring - var ga = gx & 0xffff; - var gb = gx >>> 16; - - // Calculate high and low result of squaring - var gh = ((((ga * ga) >>> 17) + ga * gb) >>> 15) + gb * gb; - var gl = (((gx & 0xffff0000) * gx) | 0) + (((gx & 0x0000ffff) * gx) | 0); - - // High XOR low - G[i] = gh ^ gl; - } - - // Calculate new state values - X[0] = (G[0] + ((G[7] << 16) | (G[7] >>> 16)) + ((G[6] << 16) | (G[6] >>> 16))) | 0; - X[1] = (G[1] + ((G[0] << 8) | (G[0] >>> 24)) + G[7]) | 0; - X[2] = (G[2] + ((G[1] << 16) | (G[1] >>> 16)) + ((G[0] << 16) | (G[0] >>> 16))) | 0; - X[3] = (G[3] + ((G[2] << 8) | (G[2] >>> 24)) + G[1]) | 0; - X[4] = (G[4] + ((G[3] << 16) | (G[3] >>> 16)) + ((G[2] << 16) | (G[2] >>> 16))) | 0; - X[5] = (G[5] + ((G[4] << 8) | (G[4] >>> 24)) + G[3]) | 0; - X[6] = (G[6] + ((G[5] << 16) | (G[5] >>> 16)) + ((G[4] << 16) | (G[4] >>> 16))) | 0; - X[7] = (G[7] + ((G[6] << 8) | (G[6] >>> 24)) + G[5]) | 0; - } - - /** - * Shortcut functions to the cipher's object interface. - * - * @example - * - * var ciphertext = CryptoJS.RabbitLegacy.encrypt(message, key, cfg); - * var plaintext = CryptoJS.RabbitLegacy.decrypt(ciphertext, key, cfg); - */ - C.RabbitLegacy = StreamCipher._createHelper(RabbitLegacy); - }()); - - - /** - * Zero padding strategy. - */ - CryptoJS.pad.ZeroPadding = { - pad: function (data, blockSize) { - // Shortcut - var blockSizeBytes = blockSize * 4; - - // Pad - data.clamp(); - data.sigBytes += blockSizeBytes - ((data.sigBytes % blockSizeBytes) || blockSizeBytes); - }, - - unpad: function (data) { - // Shortcut - var dataWords = data.words; - - // Unpad - var i = data.sigBytes - 1; - while (!((dataWords[i >>> 2] >>> (24 - (i % 4) * 8)) & 0xff)) { - i--; - } - data.sigBytes = i + 1; - } - }; - - - return CryptoJS; - -})); \ No newline at end of file diff --git a/docs/lvdeshui-film.html b/docs/lvdeshui-film.html index a8283c5..e69de29 100644 --- a/docs/lvdeshui-film.html +++ b/docs/lvdeshui-film.html @@ -1,537 +0,0 @@ - - - - - - 《驴得水》——影评 | 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - -
    - - - - -
    -
    - - -
    - - - - - -

    - 《驴得水》——影评 -

    - - -
    - - -
    - - - - - -
    -

    追求自由的人,疯了,死了。
    -不愿低头的人,成了听话的牲口。
    -宽容大度的人,成了唯利是图的小人。
    -淳朴憨厚的人,成了狡诈的恶棍。
    -正面积极的人,用谎言掩盖真相。

    -
    -

    你觉得这是电影吗?其实,这是现实。我们先来看一下电影故事讲的是什么:

    -

    一群怀揣伟大梦想的人,却敌不过山区缺水的现实,养了一头驴拉水。上头却不给养驴费,于是就把驴谎报成老师。上头来检查,不能因为一头驴毁了梦想啊。于是为了捍卫梦想的道路,却失去了梦想的意义。《驴得水》的海报上说,“讲个笑话,你可别哭啊”。 就像另一句笑话讲的那样, “小的时候我想拯救世界,长大后却发现世界都拯救不了我”。

    -

    好笑,但却想哭。

    -

    谁TM还没点梦想啊。但有时梦想很脆弱,甚至敌不过一碗炸酱面。你想让自己闪闪发光,但总得先养活自己,饿着肚子的人怎么去谈梦想?这也是很多刚毕业不久的人,所要面对的最为矛盾的情况。“我有很多想法,有很多想做的事。但我现在没钱、没人脉、没背景,甚至还没长相。想要出去闯一片天地, 但还要为一日三餐和落脚地打拼。梦想是高潮,现实却是性冷淡。还能怎么办呢?先养活自己再说吧”。于是,你找了一份莫名其妙的工作,你一日三餐是不愁了,你做着日复一日重复的工作,但是你不敢停,你越来越迷茫,越来越看不清生活的方向。

    -

    你害怕那种怀揣梦想,但却又碌碌无为的日子,但你却不知道从哪里开始改变。于是你只能在焦虑中慢慢对现实妥协,然后你变成了自己曾经最讨厌的那种人。冷漠、没有激情、不思进取、浑浑噩噩,就像影片中的人物一样。曾经那些他们坚信的东西在面对现实时,都变得不堪一击。铁男说,“我没有办法啊,你知道子弹从脸上呼啸而过的感觉吗”?像不像我们经常说的,“我没办法啊,现实就是这样”。

    -

    是啊,现实就是这样!作为芸芸众生,普通屁民,谁TM还没被现实强奸过啊。但想要活得更好,重要的不是治愈,而是带着病痛活下去。而且我们要清醒的认识到一个事实,有时我们之所以像傻逼一样努力,不是为了改变世界,而是为了不让世界改变我们。或许,这才是我们对这个世界最大的善意。

    -
    - -
    -
    -
    -
    - - - - - - - - - - - -
    -
    - -
    -
    - - - - - - - -
    -
    -
    -
    - -
    -
    - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - - - \ No newline at end of file diff --git a/docs/mac-memo.html b/docs/mac-memo.html index 5414682..e69de29 100644 --- a/docs/mac-memo.html +++ b/docs/mac-memo.html @@ -1,635 +0,0 @@ - - - - - - Mac备忘录 | 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - -
    - - - - -
    -
    - - -
    - - - - - -

    - Mac备忘录 -

    - - -
    - - -
    - - - -
    - 文章目录 -
    1. 1. 指令和任务
      1. 1.1. 隐藏文件夹
      2. 1.2. 允许任何来源软件
      3. 1.3. 任务控制
    2. 2. 文件管理
      1. 2.1. 标签的使用
    3. 3. 通用技巧
      1. 3.1. 输入法
        1. 3.1.1. 查看按键字符
      2. 3.2. 通过Automator添加快捷键
      3. 3.3. 电源管理
      4. 3.4. 升级到Mojave后鼠标发飘
    4. 4. 网络资源
      1. 4.1. 应用软件
      2. 4.2. 在线文档
        1. 4.2.1. 升级SSD固态硬盘
    -
    - - - -

    指令和任务

    -

    隐藏文件夹

    -

    Terminal 命令

    -
    1
    2
    3
    4
    //显示隐藏文件
    defaults write com.apple.finder AppleShowAllFiles -bool true
    //不显示隐藏文件
    defaults write com.apple.finder AppleShowAllFiles -bool false
    -

    快速命令,打开访达窗口,然后 ⌘ + ⇧ + . 就可以隐藏/显示。

    -

    需要重启Finder使设置生效 :

    -
    -

    重启Finder:窗口左上角的苹果标志–>强制退出–>Finder–>重新启动

    -
    -

    允许任何来源软件

    -

    系统默认在 安全与隐私 里只显示 “App Store” 和 “App Store 和被认可的开发者”,没有 “任何来源”。开启的话需要在终端输入

    -

    sudo spctl --master-disable

    -

    并输入开机密码。

    -

    任务控制

    -
      -
    • -

      将任务放在后台运行:command + &

      -
    • -
    • -

      将任务丢到后台暂停:ctrl-z

      -
    • -
    • -

      查看后台所有任务状态:jobs -l (会列出 1、2、3序列号)

      -
    • -
    • -

      将后台的任务拿到前台处理:fg %jobnumber (指序列号,而不是任务id)

      -
    • -
    • -

      将后台的任务变成运行中:bg %jobnumber

      -
    • -
    • -

      管理后台当中的任务:kill -signal %jobnumber

      -
    • -
    -

    文件管理

    -

    标签的使用

    -

    参看 mac 标签的使用

    -

    通用技巧

    -

    输入法

    -

    查看按键字符

    -
      -
    1. 偏好设置 → 键盘 → 输入法,窗口右面会显示键盘⌨️图案,按住shift⇧键或者option⌥,会显示在不同功能键下面的字符。
    2. -
    -

    通过Automator添加快捷键

    -

    文章来源

    -
      -
    1. 一次打开 Finder —> 应用程序 —> automator
    2. -
    3. 选取 服务
    4. -
    5. 从左边的双栏选取 使用工具—>运行AppleScript, 并双击运行。
    6. -
    7. 出现文本框后选定(右栏最上边)没有输入
    8. -
    -
    1
    2
    3
    4
    5
    6
    7
    on run {input, parameters}
    (* Your script goes here *)
    tell application "Safari"
    reopen
    activate
    end tell
    end run
    -
      -
    1. ⌘+S 保存,命名为 Open Safari。关闭automator
    2. -
    3. 转到 系统偏好设置—>键盘—>快捷键—>服务—>通用—>open safari ,然后设定快捷键就好了。
    4. -
    -

    电源管理

    -

    pmsetmacOS下用来操作、电源管理的工具,可设定休眠模式、时间和唤醒时间或显示电源信息,不过因为它是一个命令列的指令,因此得透过终端机察看或修改设定。当你开启「终端机」输入pmset -g 会看到具体设置。

    -
      -
    • Standbydelay 28800 :将系统储存于內存中休眠,会消耗一些电力。
    • -
    • Autopowerofdelay 28800 : 把系统写入SSD硬盘中,将內存暂存关闭,依照这篇文章的说法,两者延迟时间28800秒(约八小时)会让电脑多维持內存八小时左右的电力。
    • -
    • tcpkeepalive :设定睡眠后是否还保持网络连接, 以便可以透过TCP唤醒系统
    • -
    • hibernatemode :睡眠模式。数字越小,耗电越高。可以设置为 25
    • -
    -
    1
    2
    3
    4
    sudo pmset -b autopoweroffdelay 300 # 将睡眠时间缩短为300秒(五分钟)
    sudo pmset -b standbydelay 300 # 然后将系统储存到SSD硬盘
    sudo pmset -b tcpkeepalive 0 # 将透过TCP唤醒系统的功能关闭
    sudo pmset -a hibernatemode 25
    -
    -

    中间的参数-b是使用电池下的参数,-c为外接电源下的参数设定, -a 为所有情况下的设定。

    -
    -

    升级到Mojave后鼠标发飘

    -

    前往偏好设置–>网络–>设定服务顺序(左下角齿轮),然后将蓝牙PAN拖到最上面。

    -

    网络资源

    -

    应用软件

    -
      -
    1. 大量破解资源分享的网站 MacEnjoy
    2. -
    -

    在线文档

    -

    iMac 2012 规格

    -

    升级SSD固态硬盘

    -

    iMac 2012 21.5吋 拆卸指南

    -

    Mac升级外挂SSD硬盘

    -

    如何选择另一个启动磁盘 :pen: 官方说明

    -

    更换SSD固态硬盘攻略

    -
      -
    1. -

      固态硬盘通过USB 3连接到电脑,并格式化成 Mac OS 扩展 格式。

      -

      -
    2. -
    3. -

      用 Carbon Copy Cloner(官网下载)把原硬盘的数据镜像到 SSD。完成后要制作恢复分区「Recovery HD」破解版下载地址

      -

      或者 SuperDuper :pen: 免费版可以全盘备份,而不支持增量操作。

      -

      -
    4. -
    5. -

      重启,听到 「当 」一声后按住 Option 键(windows 键盘上的 Alt)。然后选择SSD作为启动硬盘。

      -
    6. -
    7. -

      开机后用 Trim Enabler官网下载)开启 Trim 读写加速。:+1:

      -
    8. -
    - -
    - -
    -
    -
    -
    - - - - - - - - - - - -
    -
    - -
    -
    - - - - - - - -
    -
    -
    -
    - -
    -
    - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - - - \ No newline at end of file diff --git a/docs/mac-using-tags.html b/docs/mac-using-tags.html index 0a8b71b..e69de29 100644 --- a/docs/mac-using-tags.html +++ b/docs/mac-using-tags.html @@ -1,584 +0,0 @@ - - - - - - Mac使用标签 | 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - -
    - - - - -
    -
    - - -
    - - - - - -

    - Mac使用标签 -

    - - -
    - - -
    - - - -
    - 文章目录 -
    1. 1. 使用标签
    2. 2. 查找含有标签的项目
    3. 3. 移除标签
    4. 4. 编辑标签
    -
    - - - -

    使用标签

    -

    在 Mac 上,执行以下任一项操作:

    -
      -
    • 给打开的文件添加标签:将鼠标指针悬停在文稿标题右侧,点按箭头,在“标签”栏中点按,然后输入新标签,或者从列表中选取一个标签。
    • -
    • 存储新文件时添加标签:点按“文件”>“存储”。在“存储”对话框中,在“标签”栏中点按,然后输入新标签,或者从列表中选取一个标签。
    • -
    • 给桌面上或“访达”中的文件添加标签:选择项目,然后打开“文件”菜单。也可以按住 Control 键点按该项目,或用双指轻点它。在“标签”下方选取颜色img,或点按“标签”以从更多标签中进行选择或输入新标签。在“访达”窗口中,也可以选择该项目,点按“标签”按钮 img,然后输入新标签,或从列表中选取一个标签。
    • -
    -

    查找含有标签的项目

    -
      -
    1. 在 Mac 上,点按程序坞中的“访达”图标 img以打开“访达”窗口。
    2. -
    3. 请执行以下一项操作: -
        -
      • 搜索标签:在搜索栏中输入标签颜色或名称,然后从建议中选择该标签。
      • -
      • 在边栏中选择标签:若要查看带有某个标签的所有项目,请在“访达”边栏中点按标签img。若要更改在边栏中看到的项目,请选取“访达”>“偏好设置”,点按“标签”,然后选择想要查看的标签。
      • -
      • 按标签将项目分组: 点按“分组”按钮img,然后选取“标签”。
      • -
      • 按标签排序项目:在任何显示方式下,选取“显示”>“查看显示选项”,点按“排序方式”弹出式菜单,然后选取“标签”。在“列表显示”下,选择“标签”复选框以显示分栏,将指针移到“标签”分栏上方,然后点按。再次点按分栏名称来倒序排列。
      • -
      -
    4. -
    -

    移除标签

    -

    在 Mac 上,请执行以下一项操作:

    -
      -
    • 从项目中移除标签:按住 Control 键点按项目或使用双指轻点项目,然后点按“标签”。选择您想要移除的标签,然后按下 Delete 键。
    • -
    • 从 Mac 中移除标签:在“访达”中,选取“访达”>“偏好设置”,然后点按“标签”。选择您想要移除的标签,然后点按移除按钮——。
    • -
    -

    编辑标签

    -
      -
    1. 在 Mac 上的“访达”img中,选取“访达”>“偏好设置”,然后点按“标签”。
    2. -
    3. 请执行以下一项操作: -
        -
      • 在“访达”边栏中查看标签:选择标签右侧的蓝色复选框。
      • -
      • 更改标签颜色:点按标签img
      • -
      • 旁边的颜色,然后选取新的颜色。
      • -
      • 更改标签名称:点按标签,点按标签名称,然后输入新名称。
      • -
      • 创建新标签:点按添加按钮 img
      • -
      • 删除标签:选择标签,然后点按移除按钮 ——。
      • -
      • 将标签添加到快捷键菜单中:在列表中选择标签,然后将它拖到您想要在窗口底部的个人收藏部分中替换的标签上方。当您按下 Control 键点按文件时,在出现的快捷键菜单中可至多有七个标签。
      • -
      • 从快捷键菜单中移除标签:将标签拖出“个人收藏标签”部分,直到看到移除符号img
      • -
      -
    4. -
    - -
    - -
    -
    -
    -
    - - - - - - - - - - - -
    -
    - -
    -
    - - - - - - - -
    -
    -
    -
    - -
    -
    - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - - - \ No newline at end of file diff --git a/docs/mathjax-yixue-usage.html b/docs/mathjax-yixue-usage.html index 9c36d8c..e69de29 100644 --- a/docs/mathjax-yixue-usage.html +++ b/docs/mathjax-yixue-usage.html @@ -1,659 +0,0 @@ - - - - - - MathJax用于易学领域 | 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - -
    - - - - -
    -
    - - -
    - - - - - -

    - MathJax用于易学领域 -

    - - -
    - - -
    - - - -
    - 文章目录 -
    1. 1. 效果与演示
    2. 2. 安装和使用
      1. 2.1. 文本编辑器
        1. 2.1.1. Typora
        2. 2.1.2. VSCode
      2. 2.2. Hexo博客
      3. 2.3. Gitbook
    3. 3. API 参数
      1. 3.1. 易学通用
      2. 3.2. 六爻
      3. 3.3. 八字
    4. 4. 未来与展望
    5. 5. 附录:
      1. 5.1. 命令列表
      2. 5.2. 发布
      3. 5.3. 查看当前易学函数库版本
    -
    - - - -

    关于利用 MathJaxKatex 数学公式解释器,实现易学上排六爻盘和八字盘个功能。今天实现了易学上的核心功能。有望将来能添加更多的函数,以便利各位同门以及广大易友。

    - -

    效果与演示

    - -无法观看油管的朋友请移步B站:[使用MathJax渲染六爻和八字盘](https://www.bilibili.com/video/av66317810/) -

    安装和使用

    -

    首先,你需要一个支持 Markdown (简称MD) 语言格式的文本编辑器。如果不知道什么是MD的话,请参阅以下介绍:

    - -

    Markdown 语言简约而优美,可以自由转换成pdf、word、Html 等等各种其它格式的文本。可以推送到博客、微信公众号等等。虽然算卦是一个传统的行业,我们仍然不宜固步自封。MD语言支持MathJax和Katex书写Latex数学公式,可以写出非常漂亮的数学、物理、化学方面的公式。正式的科技刊物都要求用Latex格式。

    -

    这个易学解决方案是对 MathJax 进行扩展,加入指定的易学公式,让 MathJax 解释器去完成公式渲染。它并不是一个独立的程序。需要构建在已有的MD文本编辑器之上。我使用一个文件夹存放所有的关于易学方面的MD文件,并将这个文件夹同步到 坚果云,这样就可以实现多台电脑和移动端之间的同步,而不太需要一个独立的易学软件。甚至可以将MD文件导出为HTML文件,放到我的HEXO博客上(您正在阅读的这篇博文即是例子)。

    -

    理论上所有支持Markdown语言和MathJax的文本编辑器,都可以改装。改装过程需要两段代码和一个库文件。

    -

    文本编辑器

    -
    Typora
    -

    Typora 是我个人最钟爱的MD编辑器,因此这里着重介绍。如果你喜欢用别的MD编辑器,比如iAWrte等,理论上可以用同样的方式改装。(无法百分百保证) 有需要的朋友可以私下联系我。

    -

    最新的安装教程请参考华鹤易学平台文档

    -
    VSCode
    -

    同样请移步华鹤易学平台文档。那里有详细描述。

    -

    Hexo博客

    -

    🔔 注意:首先要检查自己的 Hexo 博客使用的渲染器是否默认开启了Katex或者MathJax数学插件。如果有的话需要卸载或者禁用数学插件,如果不能禁用,就必须更换Markdown渲染器。

    -
    -

    因为系统使用的数学插件会在网页生成之前就改动数学表达,这样无法使用我提供给的函数库。我提供给博客的方案是在浏览网页的时候,即时渲染易学公式。

    -
    -

    比如我之前用了 “hexo-renderer-markdown-it-plus” 渲染器就是强制使用 Katex 数学渲染的。

    -
    1
    2
    npm un hexo-renderer-markdown-it-plus --save // 卸载
    npm i hexo-renderer-markdown-it --save // 更换
    -

    然后将下列代码添加到文件模版就可以了。使用 swig 模版的是在 <your thems>/layout/_custom/header.swig 或者 <your thems>/layout/index.swig 。而使用 ejs 模版的是文件 <your thems>/layout/layout.ejs

    -
    1
    2
    3
    4
    5
    6
    7
    8
    9
    <!--前三行最好添加到 <header></header> 头区块中-->

    <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/katex@0.11.0/dist/katex.min.css" >
    <script defer src="https://cdn.jsdelivr.net/npm/katex@0.11.0/dist/katex.min.js" ></script>
    <script defer src="https://cdn.jsdelivr.net/npm/katex@0.11.0/dist/contrib/auto-render.min.js"></script>


    <script src="https://raw.githack.com/maiernte/img/master/libs/katexYixue.js"></script>
    <script src="https://raw.githack.com/maiernte/img/master/libs/bundle.js"></script>
    -
    -

    注意搜索 _config.yml 文件,“math”, “katex”, “mathjax” 等字样,发现有的话把他们禁用。

    -
    -

    Gitbook

    -

    最新的安装教程请参考华鹤易学平台文档

    -

    API 参数

    -

    使用易学函数库非常简单,在经过改装的Markdown编辑器中,输入易学公式,并用两个 $ 符号将公式前后围起来即可。MD语言一般默认两个 $ 符号之间的文本是数学公式,它会调用MathJax对公式进行渲染。否则,它会认为这是普通文本,而不会做任何动作。

    -

    易学通用

    -

    命令:纳音 \nayin{干支名称}

    -

    【干支名称】 :就是甲子、己卯等六十甲子。

    -

    例子1:\nayin{戊午} --> $\nayin{戊午}$

    -

    命令:干支日历 \timegz{时间参数}{年月日}

    -

    【时间参数】 :例如 2020-02-21。

    -

    【年月日】 :省略时默认为111,即显示年月日。0表示不显示,1表示显示。

    -

    例子1:\timegz{2020-02-21} --> $\timegz{2020-02-21}$

    -

    例子2:\timegz{2020-02-21}{011} --> $\timegz{2020-02-21}{011}$

    -

    六爻

    -

    命令:爻符 \yao{爻名}

    -

    【爻名】:laoyin, laoyang,shaoyin,shaoyang, x, o, =, -, 交,重,阴,阳,0,1,2,3

    -

    例子2:\yao{x} --> $\yao{x}$

    -

    例子3:\yao{shaoyin} --> $\yao{shaoyin}$

    -

    例子4:\yao{重} --> $\yao{重}$

    -

    命令:六爻排盘 \paigua{时令}{卦辞}{标识}

    -

    其中 【时令】、【卦辞】这两个参数是必须的,**【标识】**参数可以省略。

    -

    【时令】允许的格式为:“1980-1-3 08:15”、“2019年3月4日”、“申月戊寅日”

    -

    【卦辞】允许的格式为:“解之师”、“离为火”、“–==x-”、“0121100”、“阴阳阴交阴阳”

    -

    【标识】由三部分组成:ID号、简排、字符大小。格式为:guadi/s/5

    -
      -
    • 「ID号」:随便一串字符,空白则默认为“gua1”。:x:不允许只有数字,因为会与参数「字符大小」混淆。如果一个文本出现多个六爻卦,则每个卦都需要指定一个ID号。否则下面的命令卦爻细节不知道具体指向哪一个卦本。
    • -
    • 「简排」:只允许sl两个英文字符的其中一个。s 表示只显示短名,如“妻财”显示为“财”,“青龙”显示为“龙”。l 则显示完整名称。留白则按照用户全局设定来显示。(参阅用户设定
    • -
    • 「字符大小」:允许 0 - 9 档。数字越大文字越大。默认大小为5或者用户的全局设定
    • -
    -

    例子5: $\paigua{1978年7月1日}{101201}{gua1}$ 效果
    -$$\paigua{1978年7月1日}{101201}{gua1}$$

    -

    :pencil2: 如果文章很长,需要在指定位置重新显示一遍卦本,则可以使用重排命令。即让【时令】和【卦辞】两个参数留白,只给出【ID号】。如 \paigua{}{}{gua1} 。留白的参数,仍然需要用大括号括起来,否则解释器会出错。

    -

    命令:卦爻细节 \guayao{标识}{位置}

    -

    使用前提:当前文本中已经排出至少一支六爻卦。

    -

    【标识】:与排盘命令的「标识」参数等同。由ID号、简排、字符大小三个部分组成。其中「ID号」标识已经存在的六爻盘。

    -

    【位置】:格式为 “ben1”、“fu3”、“bian5” 等,分别表示「本卦初爻」、「伏卦3爻」、「变卦5爻」

    -

    例子6:\guayao{gua1}{ben4} --> $\guayao{gua1}{ben4}$

    -
    -

    例子6 中给出的「ID号」为例子5中指定的ID号 “gua1”,并要求显示本卦4爻的具体信息。

    -
    -

    八字

    -

    命令:八字排盘 \paibazi{时间}{性别}{标识}[细节]

    -

    【时间】和【性别】参数必填,【标识】和【细节】参数可选。(如果要第二次显示已有的八字盘,则【时间】和【性别】参数可留白,只给定【标识】参数中的「ID号」)

    -

    【时间】:允许格式 “1980-1-3 08:15”、“2019年3月4日 6时3分”

    -

    【性别】:允许格式 “m”、“f”、“男”、“女”、“乾”、“坤”、

    -

    【标识】:与排盘命令的「标识」参数等同。由ID号、简排、字符大小三个部分组成。

    -

    【细节】:允许“藏干”、“长生”、“纳音”这三个中的一个或者多个,也可以留白。格式为 藏干/纳音/长生

    -

    例子7:\paibazi{1990年5月1日 6:45}{男}{小明/s/5}

    -

    $\paibazi{1990年5月1日 6:45}{男}{小明/5}$

    -

    例子8:重排例子7的八字盘 \paibazi{}{}{小明/s/5}[纳音/藏干/长生] ,并要求显示藏干和纳音等信息。

    -

    $\paibazi{}{}{小明/s/5}[纳音/藏干/长生]$

    -

    命令:八字细节 \bazi{标识}{类别}[细节]

    -

    使用前提:当前文本中已经排出至少一个八字盘。

    -

    【标识】:与排盘命令的「标识」参数等同。由ID号、简排、字符大小三个部分组成。其中「ID号」标识已经存在的八字命盘。

    -

    【类别】:支持 “神煞”、“大运”、“流年”、“小运” 四个选项。

    -

    【细节】:具体含义视【类别】而定。

    -
      -
    • 类别为「神煞」时:「细节」为 1~ 9 的数字,表示每行列数。
    • -
    • 类别为「大运」时: 1-9 纳音/藏干/长生/神煞 前面的数字表示第几步大运,限定 1 到 10
    • -
    • 类别为「流年」和「小运」时: 2015 - 2019 纳音/藏干/长生/神煞 前面的数字表示年份,注意不要超过命盘的生命周期,否则会出错。「纳音/藏干/长生/神煞」可以留白,也可只显示一两项。
    • -
    -

    例子9: \bazi{小明}{神煞}[6] 显示小明命盘的神煞,每行6列。

    -

    $\bazi{小明}{神煞}[6]$

    -

    例子10: \bazi{小明}{大运}[2-3 ] 显示小明的第二到第三步大运

    -

    $\bazi{小明}{大运}[2-3]$

    -

    例子11: \bazi{小明}{流年}[2017-2019 纳音/藏干/长生/神煞] 显示小明的2017到2019年的流年信息。

    -

    $\bazi{小明}{流年}[2017-2019 纳音/藏干/长生/神煞]$

    -

    未来与展望

    -

    我知道这篇文章介绍的工具,并非所有人都能使用。所以在不久的将来,还是要制作一个独立易学软件,以便易友在PC端和移动端都能按照传统的方式使用。但由于时间和精力原因,我无法保证完成时间。

    -

    不断完善易学函数,提供更丰富的应用细节。在用户更为广泛的MD编辑器中实现此方式。比如有道云笔记、为知笔记、印象笔记等。并争取介绍移动端(Android & iOS)实现此方式。也希望在Gitbook中实现。

    -

    希望能将师父的六爻和八字讲义,『增删卜易』等著作制作成Gitbook,将精彩的卦例和名人八字建成易学数据库。这样就可以通过我的易学函数直接获取, 比如 \paibazi{蒋介石}

    -

    附录:

    -

    命令列表

    -

    纳音

    -

    爻符

    -

    排卦

    -

    卦爻细节

    -

    排八字

    -

    八字细节

    -

    发布

    -

    脚本文件的原始路径https://github.com/maiernte/img/raw/master/libs/bundle.js。因为涉及到跨域问题,要通过 Gitkack 重链接,把上述路径输入到 Githack 的地址框,会得到「应用地址」和「开发地址」。

    -

    应用地址

    -

    https://rawcdn.githack.com/maiernte/img/11a1bb572a6875dbf434a7fc457ea2fdd329f7db/libs/bundle.js

    -

    开发地址

    -

    https://raw.githack.com/maiernte/img/master/libs/bundle.js

    -

    查看当前易学函数库版本

    -

    在 chrome 浏览其中打开此博文,Mac 系统中按 ⌘+⌥+I ,Windows 系统 Ctr+⇧+I,或者 Chrome 菜单栏调出 “开发者工具”,选择 Console 页面,即可显示当前易学库版本和时间。

    - -
    - -
    -
    -
    -
    - - - - - - - - - - - -
    -
    - -
    -
    - - - - - - - -
    -
    -
    -
    - -
    -
    - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - - - \ No newline at end of file diff --git a/docs/next-collapse-block.html b/docs/next-collapse-block.html index 021ae5f..e69de29 100644 --- a/docs/next-collapse-block.html +++ b/docs/next-collapse-block.html @@ -1,579 +0,0 @@ - - - - - - Next以及wikitten主题添加内容折叠 | 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - -
    - - - - -
    -
    - - -
    - - - - - -

    - Next以及wikitten主题添加内容折叠 -

    - - -
    - - -
    - - - -
    - 文章目录 -
    1. 1. 添加代码
      1. 1.1. 在main.js中添加折叠js
      2. 1.2. 自定义内建标签
      3. 1.3. 添加自定义样式
      4. 1.4. 使用
      5. 1.5. 参考
    2. 2. 实例
      1. 2.1. 嵌套代码
      2. 2.2. Hexo 代码方式
      3. 2.3. Gist
        1. 2.3.1. Hexo 方式
        2. 2.3.2. Javascript 方式
    -
    - - - -

    添加代码

    -

    当有大段的代码直接展示在页面时,看起来臃肿且不便于观看,此时将代码折叠式最好的选择。下面是在Hexo的Next主题上添加折叠功能。

    - -

    在main.js中添加折叠js

    -

    Next主题的主要js位于 themes/next/source/js/src/post-details.js,在下面添加一下代码段:

    -
    1
    2
    3
    4
    5
    6
    7
    8
    $(document).ready(function(){
    $(document).on('click', '.fold_hider', function(){
    $('>.fold', this.parentNode).slideToggle();
    $('>:first', this).toggleClass('open');
    });
    //默认情况下折叠
    $("div.fold").css("display","none");
    });
    -

    Wikitten 主题添加到 themes/wikitten/source/js/main.js 后面。

    -

    自定义内建标签

    -

    在主题scripts下添加一个tags.js,位于themes/next/scripts/tags.js

    -
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    /*
    @haohuawu
    修复 Nunjucks 的 tag 里写 ```代码块```,最终都会渲染成 undefined 的问题
    https://github.com/hexojs/hexo/issues/2400
    */
    const rEscapeContent = /<escape(?:[^>]*)>([\s\S]*?)<\/escape>/g;
    const placeholder = '\uFFFD';
    const rPlaceholder = /(?:<|&lt;)\!--\uFFFD(\d+)--(?:>|&gt;)/g;
    const cache = [];
    function escapeContent(str) {
    return '<!--' + placeholder + (cache.push(str) - 1) + '-->';
    }
    hexo.extend.filter.register('before_post_render', function(data) {
    data.content = data.content.replace(rEscapeContent, function(match, content) {
    return escapeContent(content);
    });
    return data;
    });
    hexo.extend.filter.register('after_post_render', function(data) {
    data.content = data.content.replace(rPlaceholder, function() {
    return cache[arguments[1]];
    });
    return data;
    });
    -

    再继续添加一个fold.js,位于themes/next/scripts/fold.js

    -
    1
    2
    3
    4
    5
    6
    7
    8
    /* global hexo */
    // Usage: {% fold ???? %} Something {% endfold %}
    function fold (args, content) {
    var text = args[0];
    if(!text) text = "点击显/隐";
    return '<div><div class="fold_hider"><div class="close hider_title">' + text + '</div></div><div class="fold">\n' + hexo.render.renderSync({text: content, engine: 'markdown'}) + '\n</div></div>';
    }
    hexo.extend.tag.register('fold', fold, {ends: true});
    -

    wikitten主题将这两个文件复制到 themes/wikitten/scripts 目录下。

    -

    添加自定义样式

    -

    位于themes/next/source/css/_custom/custom.styl

    -
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    .hider_title{
    font-family: "Microsoft Yahei";
    cursor: pointer;
    color: red;
    }
    .close:after{
    content: "▼";
    }
    .open:after{
    content: "▲";
    }
    -

    wikitten 主题将此代码添加到 themes/wikitten/source/css/_partial/article.styl 文件下面。在next 主题必须将==color: red==去掉,否则会影响大纲栏的颜色。

    -

    使用

    -

    在我们需要折叠的地方前后添加便签,示例用法:

    -
    1
    2
    3
    {% fold 点击显/隐内容 %}
    需要隐藏的内容。。。
    {% endfold %}
    -

    参考

    -

    Hexo next博客添加折叠块功能添加折叠代码块
    -Next主题实现内容折叠
    -jQuery 实现内容折叠功能

    -

    Hexo 标签插件 官方

    -

    实例

    -

    嵌套代码

    -

    Some Content

    -
    点击显/隐内容
    -

    <xsl:call-template name=“SetGlobaleVariable”>
    -<xsl:with-param name=“name-variable”>po_bfa_swbh_laufbahn</xsl:with-param>
    -<xsl:with-param name=“wert-variable” select="$bf_laufbahnzulage"/>
    -</xsl:call-template>

    -
    -
    -

    Hexo 代码方式

    -

    Lorem ipsum dolor sit amet, consectetur adipiscing elit. Pellentesque hendrerit lacus ut purus iaculis feugiat. Sed nec tempor elit, quis aliquam neque. Curabitur sed diam eget dolor fermentum semper at eu lorem.

    -
    DavidLevithan
    -
    KOS xsldownloadcode
    1
    1 code snippet
    -

    Gist

    -

    Hexo 方式

    -

    Gist (“48edcb5cfd92937ae61360b74852d4e1” 就是id。 而 “xml” 是我创建时的文件名)。地址是 git.github.com

    - -
    -

    Javascript 方式

    - - -
    - -
    -
    -
    -
    - - - - - - - - - - - -
    -
    - -
    -
    - - - - - - - -
    -
    -
    -
    - -
    -
    - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - - - \ No newline at end of file diff --git a/docs/old-stories-collection.html b/docs/old-stories-collection.html index d54b894..e69de29 100644 --- a/docs/old-stories-collection.html +++ b/docs/old-stories-collection.html @@ -1,539 +0,0 @@ - - - - - - 典故 | 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - -
    - - - - -
    -
    - - -
    - - - - - -

    - 典故 -

    - - -
    - - -
    - - - -
    - 文章目录 -
    1. 1. 豫让刺赵简子
    -
    - - - -
    豫让刺赵简子
    -

    晋毕阳之孙豫让,始事范、中行氏而不说,去而就知伯,知伯宠之。及三晋分知氏,赵襄子最恐知伯,而将其头以为饮器。豫让遁逃山中曰:“磋乎!士为知己者死,女为悦己者容。吾其报知氏之仇矣。”

    - -

    乃变姓名,为刑人,入宫涂厕,欲以刺襄子。 襄子如厕,心动,执问涂者,则豫让也。 刃其曰:“欲为知伯报仇!”左右欲杀之。 赵襄子曰:“彼义士也,吾谨避之耳。且知伯已死,无后,而其臣至为报仇,此天下之贤人也。”卒释之。 豫让又漆身为厉,灭须去眉,自刑以变其容,为乞人而往乞,其妻不识,曰:“状貌不似吾夫,其音何类吾夫之甚也。”又吞炭为哑,变其音。 其友谓之曰:“子之道甚难而无功,谓子有志,则然矣,谓子知,则否。以子之才,而善事襄子,襄子必近幸子;子之得近而行所欲,此甚易而功必成。”豫让乃笑而应之曰:“是为先知报后知,为故君贼新君,大乱君臣之义者无此矣。凡吾所谓为此者,以明君臣之义,非从易也。且夫委质而事人,而求弑之,是怀二心以事君也。吾所为难,亦将以愧天下后世人臣怀二心者。”

    -

    居顷之,襄子当出,豫让伏所当过桥下。 襄子至桥而马惊。 襄子曰:“此必豫让也。”使人问之,果豫让。 于是赵襄子面数豫让曰:“子不尝事范中行氏乎?知伯灭范中行氏,而子不为报仇,反委质事知伯。知伯已死,子独何为报仇之深也?”豫让曰:“臣事范中行氏,范中行氏以众人遇臣,臣故众人报之;知伯以国士遇臣,臣故国士报之。”襄子乃喟然叹泣曰:“嗟乎,豫子!豫子之为知伯,名既成矣,寡人舍子,亦以足矣。子自为计,寡人不舍子。”使兵环之。 豫让曰:“臣闻明主不掩人之义,忠臣不爱死以成名。君前已宽舍臣,天下莫不称君之贤。今日之事,臣故伏诛,然愿请君之衣而击之,虽死不恨。非所望也,敢布腹心。”于是襄子义之,乃使使者持衣与豫让。 豫让拔剑三跃,呼天击之曰:“而可以报知伯矣。”遂伏剑而死。 死之日,赵国之士闻之,皆为涕泣。

    -

    —— 《战国策》

    - -
    - -
    -
    -
    -
    - - - - - - - - - - - -
    -
    - -
    -
    - - - - - - - -
    -
    -
    -
    - -
    -
    - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - - - \ No newline at end of file diff --git a/docs/page/2/index.html b/docs/page/2/index.html index f9098a1..e69de29 100644 --- a/docs/page/2/index.html +++ b/docs/page/2/index.html @@ -1,1288 +0,0 @@ - - - - - - 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - -
    - - - - -
    -
    -
    - - -
    - - - - - -

    - 佛偈集合 -

    - - -
    - - -
    - - - - -

    佛偈(jì)
    -

    -

    虚云老和尚悟道偈

    -

    杯子扑落地,响声明历历。
    -虚空粉碎也,狂心当下息。

    -

    烫着手,打碎杯,家破人亡语难开。
    -春到花香处处秀,山河大地是如来。

    - - - -
    -
    - 查看更多 -
    - -
    -
    -
    -
    - - - - - - - -
    -
    - - -
    - - - - - -

    - 简短书摘 -

    - - -
    - - -
    - - - - -

    癌症
    -

    “以我个人有限的接触癌症的经历总结,似乎越是传统意义上的“好人”越是容易生癌。这些人往往脾气很好,性格内向,照顾周围,万事替别人考虑,总是在乎别人眼里的自己,总是担心一些可能发生的小概率负面事件。”

    -

    —— 冯唐. “无所畏【冯唐2018全新作品,一部坦露自我的真诚之作!】。”

    - - - -
    -
    - 查看更多 -
    - -
    -
    -
    -
    - - - - - - - -
    -
    - - -
    - - - - - -

    - 零散句子 -

    - - -
    - - -
    - - - - -

    幸福的路有两条
    -

    中岛美雪写的歌《幸福》(任贤齐翻唱的伤心太平洋):到幸福的路有两条,一条是所有愿望都成真,另外一条是把愿望这东西扔掉。

    - - - -
    -
    - 查看更多 -
    - -
    -
    -
    -
    - - - - - - - -
    -
    - - -
    - - - - - -

    - 典故 -

    - - -
    - - -
    - - - - -

    豫让刺赵简子
    -

    晋毕阳之孙豫让,始事范、中行氏而不说,去而就知伯,知伯宠之。及三晋分知氏,赵襄子最恐知伯,而将其头以为饮器。豫让遁逃山中曰:“磋乎!士为知己者死,女为悦己者容。吾其报知氏之仇矣。”

    - - - -
    -
    - 查看更多 -
    - -
    -
    -
    -
    - - - - - - - -
    -
    - - -
    - - - - - -

    - 搞笑段子 -

    - - -
    - - -
    - - - - -

    慢慢就习惯了
    -

    某人四十多岁了还碌碌无为,于是跑去找算命先生。算命先生掐指一算,然后问:“一个好消息,一个坏消息,你先听哪个?”哥们说:“那就先听坏的吧”。算命先生说:“坏消息是,你四十岁之前穷困潦倒……”那哥们眉头一挑,问:“那好消息呢?”算命先生幽幽的说到:“四十岁以后,你就习惯了。”

    - - - -
    -
    - 查看更多 -
    - -
    -
    -
    -
    - - - - - - - - - - - - - - - -
    -
    - - -
    - - - - - -

    - 名人语录 -

    - - -
    - - -
    - - - - - - - - - - - - - - - - - - - - - - -

    祈祷文
    -
      -
    • 上帝,请赐予我平静让我可以接受我所不能改变的,赐予我勇气让我可以改变我能够改变的,赐予我智慧以分辨这二者的不同。
    • -
    • God grand me the serenity to accept the things I cannot change, Courage to change the things I can, and wisdom to know the difference.
    • -
    -

    - - - - -

    -
    - 查看更多 -
    - -
    -
    -
    -
    - - - - - - - - - - - - - - - - - - - - - - - -
    -
    - - -
    - - - - - -

    - 编辑器工具使用技巧汇总 -

    - - -
    - - -
    - - - - -

    VSCode

    -
      -
    1. Wechseln zwischen Text-Editor und Terminal -
        -
      1. Command+K+S oder in Menü Code->Pereferenc->Hotky, öffnet Hot-Key Editor Fenster.
      2. -
      3. Tip terminal in Suchfeld, findet die Binding `^``, löscht diese Einstellung.
      4. -
      5. Sucht den “workbench.action.terminal.focus”, bindet es mit Key ⌃<.
      6. -
      7. Sucht den “workbench.action.focusActiveEditorGroup”, bindet es wiederum mit Schlüssel ⌃<, und Wenn-Kondition “terminalFocus”.
      8. -
      -
    2. -

    - - - -
    -
    - 查看更多 -
    - -
    -
    -
    -
    - - - - - - - - -
    -
    -
    -
    - -
    -
    - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - - - \ No newline at end of file diff --git a/docs/page/3/index.html b/docs/page/3/index.html index 66356db..e69de29 100644 --- a/docs/page/3/index.html +++ b/docs/page/3/index.html @@ -1,1337 +0,0 @@ - - - - - - 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - -
    - - - - -
    -
    -
    - - -
    - - - - - -

    - Ubuntu重设root用户密码 -

    - - -
    - - -
    - - - - - - - - - - - - - - - - - - - - - - -

    重设密码

    -

    原理上参考这份中文指引就好。由于我的服务器是IONOS公司的,这里主要记录IONOS的官方指引。(严格按照步骤)

    -
    1
    2
    网址 www.ionos.de/hilfe
    # 选择 Server & Cloud Infrastructure
    -
      -
    1. 打开 KVM-Konsole
    2. -

      - - - - -

    -
    - 查看更多 -
    - -
    -
    -
    -
    - - - - - - - - - - - - - - - -
    -
    - - -
    - - - - - -

    - 坚果云有关 -

    - - -
    - - -
    - - - - -

    忽略文件
    -

    配置文件 customExtRules.conf。在 Window 版可以在软件直接打开,在 Mac App 里面没有这个选项,要自行查找这个配置文件。官方说明

    -
    -

    在 Windows 和 Mac 下面目录可能不一样。

    -

    - - - -
    -
    - 查看更多 -
    - -
    -
    -
    -
    - - - - - - - -
    -
    - - -
    - - - - - -

    - 使用Github维护知识库 -

    - - -
    - - -
    - - - - -

    部署以及更新

    -
      -
    • -

      初建:将文件夹设置为仓库。只是第一次需要,以后就基本不用。
      -git init

      -
    • -
    • -

      更新:更新所有的文件。
      -git add .

      -
    • -
    • -

      描述:更新描述(optional 不是必须的)
      -git commit -m "my command..."

      -
    • -
    • -

      推送:上传到云仓库
      -git push -u origin master

      -
    • -

    - - - -
    -
    - 查看更多 -
    - -
    -
    -
    -
    - - - - - - - - - - - - - - - - - - - - - - - -
    -
    - - -
    - - - - - -

    - Mac使用标签 -

    - - -
    - - -
    - - - - - - - - - - - - - - - - - - - - - - -

    使用标签

    -

    在 Mac 上,执行以下任一项操作:

    -
      -
    • 给打开的文件添加标签:将鼠标指针悬停在文稿标题右侧,点按箭头,在“标签”栏中点按,然后输入新标签,或者从列表中选取一个标签。
    • -
    • 存储新文件时添加标签:点按“文件”>“存储”。在“存储”对话框中,在“标签”栏中点按,然后输入新标签,或者从列表中选取一个标签。
    • -

      - - - - -

    -
    - 查看更多 -
    - -
    -
    -
    -
    - - - - - - - -
    -
    - - -
    - - - - - -

    - Mac备忘录 -

    - - -
    - - -
    - - - - - - - - - - - - - - - - - - - - - - -

    指令和任务

    -

    隐藏文件夹

    -

    Terminal 命令

    -
    1
    2
    3
    4
    //显示隐藏文件
    defaults write com.apple.finder AppleShowAllFiles -bool true
    //不显示隐藏文件
    defaults write com.apple.finder AppleShowAllFiles -bool false
    -

    快速命令,打开访达窗口,然后 ⌘ + ⇧ + . 就可以隐藏/显示。

    -

    - - - - -

    -
    - 查看更多 -
    - -
    -
    -
    -
    - - - - - - - - - - - - - - - - - - - - - - - - -
    -
    -
    -
    - -
    -
    - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - - - \ No newline at end of file diff --git a/docs/page/4/index.html b/docs/page/4/index.html index 8821027..e69de29 100644 --- a/docs/page/4/index.html +++ b/docs/page/4/index.html @@ -1,578 +0,0 @@ - - - - - - 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - -
    - - - - -
    - - - - - - - - - - - - - - - - - -
    -
    -
    -
    - -
    -
    - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - - - \ No newline at end of file diff --git a/docs/prominaent-slogen-collection.html b/docs/prominaent-slogen-collection.html index 4041543..e69de29 100644 --- a/docs/prominaent-slogen-collection.html +++ b/docs/prominaent-slogen-collection.html @@ -1,566 +0,0 @@ - - - - - - 名人语录 | 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - -
    - - - - -
    -
    - - -
    - - - - - -

    - 名人语录 -

    - - -
    - - -
    - - - -
    - 文章目录 -
    1. 1. 祈祷文
    2. 2. 尼采
    3. 3. 苏格拉底
    4. 4. 亚里士多德
    5. 5. 维克多 弗兰克
    6. 6. 马克吐温
    7. 7. 赛斯
    8. 8. 叔本华
    9. 9. 谚语
    10. 10. 曾国藩
    11. 11. 宗棠
    12. 12. 俞敏洪
    -
    - - - -
    祈祷文
    -
      -
    • 上帝,请赐予我平静让我可以接受我所不能改变的,赐予我勇气让我可以改变我能够改变的,赐予我智慧以分辨这二者的不同。
    • -
    • God grand me the serenity to accept the things I cannot change, Courage to change the things I can, and wisdom to know the difference.
    • -
    -
    尼采
    -

    He who has a strong enough why can bear almost any how. – Friedrich Nietzsche

    -
    苏格拉底
    -

    Beware the barrenness of a busy life. – Socrates

    -
    亚里士多德
    -

    We are what we repeatedly do. Excellence, then, is not an act, but a habit. – Aristotle

    -
    维克多 弗兰克
    -

    人所拥有的任何东西都可以被剥夺,唯独人性最后的自由——也就是在任何境遇中选择一己态度和生活方式的自由——不能被剥夺。

    -
    马克吐温
    -

    让你陷入困境的并不是这个世界;真正让你陷入困境的,是这个世界最终并非你所想象。

    -
    赛斯
    -

    每一个心愿都预设了对于一个缺憾的承认,每一个挑战也预设了有一个要征服的阻碍。

    -
    叔本华
    -

    痛苦和无聊是人类幸福的两个死敌。欲望不满足就痛苦,满足就无聊。人生如同钟摆在痛苦和无聊两个极点之间摆动。离开一个极点就意味着正在走向另一个极点。

    -
    谚语
    -

    Don’t shoot the messenger.
    -英文有句谚语叫“不要枪毙信使”。枪毙信使并不能改变坏消息。

    -
    曾国藩
    -
      -
    • 既往不恋,当下不染, 未来不迎。天涯:染,不被当下的情绪感染。要跳出情绪来观察当下。
    • -
    • 倚天照海花无数, 流水高山心自知。
    • -
    • 久利之事勿为,众争之地勿往。
    • -
    • 勿以小恶弃人大美, 勿以小怨忘人大恩。
    • -
    -
    宗棠
    -

    人生最不幸處,是偶一失言而禍不及,偶一失謀而事倖成,偶一恣行而獲小利, 後乃視為故常,而恬不為意。則莫大之患,由此生矣。

    -
    俞敏洪
    -

    优秀是一种习惯。

    - -
    - -
    -
    -
    -
    - - - - - - - - - - - -
    -
    - -
    -
    - - - - - - - -
    -
    -
    -
    - -
    -
    - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - - - \ No newline at end of file diff --git a/docs/road-less-traveled-summary.html b/docs/road-less-traveled-summary.html index 332b2cf..e69de29 100644 --- a/docs/road-less-traveled-summary.html +++ b/docs/road-less-traveled-summary.html @@ -1,678 +0,0 @@ - - - - - - 《少有人走的路》笔记 | 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - -
    - - - - -
    -
    - - -
    - - - - - -

    - 《少有人走的路》笔记 -

    - - -
    - - -
    - - - -
    - 文章目录 -
    1. 1. 自律
      1. 1.1. 1 延迟满足感
      2. 1.2. 2 承担责任
      3. 1.3. 3 忠于事实
      4. 1.4. 4 保持平衡
    2. 2.
      1. 2.1. 过度关注
      2. 2.2. 坠入情网
      3. 2.3. 精神贯注
      4. 2.4. 自我牺牲
    3. 3. 信仰
      1. 3.1. 科学也是信仰
      2. 3.2. 原罪
      3. 3.3. 两种力量
    -
    - - - -

    成熟 = 自律 +

    - -

    自律

    -

    【自律】 : 主动要求自己以积极的态度去承受痛苦,解决问题。

    -

    自律的四个原则:延迟满足感、承担责任、忠于事实、保持平衡。:smile:

    -

    1 延迟满足感

    -
    - -人生当中总是绕着困难走。一个揍孩子和对孩子大喊大叫的父母就是不懂得延迟满足感的父母。 应该陪着孩子一起经历困难和痛苦。而父母试图通过家庭暴力的方式,试图将父母本身的责任区隔开。父母没有学会延迟满足感,这个孩子将来长大了也不会。很多人延迟满足感的能力非常糟糕,来自于父母的不自律。当父母不自律的时候,孩子就没法获得足够的爱和照顾。—— 所以这个孩子会忽略自我的价值。有的人喜欢浪费时间,而浪费时间的意思就是,_「我这个人的时间没什么价值」_。 -不会延迟满足感的人,在长大后看到问题会假装没看到,以为等着问题慢慢就会过去,期待问题自行消失。 -
    -
    -
      -
    • 训斥孩子 ~> 是为了迅速达成目的,而不是耐心陪孩子面对问题。
    • -
    • 父母不自律 => 孩子不自律
    • -
    • 不会延迟满足感 => 有意忽略问题
    • -
    -
    -

    2 承担责任

    -
      -
    1. 神经官能症: 把一切东西都认为是自己的问题。
    2. -
    -
    -

    我如果怎么样就好了。我要是不怎么样就好了。总是充满后悔和内疚。祥林嫂

    -
    -
      -
    1. 人格失调症:他认为这一切都不是我的问题。他能找到任何一个理由,是因为外在的东西,他就不会责怪自己,他认为都是你们的问题。
    2. -
    -
    -

    「神经官能症」自己活得很痛苦,「人格失调症」让别人活得很痛苦。

    -
    -
    - -作者提供在冲绳岛上的一个案例,一个军官的妻子,宁愿自杀也不愿意去学自动挡开车的事。 -从某种意义上说,所有的孩子都患有人格失调症,都会本能的逃避责罚。 同时又患有某种神经官能症,把自己承受的痛苦看成是罪有应得。缺少关心的孩子会自惭形秽,认为自己不够可爱,缺点大于优点等等。 -
    -

    如果你不能解决问题,那么你自己就会成为问题。我们需要合理的承担责任,既不把责任全部推卸到外部,也不把责任全部揽到自己身上。保持一个合理的平衡。

    -
    -

    如果你不能让自己成为人格更加健全,更加成熟的人。你就会把问题带给你的孩子,带给你的家庭。

    -
    -

    3 忠于事实

    -

    大量的人是生活在自己的幻想当中的。这叫人生地图。他给自己绘制一张人生地图,他认为人生就这样,他已经认定了。这就叫做“不忠于事实”,他只 忠于自己的幻想

    -
    - -案例:有个人小时候被父母欺骗过,就是父母说话经常不算数。导致他潜意识积累了一个信念:“父母是不可信”的。当他的人生地图绘制出来这么一个坐标,认为父母不可信了自后,他几乎就推论到“人人都不可信”。所以在他一生的成长过程当中,他跟警察发生矛盾,跟领导发生矛盾,跟顾客发生矛盾,跟妻子发生矛盾。案例中最后他唯一信任的是他的两个孩子。妻子把两个孩子带走,所以他人生也崩溃了。他跟作者约定时间不来,然后他说能不能星期六,作者说我的时间是跟别人约过的,不能随便调整。他说:“你不是心理医生吗?为什么不能多关心我一点呢”?他认为作者(心理医生)也是不可信任的人,直接拉黑。 -
    -这种人你很难跟他解释,很难让他面对真正的世界。因为在他心目当中完全是用自己的一套逻辑在解决问题。 -

    所以所谓的「心理治疗」,就是鼓励「说真话」的游戏。鼓励大家能够面对事实,能够把自己看到的真相,感受到的真实的感觉,说出来的一个过程。所以没有经过这样的调试,有大量的人是天天活在「幻觉」当中的,就是沉浸在自己的人生地图当中。根本不去看一看,别人的地图是什么样。也根本不去看一看实际的生活当中,事实是什么样的。

    -

    移情:人们会把对一个人的感情和经验移植在别人身上。会认为别人也这样。

    -
    -

    应该说移情、或者忽略史实,也是一种懒惰的表现。因为去更新地图是件很费力的事情。

    -
    -

    4 保持平衡

    -

    既要承担责任,也要拒绝承担不该承担的责任。差不多又回到了「中庸」之道。「延迟满足」也不能延迟到无限, 从来不过好日子。既要延迟满足,也要过好当下的生活。要有一个富于弹性的约束机制。好像骑自行车下坡一样,既要享受速度,也要注意刹车。为了待会安全的拐弯,也要捏一捏车闸。
    -生活就是一个不断放弃的过程。必须能够学会放弃一件又一件的事情。包括接受心理治疗就是「放弃」—— 放弃了一个「自己是正常人」 的想法。

    -
    -埃里克 埃里克森列举的人一生当中不断放弃的事情 -
      -
    1. 首先要放弃「无需对外界要求作出回应」的婴儿状态。
    2. -
    3. 三四岁的时候有「无所不能的幻觉」,这个要放弃掉。(为何小孩子特别喜欢绿巨人、钢铁侠、金刚狼这样的超级英雄?因为每个人在三四岁的时候都曾经幻想过自己是无所不能的超人。所以这种童话永远有市场。)
    4. -
    5. 放弃完全占有父亲或者母亲的欲望。放弃童年的依赖感。
    6. -
    7. 放弃心中被扭曲了的父母形象。(我们曾经以为父母是完美的)放弃。
    8. -
    9. 青春期的自以为拥有「无穷潜力」的感觉。放弃! I am the King of the World!
    10. -
    11. 无拘无束的自由
    12. -
    13. 青年时期的灵巧与活力
    14. -
    15. 青春时期的性吸引力;长生不老的空想。
    16. -
    17. 对子女的权威(在子女面前总是说了算的)
    18. -
    19. 各种各样「暂时性」的权力——退休了,社会给你的权力也没有了。
    20. -
    21. 身体永远健康——放弃
    22. -
    23. 最后,自我以及生命本身也要放弃。
    24. -
    -
    -

    -

    【爱】 :为了促进自己和他人心智成熟,而不断拓展自我界限,实现自我完善的一种意愿。

    -
    -

    核心观点就是「要看重心智成熟这件事」。心智成熟是发生在你和被爱的那个人之间的,两个人都需要达成心智成熟。
    -不要以为一昧的付出就是爱。爱的要求很高。要达成两个的共同成熟

    -
    -

    一个人懂得什么是真正的爱,才能够是一个真正成熟的人。否则你会看到很多人以「爱」的名义在伤害、控制、占有对方。「爱」有以下四个误区:过度关注、坠入情网、精神灌注、自我牺牲。

    -

    过度关注

    -
      -
    • -

      实际上是一种「依赖」
      -例子,一个妈妈,孩子都上高中了,还每天开车接送孩子上学。说孩子一个上学走太让人担心了。「过度关注」实际上是一种「依赖」。(妈妈在“依赖”这个孩子)这种类型的人经常说的话是“没有你我活不下去”。这个小孩之所以出现在书中,是因为孩子长大后来做了心理咨询。他在人生当中做任何事情都不成功。他的能力非常的欠缺。为什么?因为他从小到大完全被母爱这样束缚着。他妈妈根本不去管孩子能否「成熟」。他妈妈根本不去管这样做对孩子的心智健康、发展有没有好处。唯一的就是「你别出事,我必须盯着你」!`她不是为对方在做这样的事,她是在为自己做这样的事情。如果发展到极致,变得很严重的话,会变成一种疾病,叫「消极性依赖人格失调症」。—— 他必须依赖某一个外在的东西,他才能够觉得自己是存在的。如果有这么一个人,就是死死的缠住他,就是不离开他。有一个人作为对象,他才能找到自己的位置。如果找不到这样的人,就很可能会沉迷于毒品和酒精。

      -
    • -
    • -

      对「爱」无度的索求
      -对别人的爱根本与对方无关,他只是希望找到一个人,能够投射自己在上面,能够找到自己——「因为有人爱我,我就存在」。(例子,有个人离婚了,生活很痛苦,用酒精麻醉自己。咨询的第二天来跟医生说,我好了,我现在很幸福。因为昨晚在酒吧认识一个女人,她说她爱我。我现在很好。)总是苦思如何获得别人的爱,却没有精力去爱别人。就像饥肠辘辘的人,总想着向别人讨要食物,却拿不出食物来帮助别人。他们永远孤独寂寞,永远无法体会到满足感。尤其可怕的是,他们不知道自己患上了「消极性依赖人格失调症」。其造成原因多是童年缺乏爱,然后总觉的自己「没资格被爱」。人要感觉自己是被爱的,才有资格跟别人平起平坐,独立地生活和对话。患有这种心理疾病的人,他根本没有感觉到自己的资格,永远都在怀疑别人不爱他。所以只要别人拒绝他,就会感到无比的痛苦和伤心。而他永远需要找到一个紧紧拉住的,依赖的对象。这不是爱,这是占有。

      -
    • -
    -

    坠入情网

    -

    坠入情网是欲望。是你体内的激素分泌。因为我们的基因要求我们要生殖,见到异性感觉自己爱上他了。实际上是自己的一种欲望。一段时间后当你的欲望被释放掉了,体内的激素的大潮开始退去的时候,会发现这个人看起啦那么讨厌。坠入情网实际上是「自我界限的短暂崩溃」。除了自我界限的理论,还有以下几个点:

    -
      -
    • 不是出于主管意愿,它不是一个有计划有意识的选择。(很多人只把它看成一个感觉,而不是一个「动作」,爱是一个动词,不是感觉)
    • -
    • 不是自我界限的扩展,而是自我界限的部分的暂时性的崩溃。扩展自我界限需要付出足够的努力,坠入情网却无需努力。
    • -
    • 坠入情网唯一的作用是消除寂寞。而不是有目的的促进心灵的成长。
    • -
    • 简单来说贪恋爱可能是「爱」的发端,可能能培养出来爱,但它不是「爱」本身。
    • -
    -

    精神贯注

    -

    爱宠物、爱好这些也不是爱,而是「精神贯注」。就是当你把自己的精神贯注在一个事物上的时候,你以为这只狗“懂你”,其实上是“你投射在了它身上”,你在猜想它的想法。跟真正的爱不一样。为什么呢:

    -
      -
    • 首先,我们跟宠物的沟通非常有限。我们不知道他们每天在想什么,却一厢情愿的把自己的想法和感受投射在它们身上。实际上这只是我们的主观愿望罢了。
    • -
    • 其次,我们喜欢宠物的原因是因为它们表现乖巧,任凭摆弄。如果宠物不听话,破坏家具,随意大小便,甚至咬上我们几口。我们就可能把它赶出家门。如果要改变宠物的心智,我们只能把它送到宠物学校。如果与某个人相处,局面就完全不同了。
    • -
    -

    有一种精神贯注叫「婴儿之爱」。 很多妈妈只喜欢婴儿期的孩子。等孩子三四岁以后妈妈开始烦了。赶紧推给爷爷奶奶带。反过来呢,母爱很充沛,喜欢别人家的孩子,刚生的小婴儿。 这种不是爱,而是「唯命是从的追求」。 比如二战后美国的「战争新娘」。一开始新娘对丈夫唯命是从,当她们懂得英语,开始融入美国社会以后,矛盾就渐渐开始产生,离婚率开始上升。

    -

    以上几种感情我们误以为是爱,其实不是。它们都有共同的特征,就是以「爱」作为幌子,只想满足自己的需要。却从来不把对方的心智成熟当一回事。

    -

    自我牺牲

    -

    甚至还有人人会发展出来「自我牺牲式的爱」。有个妻子,她老公总是欺骗她,总是有外遇。每次闹完,老公回来道歉,她又开始接受他。五六次以后,妻子去找心理医生谈。心理医生告诉她要想清楚,不能老是这样接受他。有一次这个妻子说,我又原谅他了,这次他是真的改好了。他特别怎么怎么样。结果医生发现这个妻子有“受虐倾向”。有受虐倾向的人,会把「自我牺牲」当作是「爱」。他们觉得只要我能够牺牲、奉献就好。

    -

    这些东西也是来自童年的经历,就是他童年当中如果有一个这样的“楷模”,总是以自我牺牲为标榜,总是以为我为别人牺牲了那么多,所以 “你看我多好,多高尚”,他在潜意识当中就会慢慢接受“自我牺牲就是爱”这种想法。

    -
    - **自我界限**: -小孩子刚出生的时候是没有自我界限的。他在挥动胳膊的时候,觉得整个房间都在动,他与这个世界没有是分割的。到了两三岁发现自己挥动胳膊的时候,房间没有动,甚至他发现自己哭的时候,别人并不饿。 才能慢慢感受到原来自己跟他人是不一样的。到青春期这个人的自我界限已经开始完全封闭起来了。原来这个世界只有我自己,连我的父母都不了解我,我的喜怒哀乐他们根本不知道。所以人们开始陷入深深的孤独。青春期的孩子觉得自己最“孤独”,他觉得没人理解他,我是一个完全独一无二的个体,谁跟我都不一样,他的自我界限完全封闭起来。 -到了谈恋爱。谈恋爱是需要冒风险的,你是需要有勇气打开自我的界限,和另外一个人融为一体的。所以初恋的时候,很多人会有「**圣洁**」的感觉。就是“我打开了”,有一个人竟然“完全懂我”。有一个人可以跟我融为一体,那种水乳交融的感觉,他以为自己找到了「真爱」。因为他的边界在短期的崩溃。当他的自我边界崩溃以后,他感受到了生命的狂喜,那个就是短暂的获得了「爱」的感觉。但是那是假象。`因为那个并不建立在令我和对方人格不断成熟的一个过程当中。他并不是希望达成心智的成熟,他只是自我边界的短暂崩溃`。所以过了一两个月以后,这个自我界限慢慢弥合起来,他发现说“这个人怎么跟我也不一样”?“这个人的想法跟我也不同”。 现在的孩子谈恋爱特别快,有感觉就谈,没感觉了就分。把「感觉」当成了「爱」,事实上感觉只是欲望,是性欲。 - 但不要觉得欲望不是一件好事,无论是欲望,还是依赖,或者过度关注这样的东西,都是`培养爱的基础`。 -正是因为两个人打破了边界,走到一起,双方有可能为对方作出了承诺。接下来为了完成自己的承诺,需要不断的努力,需要有自律性。当你的自律性跟承诺相结合在起来的时候,你的这个短暂的恋爱的感觉爱,会慢慢滋生出真正的爱。 能够带来对方和自己心智共同的成熟。 -
    -
    -

    真正的「爱」 :爱是实际行动,是真正的付出。

    -

    爱的感觉与精神贯注密不可分。后者是把情感与兴趣贯注在对外的对象上,将其当作属于自己的一部分。精神贯注虽然跟真正的爱容易混淆,但是依然有显著的区别。首先,精神贯注的对象不一定是有生命的事物。因此就不见得会有心灵的感受。其次,对某种事物产生精神贯注的人,未必会重视其心智的成熟。(比如无原则溺爱孩子的父母)第三,精神贯注可能与智慧和责任无关。(酒吧认识一个人,立刻就情有所钟。但没有任何计划性,没有后续责任)。最后,精神贯注随时都有可能消失。今晚还很开心,明天不开心就分手啰。

    -

    真正的爱需要投入和奉献,需要付出全部的智慧与力量。要使爱的对象得到成长,就必须付出足够多的努力,不然爱的愿望就会落空。 唯有真正的投入与奉献,才是实现爱的有效方式。真正的爱是自主的选择,无论「爱」的「感觉」是否存在, 都要奉献出情感和智慧。

    -
    -

    「爱」的表现

    -
      -
    1. 倾听。我们真的能够拿出时间来,认真倾听对方的说话。最起码的尊重是通过倾听来展开的,我们要做一个良好的「倾听者」。
    2. -
    3. 要有心里准备,接受爱的时候,就要准备承担风险。(有人经历过丧失亲人,之后就特别怕建立亲密关系。因为怕失去,「失去」的痛苦吓坏了他。)(爱还要面临冲突的风险。)
    4. -
    5. 需要尊重对方的独立性。否则就是占有,就是依赖。
    6. -
    -

    信仰

    -

    科学也是信仰

    -

    科学也是一种信仰。这个世界上上信科学的人比信宗教的人多。人不是生活在一个真实的世界当中的,人是生活在思想家为我们所设定的思想通道当中的。科学家在不断的拓宽我们人类的视线,建立了科学的信仰。 作者认为宗教的信仰在某种程度上可能会导致人的某些情况下的精神分裂。但是在某些情况下也会带来信念,帮助人们解决心理的问题。比喻:倒洗澡水的时候,千万不要把婴儿也倒出去。对待信仰的时候,不能过于简单化。

    -

    原罪

    -

    作者认为人类的「原罪」就是「懒惰」

    -

    自律需要用力,爱需要用力,这个世界天然的方向是「熵增」,屋子一定会变乱。我花力气把屋子整理干净十个「逆熵」的过程,逆熵是需要话费气力的。 人天生喜欢熵增,喜欢懒惰。在伊甸园,其实上帝经常在园子里散步。这两孩子如果能去问一下,这玩意儿能吃吗?人类的命运就改变了。这两个人为什么不去问 一下上帝呢?因为这两孩子「懒惰」,而「懒惰」的背后是「恐惧」。他们担心问了上帝以后受到上帝的责罚。

    -
    -

    (天涯:我认为这个解释不对。那个时候的亚当和夏娃没有罪恶感,也从来没有受过责罚,怎么会有这个恐惧呢?而恐惧则是被赶出伊甸园以后人类才有的心智。)

    -
    -

    有人不好好学习,是因为就算好好学习了也未必学得好啊。如果好好学了而没有学好,就会面对失去「我不是没能力,只是不愿学而已」这块遮羞布的恐惧。

    -

    尽量要做到潜意识和意识「合一」。因为潜意识里面有很多的能量,而我们由于“懒惰”以及“恐惧”不愿意去开发的,不愿意去面对的。

    -

    这本书为什么叫【少有人走的路】呢?因为人人都喜欢熵增的方向,都喜欢轻松的方向,人人都喜欢懒惰的方向。喜欢部分什么劲,就得到一切的这种感觉。如果你想要变得成熟,就要费力去做一些逆熵的行为,自律的事,延迟满足的事,用行动表达「爱」的 过程。

    -

    两种力量

    -

    这个世界始终是由两种力量来统治的,分别是「政治的力量」和「心灵的力量」。

    -

    【政治的力量】:以公开或者隐秘的方式,去强迫别人遵循自己的意愿。这种力量既存在于权力之中,也存在于金钱之中。然而他并不属于拥有权力或者金钱的人。归根到底,政治的力量和德行以及智慧无关,最愚蠢最邪恶的人也可能成为地球的统治者。
    -【心灵的力量】:则完全存在于人类的心中,它和强迫、控制别人的力量没有关系。它是在意识基础上作出决定的力量。也就是「意识的力量」。

    -

    如果我们的心理能够得到力量,我们就会感到舒适和愉快,在人生的旅途上稳扎稳打,循序渐进。 进步带给我们的愉悦感难以言喻。没有什么比成为人生的专家,熟知自己所做的事情,更让人感觉到幸福。我们的心灵越是成熟,就越有可能成为人生的专家。当我们的心智成熟到一定的阶段,我们就会更加谦逊而快乐。

    -
    - -
    - -
    -
    -
    -
    - - - - - - - - - - - -
    -
    - -
    -
    - - - - - - - -
    -
    -
    -
    - -
    -
    - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - - - \ No newline at end of file diff --git a/docs/road-to-asset-freedom.html b/docs/road-to-asset-freedom.html index c631971..e69de29 100644 --- a/docs/road-to-asset-freedom.html +++ b/docs/road-to-asset-freedom.html @@ -1,677 +0,0 @@ - - - - - - 财富自由之路-李笑来 | 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - -
    - - - - -
    -
    - - -
    - - - - - -

    - 财富自由之路-李笑来 -

    - - -
    - - -
    - - - -
    - 文章目录 -
    1. 1. 哲学层面
      1. 1.1. 金钱、时间、注意力
      2. 1.2. 合作与信任
      3. 1.3. 活在真实中
        1. 1.3.1. 什么算落后
        2. 1.3.2. 元认知能力
      4. 1.4. 竞争力
        1. 1.4.1. 多维竞争
    2. 2. 应用层面
      1. 2.1. 「活在未来」
      2. 2.2. 人际关系的本质
      3. 2.3. 资本的定义
    3. 3. 暂时不知道往哪里分
    -
    - - - -

    进度:10课

    -

    哲学层面

    -

    金钱、时间、注意力

    -

    钱不是最重要,它可以再生。时间也不是,它本质上不属于你,你只能试着与它做朋友。注意力是自己可以做主的。必须把宝贵的注意力全部放在自己身上。放在自己的哪儿上?答:“成长”。不珍惜自己注意力的人最终注定是贫穷的,因为他们终生被收割,不可能有真正有价值的产出,怎么可能最终变得富有?另外,要放在自己的真爱上,以及对整个社会真正有贡献的事情上。(对于后两者,关注的焦点还是“成长”。)

    -

    注意力才是你人生最宝贵的财富(不是金钱和时间),你的一切价值都是你的注意力的产出。

    -
    -

    俗三个大坑:1. 莫名其妙的凑热闹。2. 心急火燎的随大流。3. 操碎了别人的心 (万众创业关你屁事,干好自己的活)。

    -
    -

    金钱、时间和注意力的比较:$ 注意力 > 时间 > 金钱 $

    -
      -
    • -

      凡是可以用钱买的其实都是便宜的。

      -
    • -
    • -

      凡是能用钱买来的时间就是便宜的。

      -
    • -
    • -

      凡是能用时间换来的注意力持续就是有价值的。

      -
    • -
    -

    :question: 时间和金钱谁更重要。

    -
    -

    答案是时间。因为财富自由的定义就是“不为生活需要出售时间”。另外一个角度是,“花钱买你的时间更划算”。

    -
    -

    :question: 注意力和时间更重要。

    -
    -

    注意力是能让你有所产出的唯一资源!而时间不一定是你的,时间不会自动产出。(李笑来: 花大量时间与老婆沟通,陪伴,以便换来自己集中注意力工作的机会。)

    -
    -

    合作与信任

    -

    追求百分百的安全感,肯定会把自己困在了永恒的当下。必须放弃一部分安全感,才能有深入的、长期的观察和思考。打破枷锁的方法:

    -
      -
    1. 放弃部分安全感,才能获得进步。
    2. -
    3. 通过有效社交,补全主动放弃的安全感。
    4. -
    -

    :bookmark:【合作】​ 的本质是大家各自放弃一小部分安全感,并把那一部分安全感交给合作方来保障。

    -

    :bookmark: 【信任】就是相信对方不会利用自己主动放弃的那一部分安全感。所谓缺乏安全感,就是不相信别人竟然可以不利用自己放弃的那一部分安全感,所以只能自己去搞定百分之百的安全感,让人心力交瘁。

    -
      -
    • 不要与缺乏安全感的人合作。尤其是婚姻。
    • -
    • 最大的勇敢,就是在孑然一身的时候,还勇于放弃部分安全感。“大智若愚”,大智更像是结果。若愚才是原因。
    • -
    • 将军赶路不打小鬼。
    • -
    -

    活在真实中

    -

    如果想活在真实的世界,就要勇于面对「真实」。要搞清楚以下几个概念。

    -

    什么算落后

    -
      -
    1. -

      20%之后都是落后,因为世界20%的人占了有限资源的80%。在人工智能和新技术时代,可能1%之后都算落后。将来可能是千分之一,万分之一之后都算。

      -
    2. -
    3. -

      我们每个人都已经可以尽量感知到这个世界的全部。所以要对自己是否处在落后状态有清晰认知。

      -
    4. -
    5. -

      我们对知识的渴求已经变成害怕落后。这是种危机感和焦虑,但它能帮我们持续进步,摆脱落后。

      -
    6. -
    -

    乌比冈湖效应:Lake Wobegon Effect 每个人都自认高于平均水平。

    -

    邓宁- 克鲁格效应 :Dunning-Kruger Effect 能力欠缺的人有一种虚幻的自我优越感,错误的认为自己比真实情况更加优秀。

    -

    麻烦守恒定律:以前因为怕麻烦二省去的麻烦,在未来的某一天,或者未来的某一时刻,一定会以另一种形式呈现在你面前。麻烦不会无缘无故的消失,问题也不会无缘无故的解决。

    -

    元认知能力

    -

    :pencil:指对自己的思考过程的认知和理解

    -

    元认知能力起作用的三个步骤:

    -
      -
    1. 哦,原来我是这么想的。
    2. -
    3. 嗯?我这么想难道是不对的吗?
    4. -
    5. 啊!我应该这么想才对。。。。
    6. -
    -

    认知能力好比是马,而元认知能力是马车夫。所谓可以用来解放自己的“心智”,指的就是具备足够的元认知能力的大脑。人与人之间的技能差异,证据确凿来自于“刻意锻炼”。而一个人能做到“刻意锻炼”,唯一能够仰仗的就是元认知能力。

    -
      -
    • 元认知能力是一个人可拥有的最重要的能力。
    • -
    • 元认知能力不仅可以习得,还可以通过刻意训练长期持续发展。
    • -
    -

    我们知道我们想要改变的,能够改变的,不是“现在的自己”,而是“将来的自己”。通过刻意练习提高元认知能力的三个方法:坐享、兴趣、反思。

    -
      -
    • -

      坐享:可以增加大脑皮层的沟回。

      -
    • -
    • -

      兴趣:兴趣是最好的教学。

      -
    • -
    • -

      反思:每天花十分钟反思一下自己的思路和思考结果,琢磨一下自己想法有没有逻辑错误。不仅是元认知能力的刻意训练方式,也是调整情绪的根本。

      -
    • -
    -

    竞争力

    -

    多维竞争

    -

    😂 据说绝大多数人的幸福感是建立在比较之上的。有个玩笑:所谓的幸福就是自己的收入总比妹夫的收入多百分之二十。。。。。

    -

    😂 一般人所谓的“成长”,就是不断的把别人比下去的过程。

    -

    维度在生活上有三个体现:

    -
      -
    1. 生活是有多个维度的。
    2. -
    3. 在多个维度打造竞争力。
    4. -
    5. 至少在一个维度上足够突出。凡事都是有成本。处处平庸是不行的。
    6. -
    -

    面对维度,要有以下意识:

    -
      -
    • 单个维度,大家比的是长度,两个维度上大家比的是面积,三个维度上大家比的是体积。
    • -
    • 每次跨界,都是给自己拓展一个新的维度。
    • -
    • 对新知识保持开放态度。
    • -
    -

    应用层面

    -

    「活在未来」

    -

    如何活在未来

    -
      -
    1. 对未来要有个预测
    2. -
    3. 那个预测需要时间才能得到结果
    4. -
    5. 笃信你的预测是正确的。
    6. -
    7. 于是你按照那个预测的结果行动、选择、思考。
    8. -
    9. 你终将走到那个结果出现的时刻
    10. -
    11. 最终证明你的预测是正确的。
    12. -
    13. 那么,由于你提前按未来正确的结果行动、选择、思考,于是,在相当长的时间里,你生活的一部分就是“活在未来”。
    14. -
    -

    人际关系的本质

    -

    人际关系在本质上还是交易。明白这一点,就能更清楚的看清楚关于贵人的问题。

    -

    $ 求助别人 != 麻烦别人 $

    -

    求助不是低声下气的行为,而是一种交易。不仅如此,还是一种隐蔽的、意义巨大的交易。贵人之所以原因帮助你,是因为他已经看到你的价值。分清楚“求助”、“乞讨”、“添麻烦”、“占便宜”之间的区别。

    -

    能够遇到贵人在一定程度上是偶然也是必然,它是自己生活的一面镜子。你是贵人,生活这面镜子就帮你找到更多的贵人。至于是偶然还是必然,其实你是控制不了的。自己首先得是个贵人,才能遇到贵人,甚至更多贵人。最不济,你也已经成为自己的贵人,而且不会轻易离你而去。“遇到贵人”这件事从来不是我们的目的,相反“成为贵人”倒是我们应该努力的方向。在你出手相助的那一瞬间,你已经得到了自然的回报。

    -

    12条遇到贵人的原则:

    -
      -
    1. 乐观的人更容易成为他人的贵人
    2. -
    3. 贵人更容易遇到贵人
    4. -
    5. 能帮助他人进步,才是真正的贵人
    6. -
    7. 优秀的、值得尊重的人,更容易获得帮助。
    8. -
    9. 乐于分享的人容易获得帮助
    10. -
    11. 不给他人制造负担的人容易获得帮助
    12. -
    13. 不以求助为耻的人容易获得帮助
    14. -
    15. 求助的时候不仅仅用金钱作为回报,帮助他人的时候也不应该收取金钱回报。
    16. -
    17. 贵人不一定是牛人,贵人通常“以和为贵”。
    18. -
    19. 很多时候,人们的成功,来源于大量的人希望看到他成功。反过来,如果大量的人不愿意看到某人成功,那么这个人真的很难获得所谓的“贵人相助”
    20. -
    21. 正在做“正确”事情,更容易获得贵人相助。也就是所谓的“得道多助”。
    22. -
    23. 活在未来的人更容易遇到贵人,因为别人能在他身上看到未来
    24. -
    -

    资本的定义

    -

    钱和资本不是一样的东西,正如砖头和房子不是一回事。钱要成为资本必须满足三个基本要素:

    -
      -
    1. 资金的金额大小
    2. -
    3. 资金的使用时限
    4. -
    5. 资金背后的智慧
    6. -
    -

    残酷的事实,大多数人其实不配站在资本之后。好消息是资本背后的实力是可以习得的。不能被自己心平气和判上无期徒刑的资金,就别假装资本出来混迹江湖。大多数人在股票市场上“投资”的不是资本,而是“装傻充愣的资金”而已。

    -

    暂时不知道往哪里分

    -
      -
    • 好的工具应该让人离开它,而不是黏住它。
    • -
    • 你创造财富能力取决于你能给别人创造多少真正的价值。(只有你觉得有价值的话,是几乎没有什么意义的)。
    • -
    -

    财富自由之路 - 思维导图 (看全景导图请点击链接

    -
    -
    - -
    -
    -
    -
    - - - - - - - - - - - -
    -
    - -
    -
    - - - - - - - -
    -
    -
    -
    - -
    -
    - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - - - \ No newline at end of file diff --git a/docs/rzf-organisation.html b/docs/rzf-organisation.html index 99fdcfe..e69de29 100644 --- a/docs/rzf-organisation.html +++ b/docs/rzf-organisation.html @@ -1,559 +0,0 @@ - - - - - - RZF Organisation | 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - -
    - - - - -
    -
    - - -
    - - - - - -

    - RZF Organisation -

    - - -
    - - -
    - - - -
    - 文章目录 -
    1. 1. Kontakt
      1. 1.1. Abteilung
      2. 1.2. Personal
        1. 1.2.1. Rohde, Rainer
        2. 1.2.2. Uphoff, Christian
    -
    - - - -

    Kontakt

    -

    Abteilung

    -
      -
    • Verteiler “V-Krank
      -Für Ihre Krank- bzw. Gesundmeldung sowie alle übrigen Mitteilungen zum Thema Krankheit nutzen Sie bitte den Verteiler V-Krank (V-Krank-5011@fv.nrw.de).
    • -
    • Verteiler “V-Heimarbeitszeiten
      -Für die Meldung der Heimarbeitszeiten nutzen Sie bitte den Verteiler V-Heimarbeitszeiten (V-Heimarbeitszeiten-5011@fv.nrw.de).
    • -
    • Verteiler “V-Dienstreisezeiten
      -Über den Verteiler V-Dienstreisezeiten (V-Dienstreisezeiten-5011@fv.nrw.de) teilen Sie bitte Ihre Dienstreisezeiten, Lehrgangzeiten sowie das Ende des Dienstgeschäftes bei Dienstgängen mit. Zur Berechnung der Reisezeiten nutzen Sie bitte das im OASE-Vordruckschrank hinterlegte Berechnungsblatt (Vordruck H76 Reisezeitenberechnung).
    • -
    • Verteiler “V-GST
      -Den Verteiler V-GST (V-GST-5011@fv.nrw.de) verwenden Sie insbesondere für die nachfolgenden Angelegenheiten:
      -Fragen/Mitteilungen zum Thema Urlaub, Sonderurlaub, Dienstbefreiung -
        -
      • Mitteilung von Zeiten bei vergessenen oder fehlerhaften GLAZ-Buchungen
      • -
      • Mitteilung über die ganztägige Kernzeitinanspruchnahme (GLAZ-Tag)
      • -
      • alle Fragen/Mitteilungen zu den übrigen Personalangelegenheiten, die nicht über die vorgenannten Verteiler abgedeckt sind.
      • -
      -
    • -
    -

    Personal

    -

    Rohde, Rainer

    -

    Telefon : (0211) 4572 - 2554
    -E-Mail: rainer.rohde@fv.nrw.de

    -

    Uphoff, Christian

    -

    christian.uphoff@fv.nrw.de

    -

    \Drucker \C0114237\DR011226

    - -
    - -
    -
    -
    -
    - - - - - - - - - - - -
    -
    - -
    -
    - - - - - - - -
    -
    -
    -
    - -
    -
    - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - - - \ No newline at end of file diff --git a/docs/search.xml b/docs/search.xml index d59103a..e69de29 100644 --- a/docs/search.xml +++ b/docs/search.xml @@ -1,397 +0,0 @@ - - - - <![CDATA[JavaScript & Typescript技术摘要]]> - %2Fwiki%2Fjavascript-typescript-skills.html - - - IT - Code - - - Hexo - - - - <![CDATA[MathJax用于易学领域]]> - %2Fwiki%2Fmathjax-yixue-usage.html - - - IT - skill - - - 工具 - - - - <![CDATA[用TypeScript编写JS函数库]]> - %2Fwiki%2FTypeScript-build-JS-Package.html - - - IT - skill - - - 工具 - - - - <![CDATA[还在用七牛?]]> - %2Fwiki%2Fstill-using-qiniu.html - - - IT - skill - - - 工具 - - - - <![CDATA[Gitbook攻略]]> - %2Fwiki%2Fgitbook_with_typora_gh-pages.html - - - IT - Tools - - - 工具 - - - - <![CDATA[配置服务器端MySQL]]> - %2Fwiki%2Fconfig-mysql-access-privileges-on-vps.html - - - IT - Tools - - - 工具 - - - - <![CDATA[斯多葛主义手册]]> - %2Fwiki%2Fstoric-summary.html - - - 读书笔记 - - - 哲理 - 书籍 - - - - <![CDATA[同步Hexo文章与Mac上原笔记的分类和标签]]> - %2Fwiki%2Fsynchron-the-tag-and-categories-btw-pc-hexo.html - - - IT - Web - - - Hexo - Mac - - - - <![CDATA[有用的Shell命令]]> - %2Fwiki%2Fhelpfull-shell-command.html - - - IT - Tools - - - 工具 - - - - <![CDATA[Hexo日常管理]]> - %2Fwiki%2Fhexo-blog-alltag-verwalten.html - - - 常用文件 - - - Hexo - - - - <![CDATA[佛偈集合]]> - %2Fwiki%2Fbudahlisisch-poeim-collection.html - - - 摘录 - 片段 - - - 文学 - - - - <![CDATA[简短书摘]]> - %2Fwiki%2Fbrief-notions-collection.html - - - 摘录 - 片段 - - - 文学 - - - - <![CDATA[零散句子]]> - %2Fwiki%2Ffunny-sloga-collection.html - - - 摘录 - 片段 - - - 文学 - - - - <![CDATA[典故]]> - %2Fwiki%2Fold-stories-collection.html - - - 摘录 - - - 历史政治 - - - - <![CDATA[搞笑段子]]> - %2Fwiki%2Ffunny-things-collection.html - - - 摘录 - 娱乐 - - - 娱乐 - - - - <![CDATA[缠中说禅]]> - %2Fwiki%2Ffunny-things-collection.html - - - 摘录 - 片段 - - - 文学 - - - - <![CDATA[名人语录]]> - %2Fwiki%2Fprominaent-slogen-collection.html - - - 摘录 - 片段 - - - 文学 - - - - <![CDATA[如何系统化管理Hexo博客]]> - %2Fwiki%2Fhow-to-manage-big-hexo-blog.html - - - IT - Web - - - Hexo - - - - <![CDATA[《驴得水》——影评]]> - %2Fwiki%2Flvdeshui-film.html - - - 摘录 - - - 影视 - - - - <![CDATA[编辑器工具使用技巧汇总]]> - %2Fwiki%2FEditor-Skills-Summary.html - - - IT - Tools - - - 工具 - - - - <![CDATA[Ubuntu重设root用户密码]]> - %2Fwiki%2Fubuntu-reset-root-pw.html - - - IT - Tools - - - 工具 - - - - <![CDATA[搭建Hexo博客的流水账]]> - %2Fwiki%2Fhow-build-my-hexo-blog.html - - - IT - Web - - - Hexo - - - - <![CDATA[坚果云有关]]> - %2Fwiki%2Fabout-jianguoyu.html - - - IT - Tools - - - 工具 - - - - <![CDATA[使用Github维护知识库]]> - %2Fwiki%2Fuse-github-in-wiki.html - - - IT - Tools - - - 工具 - - - - <![CDATA[Next以及wikitten主题添加内容折叠]]> - %2Fwiki%2Fnext-collapse-block.html - - - IT - Web - - - Hexo - - - - <![CDATA[RZF Organisation]]> - %2Fwiki%2Frzf-organisation.html - - - 文档 - - - 工作 - - - - <![CDATA[Mac使用标签]]> - %2Fwiki%2Fmac-using-tags.html - - - IT - Mac - - - Mac - - - - <![CDATA[Mac备忘录]]> - %2Fwiki%2Fmac-memo.html - - - IT - Mac - - - Mac - - - - <![CDATA[爱乐之城——影评]]> - %2Fwiki%2Flalaland-film.html - - - 摘录 - - - 影视 - - - - <![CDATA[财富自由之路-李笑来]]> - %2Fwiki%2Froad-to-asset-freedom.html - - - 读书笔记 - - - 成长 - 经济 - - - - <![CDATA[《少有人走的路》笔记]]> - %2Fwiki%2Froad-less-traveled-summary.html - - - 读书笔记 - - - 成长 - 心理 - - - - <![CDATA[Hello World]]> - %2Fwiki%2Fhellow-world.html - - - 随笔 - - - Hexo - - - - <![CDATA[关于本站]]> - %2Fwiki%2Fabout%2Findex.html - - - - <![CDATA[分类]]> - %2Fwiki%2Fcategories%2Findex.html - - - - <![CDATA[标签]]> - %2Fwiki%2Ftags%2Findex.html - - - diff --git a/docs/sitemap.xml b/docs/sitemap.xml index ed3b36e..e69de29 100644 --- a/docs/sitemap.xml +++ b/docs/sitemap.xml @@ -1,249 +0,0 @@ - - - - - http://maiernte.github.io/wiki/mathjax-yixue-usage.html - - 2020-05-08T09:38:08.489Z - - - - - http://maiernte.github.io/wiki/mac-memo.html - - 2020-05-07T07:28:37.649Z - - - - - http://maiernte.github.io/wiki/javascript-typescript-skills.html - - 2019-09-16T18:53:45.000Z - - - - - http://maiernte.github.io/wiki/Editor-Skills-Summary.html - - 2019-09-01T17:11:47.000Z - - - - - http://maiernte.github.io/wiki/TypeScript-build-JS-Package.html - - 2019-08-24T11:30:40.000Z - - - - - http://maiernte.github.io/wiki/rzf-organisation.html - - 2019-08-22T08:39:21.000Z - - - - - http://maiernte.github.io/wiki/how-to-manage-big-hexo-blog.html - - 2019-08-15T21:51:57.000Z - - - - - http://maiernte.github.io/wiki/lvdeshui-film.html - - 2019-08-15T21:48:56.000Z - - - - - http://maiernte.github.io/wiki/budahlisisch-poeim-collection.html - - 2019-08-15T21:46:14.000Z - - - - - http://maiernte.github.io/wiki/how-build-my-hexo-blog.html - - 2019-08-15T10:44:25.000Z - - - - - http://maiernte.github.io/wiki/gitbook_with_typora_gh-pages.html - - 2019-08-15T09:46:18.000Z - - - - - http://maiernte.github.io/wiki/use-github-in-wiki.html - - 2019-08-15T09:40:53.000Z - - - - - http://maiernte.github.io/wiki/still-using-qiniu.html - - 2019-08-15T06:54:53.000Z - - - - - http://maiernte.github.io/wiki/about-jianguoyu.html - - 2019-08-14T22:10:30.000Z - - - - - http://maiernte.github.io/wiki/helpfull-shell-command.html - - 2019-08-14T13:12:36.000Z - - - - - http://maiernte.github.io/wiki/config-mysql-access-privileges-on-vps.html - - 2019-08-14T13:10:45.000Z - - - - - http://maiernte.github.io/wiki/road-to-asset-freedom.html - - 2019-08-14T06:36:09.000Z - - - - - http://maiernte.github.io/wiki/ubuntu-reset-root-pw.html - - 2019-08-14T06:34:27.000Z - - - - - http://maiernte.github.io/wiki/lalaland-film.html - - 2019-08-14T06:31:50.000Z - - - - - http://maiernte.github.io/wiki/storic-summary.html - - 2019-08-14T06:31:28.000Z - - - - - http://maiernte.github.io/wiki/funny-sloga-collection.html - - 2019-08-04T18:15:28.000Z - - - - - http://maiernte.github.io/wiki/synchron-the-tag-and-categories-btw-pc-hexo.html - - 2019-08-03T12:58:26.000Z - - - - - http://maiernte.github.io/wiki/hexo-blog-alltag-verwalten.html - - 2019-08-02T03:54:52.000Z - - - - - http://maiernte.github.io/wiki/road-less-traveled-summary.html - - 2019-08-01T04:04:18.000Z - - - - - http://maiernte.github.io/wiki/prominaent-slogen-collection.html - - 2019-07-31T03:51:35.000Z - - - - - http://maiernte.github.io/wiki/funny-things-collection.html - - 2019-07-31T03:51:35.000Z - - - - - http://maiernte.github.io/wiki/funny-things-collection.html - - 2019-07-31T03:51:35.000Z - - - - - http://maiernte.github.io/wiki/old-stories-collection.html - - 2019-07-31T03:51:35.000Z - - - - - http://maiernte.github.io/wiki/hellow-world.html - - 2019-07-31T03:51:35.000Z - - - - - http://maiernte.github.io/wiki/brief-notions-collection.html - - 2019-07-31T03:51:35.000Z - - - - - http://maiernte.github.io/wiki/mac-using-tags.html - - 2019-07-31T03:51:34.000Z - - - - - http://maiernte.github.io/wiki/next-collapse-block.html - - 2019-07-31T03:51:34.000Z - - - - - http://maiernte.github.io/wiki/about/index.html - - 2019-07-22T17:31:07.000Z - - - - - http://maiernte.github.io/wiki/categories/index.html - - 2019-07-22T03:39:06.000Z - - - - - http://maiernte.github.io/wiki/tags/index.html - - 2019-07-22T03:37:51.000Z - - - - diff --git a/docs/still-using-qiniu.html b/docs/still-using-qiniu.html index cfd483b..e69de29 100644 --- a/docs/still-using-qiniu.html +++ b/docs/still-using-qiniu.html @@ -1,554 +0,0 @@ - - - - - - 还在用七牛? | 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - -
    - - - - -
    -
    - - -
    - - - - - -

    - 还在用七牛? -

    - - -
    - - -
    - - - -
    - 文章目录 - -
    - - - -

    自从七牛换了服务条款,每个空间就只分配测试域名, 30天到期。想省钱的用户,必须每30天倒腾一次。如果忘记了,过了期限,据说图都找不回来。不想费那个劲的用户, 得绑定自己的域名。 这样不但增加费用,还要考虑到域名备案。 十分麻烦。

    - -

    这是我弃用七牛的主要原因。 第二个原因就是——! 也许我人在国外的原因吧, 每次打开七牛的后台,刷好几遍都打不开对象存储的页面,只能用第三方软件进行上传下载,那样会相对好一些.

    -

    第三个原因是七牛的图床不能分目录存储。 当图片越积越多的时候,管理和查找起来非常麻烦。比如我昨天用Typora的Pandoc功能将一个Word技术文档转换成MD文件,一个文件就有100来张图。放在七牛得分好几页显示了。如果再想找别的图, 那得多费劲.

    -

    后来还是把心思用在了Github上。 在自己的账号下新开一个仓库, 然后在自己的本地电脑专建立一个文件夹, 用来存放MD文档或者博客中使用到的图片, 把这个专门的文件夹推送到新的仓库就完了! 相比七牛, Github还有不少优势:

    -
      -
    • 可以分多级目录存储
    • -
    • 传输速度快 !(可能国内慢吧, 但国内可以同样的思路, 放到 Coding 或者 CSDN 上 )
    • -
    • 免费
    • -
    • 不限流量
    • -
    -

    还要我说啥呢?

    -

    但引用Github图片, 要做一个小小的改动. 比如Github上一个图片的原始地址是:

    -
    -

    https://github.com/maiernte/img/blob/master/books/ng-book2-71/image100.png

    -
    -

    需要把其中的 blob 改成 raw, 变成

    -
    -

    https://github.com/maiernte/img/raw/master/books/ng-book2-71/image100.png

    -
    -

    自打有了Github这个神器, 可以跟七牛说再见! 再也不见!

    - -
    - -
    -
    -
    -
    - - - - - - - - - - - -
    -
    - -
    -
    - - - - - - - -
    -
    -
    -
    - -
    -
    - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - - - \ No newline at end of file diff --git a/docs/storic-summary.html b/docs/storic-summary.html index 5b57361..e69de29 100644 --- a/docs/storic-summary.html +++ b/docs/storic-summary.html @@ -1,628 +0,0 @@ - - - - - - 斯多葛主义手册 | 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - -
    - - - - -
    -
    - - -
    - - - - - -

    - 斯多葛主义手册 -

    - - -
    - - -
    - - - -
    - 文章目录 - -
    - - - -
      -
    1. -

      世间的事,有些可控,有些不可控。可控的有:观点,追求,欲望,和喜恶等。这些都是我们自己可以做出选择的。不可控的是身体,财物,名声,指令等。这些我们都无法选择。

      -

      可控范围之内的东西在本质上是自由的,不被束缚、阻碍的。那些不可控的是虚的,是被奴役的,是我们受控于他人。记住,如果你觉得那些不可控的事物是自由的,那些受控于别人的也是你的,那么你就会被控制,被束缚。你会悲痛,你会受扰,你会指责神以及他人。但如果你只专注于你所能控制的,不被他人所拥有的干扰,那么就没有人能够影响你、束缚你。并且,你不会把过错推在他人身上。你不会去做违背你的意志的事。你不会有敌人。你也不会被伤害。

      -

      把这些当做你的目标,不让自己受那些没有意义的事诱惑,哪怕就一点点也不可以。放弃那些不可控的。如果你既想把握住可控的,又想拥有财富和权力,那么你将会什么都得不到,更不用说幸福和自由-因为幸福和自由是依赖于可控事物。

      -

      尽你最大的努力。这样你就可以对看似艰难的每一件事说:“你只不过是看起来艰难而已。” 然后比照你为自己制定的原则:这件事是否可控。如果在你控制范围之外,那么结果就无关乎于你。

      -
    2. -
    3. -

      欲望要求你去追求你想要的;厌恶则让你尽量避免你所讨厌的。但是,如果你得不到你想要的,你就会十分失望;如果你无法避免你所讨厌的,那你就会被厌恶扭曲。那么,如果你只讨厌那些在你出自本质所做选择的对立事物(即在你控制范围内你不会选择的事物),那么你就永远不需要去为之伤神。但是,如果你厌恶疾病、死亡、贫穷等你无法选择和改变的,那你就会被厌恶扭曲。不厌恶你所不能控制的,把厌恶限制在和你本性对立的事物。但是,就目前来说,压制你的欲望:因为如果你追求任何可控范围之外的事物,那你就必然会失望。不要轻易追求或者厌恶。

      -
    4. -
    5. -

      对于给你带来乐趣、有用处以及你十分喜欢的东西,从最不重要的事情开始,记得提醒你自己:他们真正的本质是什么。比如说,你很喜欢某个陶瓷杯,提醒你自己那只是因为你喜欢陶瓷杯而已,而不在于具体是哪个杯子。这样,如果杯子碎了,你也不会太伤心。当你亲吻你的家人时,提醒你自己你只是在亲吻和你亲近的人,这样当他们离世时,你就不会太难过。

      -
    6. -
    7. -

      当你做事情时,提醒你自己事情的本质是什么,你可能遇到哪些情况。比如说洗澡。在你洗澡之前,先想想洗澡时会发生哪些事情。有的人可能会把水溅得哪都是,有人可能会推娜,有人会诅咒,有人会偷东西。这样你在洗澡之前就可以跟自己说:“我现在要去洗澡了,任何这些事都有可能发生,但是这不是我能控制的,所以我会保持好的心态”。如果你以同样的心态去对待任何其他事情,你内心的平和就不会被打扰。因为你可以对自己说:”我希望的不仅仅是洗澡,还有不被任何意外困扰”。

      -
    8. -
    9. -

      人内心困扰时,通常不是被事物本身困扰,而是被他们自己的原则和概念所困扰。比如说,死亡本身并不可怕,要不然苏格拉底面临死亡时该有多么惊慌。我们对死亡的恐惧是源于我们对死亡的概念:死亡是可怕的。当我们被困扰、阻碍,伤心难过时,我们不要从事物本身或者他人身上找原因,而应该反省我们自己,还有我们的原则。一个还不通明的人,会把自己的糟糕情况怪罪于他人。一个刚刚开始学习处理这些情况的人,会从自己身上找原因。而一个已经通彻的人,既不会怪罪别人,也不会苛求自己。

      -
    10. -
    11. -

      不要为任何身外之物骄傲。一匹马可以因为自己的英爽豪气自豪,因为这是它本身拥有的。但是如果你因为拥有这样一匹马儿骄傲,事实上,你所自豪的,不过是马所拥有的好。那么,什么才是属于你的呢?你对事物的反应和态度。如果你对任何事物的形态的处之泰然,那么你就可以为你的理性自豪,因为这是属于你的。

      -
    12. -
    13. -

      想象以下情况:在一次航海旅行中,你的船抛锚靠岸了,你上岸去找水,途中你还捡了些你喜欢的贝壳,或者买个洋葱。但是,你的所有注意力必须一直集中在那艘船上,注意船长什么时候呼叫大家上船继续航行。当船长呼叫时,你必须立刻放下手中所有的东西,否则你就会被手脚捆绑得像只羊一样抛到船上。生活也是这样。生活给你老婆孩子,而不是洋葱贝壳。如果生活的船长呼叫了,你必须离开他们,立马跑到船上,而不是光顾着他们。如果你年纪大了,那你就不能离开船太远,否则你可能来不及回到船上。

      -
    14. -
    15. -

      不要苛求生活给予你所有你想要的,该发生的就会发生,随遇而安就好。

      -
    16. -
    17. -

      疾病影响的只是你的身体,而不是你选择的能力,除非那是你的选择。瘸的是腿,而不是你的脑子。不管发生什么事,只要这么跟自己说,你就会明白困难阻碍的是事物,而不是你。

      -
    18. -
    19. -

      对于每一件发生的事,检视你自己的能力,问你自己能够用哪些能力从每一件事情中获得什么适当的用处。遇到一个十分有吸引力的人时,你就会发现你的自控就是你的能力。当你痛苦时,你会发现自己的坚强。听到坏话时,你会发现自己的耐心。形成了这样的习惯之后,你就不会被事物的表象所影响。

      -
    20. -
    21. -

      不要说:“我失去了什么”。而应该说:“我归还了什么”。如果你的孩子或者妻子不幸离世了,你不是失去他们了,而是他们回归了。如果你的房子被夺走了,同样的,你是归还它们了。你可能会说:“可是那些夺走我房子的人是坏人!“。可是,给予你的人让谁来夺走你的房子真的那么重要吗?当你拥有时,照顾好它,但不要把它当做永久财物,就当自己是一个在那暂住的旅行者。

      -
    22. -
    23. -

      如果你想要提高自己,那就要拒绝以下思考方式:“如果我忽视那些琐事,那我就没有收入;如果我不更正我的仆人,那他们就会变坏”。 如果能够免于悲伤和恐惧,即使死于饥饿,那也比富得流油但备受精神困扰好得多。比起坏仆人,难道你的开心不是更重要吗?

      -

      如果你想要让自己变得更好,那就从小事做起。油洒了,酒被偷了,没关系,告诉你自己:“那只不过是平静生活的一点点代价。任何事情都是有代价的”。当你召集你的仆人时,他们可能不会来,也可能来了但是做的事情不合你意。但是他们并没有重要得以至于你必须打破自己的平静。

      -
    24. -
    25. -

      如果你想要让自己变得更好,那就不要在乎被人认为你是愚蠢的。不要希望别人认为你无所不知。即使你看上去好像对别人来说很重要,也不要被这种虚名欺骗。因为想要既保持内心平和又拥有外在事物是非常困难的。当你专注于二者之一时,你必然会忽略剩下的那个。

      -
    26. -
    27. -

      如果你希望你的家人、朋友长生不老,那是很愚蠢的想法。因为生死是在你控制范围之外的,是关乎他人的。同样地,如果你希望你的仆人不犯错,那你和傻瓜无异,因为你希望错误不是错误。但是,如果你希望你的欲望不带来失望,那是在你所能控制的范围之内的。练习控制你所能控制的。一个能够控制自己的喜恶的人,是自己生活的主人。这样的人,是真正自由的,不会成为被自己的欲望控制的奴隶,不会喜欢或者厌恶那些受别人控制的事物。

      -
    28. -
    29. -

      记住生活就像是一个晚餐聚会一样。如果别人递给你一盘食物,你应该伸出手去接,舀起适当份量给自己。如果盘子从你身边递过,不要试图去截取。如果还没轮到你这,不要起身去拿,而是等着别人递到你面前。用相同的态度对待孩子,配偶,财物,公共职位,这样你最终自然就会成为诸神宴会的搭档。如果你不仅能够做到这些,还能够做到不去拿你面前的食物,甚至是有能力拒绝你自己的欲望,这样你不仅仅能够成为诸神宴会的搭档,你还能进入他们的国度,成为为他们的一员。像Diogenes, Heraclitus这些人就是因为他们的尊贵行为而被视为神一般神圣。

      -
    30. -
    31. -

      当你看到别人因为孩子出国了,或者离世了,或者因为被琐事困扰而哭泣伤心时,不要让这些情感表象误导你。你必须作出自己的判断,明白他的伤心难过不是因为发生的事情本身,因为其他同样身处其中的人并没有受到同样的影响。他之所以受到那么大的困扰,是因为他自己本身对事情的判断。不要让自己和他一样受影响,不要让自己一样受困扰,不管是外在表现还是内心感受上。

      -
    32. -
    33. -

      记住你只是一出戏里的一个演员,而戏份角色并不是由你决定的。不管角色故事长短,不管你是一个穷人,瘸子,政府官员,或者是一个很私密的人,把你的角色演好演自然了就行。把分配给你的角色演好,那是你的本分;而到底是哪个角色,那不是由你决定的。

      -
    34. -
    35. -

      如果一只乌鸦向你预示不幸的事即将发生,不要让你内心的平静被这个表象破坏。要即刻告诉自己,“我不知道会发生什么,我不知道我的身体,财物,名声,或者家人会受什么影响,如果我愿意理性地去想,那么所有的这些恶兆就会变成幸运,因为我可以控制我要用什么态度去对待这些事情。不管发生什么,我都可以从中获得对我有利的。

      -
    36. -
    37. -

      如果你不去参与在你控制范围之外的任何战斗,那你就不会被打败。当你看到那些声名显赫,社会地位高,或者在任何方面做得很好的人,不要着急认为他们是开心的。因为如果我们清楚明白幸福只在于我们所能够控制的范围内,那我们就不会去羡慕或者攀比。不要向往头衔,而是要向往内心自由和平静。而要做到这一点,唯一的途径是要看轻我们控制范围之外的一切事物。

      -
    38. -
    39. -

      记住,那些对你出言不逊或者动手的人他本身并不是一种羞辱,而是代表那些言行的原则让你感觉到被羞辱。如果有人激怒你了,那是你对这种行为的观点激怒了你。试着不要被事情的表象牵引你的情感。给予适当的时间和稍作休息,你就能够很好地调整控制自己的情感。

      -
    40. -
    41. -

      把死亡和流放这些看似可怕的事看作是日常,那你就赢了。不用害怕贫穷,也不要刻意贪求任何东西。

      -
    42. -
    43. -

      如果你真心希望从哲学中获益,那么就要做好被众人嘲笑的准备:“她这是准备要成为一个哲学家呢”,“瞧她那傲慢的样子”……这个时候,你该做的,不是摆起傲慢的样子,而是要以神圣的态度忠诚于你所认定的,这样总有一天嘲笑你的人会开始尊敬你崇拜你。但是如果你被这些嘲笑打败,那你就成了双重的笑话。

      -
    44. -
    45. -

      如果你为了取悦他人而把你的注意力转移到那些外在的你无法控制的事物上,那么恭喜你,你已经成功地毁了你自己的生活了。

      -
    46. -
    47. -

      不要让以下这些思考方式困扰你:“我将会颜面丢尽,而且什么都不是。”耻辱是邪恶的,我们不应该被耻辱感所控制。因为获取权力或着被人嘲笑,这些都在你的控制范围之外。我们不用为任何在我们控制范围之外的事而感到耻辱。在我们可控范围之内,我们是自由的,能够左右我们自己的事情,是自我的主人-从这个角度看,我们永远不会什么都不是。“可是我帮不了我的朋友啊”,你可能会这么说。可是,怎么算是帮助朋友呢?你不能给他们钱,或者帮他们成为罗马市民。这些都是你所能控制范围之内的,是他们自己应该处理的事情。而且,如果这些都是你自己所没有的,那你怎么能够给他们呢?你可能会说:“如果我帮助他们获得这些的话,说不定我也能够得到一份呢“。如果我能够在保存我自己的尊严,忠诚和思想得到这些的话,请你帮我指明道路。可是如果你要我损害自己去得到你的利益,那这样的做法不仅不公平,而且愚蠢至极。

      -
    48. -
    49. -

      如果别人,而不是你,被邀请去宴会,或者被赞美,或者被别人咨询,不要懊恼。如果这些是好事,你应该为他人高兴。如果是坏事,不要难过。记住:这些都是在你的控制范围之外的,这样的对待一般是有对应的代价的。如果你不愿意付出这样的代价而希望得到同样的对待,那是不公平的。比如说别人用50分买了一棵生菜,但是你不想花这50分,那你就不应该认为拥有生菜的人占了便宜。那个人付出50分得到了生菜,而你口袋里还有那没有花出去的50分。同理,宴会邀请,别人的赞美,这些都是有代价的。如果你觉得这些对你是有价值的,那你就要付出同等的价值去拥有。如果你不付出就想要得到这些,那么你就是个贪得无厌的傻瓜。换个角度想,在决定不和别人交换价值的时候,你真的什么都没有得到吗?不是的:你得到了不赞美你不想赞美的人的自由,而且也不需要容忍你不想容忍的行为。

      -
    50. -
    51. -

      记住:很多事情不应该分自我或者他人。举个例子,如果邻居家的孩子打破了个杯子或者其他什么东西,我们很容易会说:“没事的,打碎东西是正常的”。可是如果打碎的是你自己的杯子呢?你应该作出相同的反应,而不是心生懊恼。同理,当别人的孩子或者妻子去世了,我们知道死亡的悲剧有时候是不可避免的,但是如果发生在我们自己身上的时候,我们却心如刀割。但是,我们应该清醒的认识到类似的悲剧不是我们能够控制的,我们所能够控制的是自己的情绪和反应,因为即使是发生在自己的身上,死亡本身并没有因为我们和死者的关系而变的更糟糕。

      -
    52. -
    53. -

      立一个靶子的目的,不是为了射失它(靶子的目的都是为了让人射中它)。那么同样的道理,大道创造出一个“恶”的事物(至少看起来如此),不是为了让人绕开它。

      -
    54. -
    55. -

      如果别人把你的身体交给一个路上遇到的陌生人,你一定会很生气。可是当别人用恶语打击你的时候,你为什么要心甘情愿地让别人控制你的思想,困惑你呢?

      -
    56. -
    57. -

      做每件事情都要考虑缘由和后果之后才能开始行动。如果你兴高采烈地开始而没有考虑可能发生的后果,当某些不好的后果开始出现时,你就会停止前进。拿参加奥林匹克赛事为例子。如果你把所有前因后果都考虑周全后认为参加比赛对你时有益的,那就全力以赴。其中,应该考虑的事情包括:你要遵守规则,节制饮食;不管风吹日晒雨淋都要雷打不动地坚持按时锻炼;你不能喝凉水活着酒。你必须全身心地、完全忘我地投入训练。而且,要做思想准备准备,比赛中你有可能会摔入沟里,胳膊脱臼,脚踝受伤,吃入尘土,被鞭打,甚至最后以失败告终。当你评估完所有的可能性之后还是一心想比赛,那就以战争的姿态出发。否则,你就会像孩子过家家一样:一会扮摔跤手,一会扮角斗士,一会吹喇叭,一会又想参加戏剧演出。这样,即使你什么都做过,但是什么都不是。就想大猩猩一样,你模仿你所看到的一切,不停地换把戏可能是一件好玩的事,但是你很快就玩腻了。你从来都没有完全投入过任何事,没有深度地从各个角度考虑和研究所有相关的细节,而只是凭一时的兴趣蜻蜓点水般地接触了各种行业。有些人当他们看到一个人说话的方式和Euphrates十分相像(不过事实上,真的有人能和Euphrates一样犀利善辩吗?),他们认为自己也能够拥有和哲学家一样的思想。但是,如果你细想一下,如果你想要成为一个摔跤手,那么你必须具备有摔跤手的宽阔肩膀,强有力的背部和大腿。但是每一个人的身体构造都是不一样的,你必须具有必备的条件才能称为一个好的摔跤手。同理,要想成为一个哲学家,你不能像你现在这样随心所欲地吃喝,不能让愤怒和不满控制你的情绪,你必须细心观察,劳作,控制自己的欲望,你必须能够忍受孤独,仆人的不敬,和外人的嘲笑,你必须能够接受别人在其他方面做得比你好。如果你已经仔细考虑过这些情况,如果你认为如果做到以上这些可以让你享受自由和宁静,那就尽情去追求哲学家的道路。如果你无法做到这些的话,那么就请不要继续,不要像孩子一样,一会试试做哲学,一会又想当政治家,演讲者,或者凯撒的军官。这些追求是互相矛盾的,你只能成为其中一个,不管做得好坏。你必须培养你自己内在的能够掌控行为的能力,或者外在的技术,二者只能取其一。

      -
    58. -
    59. -

      一个人的责任是由和别人的关系定义和衡量的。如果一个人拥有父亲的角色,那么他就有以下权利:他的孩子要照顾他,遵从他,耐心听他训话和教导。那如果他不是一个好父亲呢?他也应该受到同等的对待,因为我们无法选择我们的父亲是谁。不管他做了什么,你必须做到让自己心安理得。因为只有你能够让别人的行为伤害到你。当你觉得你被伤害了,那你就会被伤害。如果你以同样的逻辑看待邻居,市民,将军这些不同的角色,你就能够清楚地明白与这些角色相对应的社会责任。

      -
    60. -
    -
    - -
    -
    -
    -
    - - - - - - - - - - - -
    -
    - -
    -
    - - - - - - - -
    -
    -
    -
    - -
    -
    - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - - - \ No newline at end of file diff --git a/docs/synchron-the-tag-and-categories-btw-pc-hexo.html b/docs/synchron-the-tag-and-categories-btw-pc-hexo.html index 340410f..e69de29 100644 --- a/docs/synchron-the-tag-and-categories-btw-pc-hexo.html +++ b/docs/synchron-the-tag-and-categories-btw-pc-hexo.html @@ -1,543 +0,0 @@ - - - - - - 同步Hexo文章与Mac上原笔记的分类和标签 | 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - -
    - - - - -
    -
    - - -
    - - - - - -

    - 同步Hexo文章与Mac上原笔记的分类和标签 -

    - - -
    - - -
    - - - -
    - 文章目录 - -
    - - - -

    最近才搞明白,原来Hexo博客的_post文件夹里面的Markdown原文件是可以按照分级嵌套的目录结构摆放的。编译的时候才放到public这个单一目录下。如果能让文章在Hexo的==分类==严格跟md文件的存储目录一一对应,将来需要找原文件的时侯会方便很多。😄

    -

    使用Mac系统的同学也知道,mac有个很风骚的操作,就是给文件分配不同颜色的标签,非常方便文件寻找。我也希望博客上的文章标签,能跟Mac系统里的标签统一起来。:smile:

    -

    实现物理存储目录与Hexo分类统一很简单,将源md文件的相对存储路径写到文件meta元素的categories里面就行了。比如源文件放在我的博客-->IT-->前端,文章的头文件就写成这样:categories:[IT, 前端]

    -

    实现标签的统一稍微麻烦一点,需要先读取文件实际分配到的标签。网上已经有一个公开的项目, tag 。下载并安装,就可以通过 tag 命令读取文件和文件夹的标签。

    -
    1
    2
    3
    4
    5
    6
    # 安装
    brew install tag
    # 查看版本
    tag --version
    # 读取文件标签
    tag --list fileUrl
    -

    我已经写好了相应的脚本文件,下载并执行脚本文件就好了。脚本文件里的dirPath变量是我的统一存放md源文件的文件夹,你需要改成自己的存放路径,那样就不用每次运行的时候输入一遍。

    -
    -

    我在Hexo项目的根目录新添一个文件夹专门存放管理的脚本文件,每次都在终端运行这个脚本,所以默认执行路径是 ./source/_post

    -
    -

    运行脚本的时候可以设定时间参数,过滤掉太久远的文件。默认情况不会更改文件内容,只查看文件的实际分类和标签是否与文内头文件相同。然后按照给出的列表手动更改。如果想让程序自动更改,按照提示输入fix参数就好。

    - -
    - -
    -
    -
    -
    - - - - - - - - - - - -
    -
    - -
    -
    - - - - - - - -
    -
    -
    -
    - -
    -
    - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - - - \ No newline at end of file diff --git a/docs/tags/Hexo/index.html b/docs/tags/Hexo/index.html index af7c0cc..e69de29 100644 --- a/docs/tags/Hexo/index.html +++ b/docs/tags/Hexo/index.html @@ -1,674 +0,0 @@ - - - - - - 标签: Hexo | 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - -
    - - - - -
    -
    -
    - -

    #Hexo

    -
    - -
    - -
    - - -

    - JavaScript & Typescript技术摘要 -

    - - - -
    -
    - -
    - -
    - - -

    - 同步Hexo文章与Mac上原笔记的分类和标签 -

    - - - -
    -
    - -
    - -
    - - -

    - Hexo日常管理 -

    - - - -
    -
    - -
    - -
    - - -

    - 如何系统化管理Hexo博客 -

    - - - -
    -
    - -
    - -
    - - -

    - 搭建Hexo博客的流水账 -

    - - - -
    -
    - -
    - -
    - - -

    - Next以及wikitten主题添加内容折叠 -

    - - - -
    -
    - -
    - -
    - - -

    - Hello World -

    - - - -
    -
    - -
    -
    -
    -
    -
    - -
    -
    - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - - - \ No newline at end of file diff --git a/docs/tags/Mac/index.html b/docs/tags/Mac/index.html index 1b08a87..e69de29 100644 --- a/docs/tags/Mac/index.html +++ b/docs/tags/Mac/index.html @@ -1,530 +0,0 @@ - - - - - - 标签: Mac | 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - -
    - - - - -
    -
    -
    - -

    #Mac

    -
    - -
    - -
    - - -

    - 同步Hexo文章与Mac上原笔记的分类和标签 -

    - - - -
    -
    - -
    - -
    - - -

    - Mac使用标签 -

    - - - -
    -
    - -
    - -
    - - -

    - Mac备忘录 -

    - - - -
    -
    - -
    -
    -
    -
    -
    - -
    -
    - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - - - \ No newline at end of file diff --git a/docs/tags/index.html b/docs/tags/index.html index 0e9889f..e69de29 100644 --- a/docs/tags/index.html +++ b/docs/tags/index.html @@ -1,426 +0,0 @@ - - - - - - 标签 | 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - -
    - - - - -
    -
    - 标签 -
    - -
    -
    -
    -
    - -
    -
    - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - - - \ No newline at end of file diff --git "a/docs/tags/\344\271\246\347\261\215/index.html" "b/docs/tags/\344\271\246\347\261\215/index.html" index 68f528d..e69de29 100644 --- "a/docs/tags/\344\271\246\347\261\215/index.html" +++ "b/docs/tags/\344\271\246\347\261\215/index.html" @@ -1,458 +0,0 @@ - - - - - - 标签: 书籍 | 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - -
    - - - - -
    -
    -
    - -

    #书籍

    -
    - -
    - -
    - - -

    - 斯多葛主义手册 -

    - - - -
    -
    - -
    -
    -
    -
    -
    - -
    -
    - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - - - \ No newline at end of file diff --git "a/docs/tags/\345\216\206\345\217\262\346\224\277\346\262\273/index.html" "b/docs/tags/\345\216\206\345\217\262\346\224\277\346\262\273/index.html" index 4effef6..e69de29 100644 --- "a/docs/tags/\345\216\206\345\217\262\346\224\277\346\262\273/index.html" +++ "b/docs/tags/\345\216\206\345\217\262\346\224\277\346\262\273/index.html" @@ -1,458 +0,0 @@ - - - - - - 标签: 历史政治 | 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - -
    - - - - -
    -
    -
    - -

    #历史政治

    -
    - -
    - -
    - - -

    - 典故 -

    - - - -
    -
    - -
    -
    -
    -
    -
    - -
    -
    - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - - - \ No newline at end of file diff --git "a/docs/tags/\345\223\262\347\220\206/index.html" "b/docs/tags/\345\223\262\347\220\206/index.html" index 7451297..e69de29 100644 --- "a/docs/tags/\345\223\262\347\220\206/index.html" +++ "b/docs/tags/\345\223\262\347\220\206/index.html" @@ -1,458 +0,0 @@ - - - - - - 标签: 哲理 | 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - -
    - - - - -
    -
    -
    - -

    #哲理

    -
    - -
    - -
    - - -

    - 斯多葛主义手册 -

    - - - -
    -
    - -
    -
    -
    -
    -
    - -
    -
    - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - - - \ No newline at end of file diff --git "a/docs/tags/\345\250\261\344\271\220/index.html" "b/docs/tags/\345\250\261\344\271\220/index.html" index cc8615d..e69de29 100644 --- "a/docs/tags/\345\250\261\344\271\220/index.html" +++ "b/docs/tags/\345\250\261\344\271\220/index.html" @@ -1,458 +0,0 @@ - - - - - - 标签: 娱乐 | 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - -
    - - - - -
    -
    -
    - -

    #娱乐

    -
    - -
    - -
    - - -

    - 搞笑段子 -

    - - - -
    -
    - -
    -
    -
    -
    -
    - -
    -
    - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - - - \ No newline at end of file diff --git "a/docs/tags/\345\267\245\344\275\234/index.html" "b/docs/tags/\345\267\245\344\275\234/index.html" index 869b547..e69de29 100644 --- "a/docs/tags/\345\267\245\344\275\234/index.html" +++ "b/docs/tags/\345\267\245\344\275\234/index.html" @@ -1,458 +0,0 @@ - - - - - - 标签: 工作 | 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - -
    - - - - -
    -
    -
    - -

    #工作

    -
    - -
    - -
    - - -

    - RZF Organisation -

    - - - -
    -
    - -
    -
    -
    -
    -
    - -
    -
    - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - - - \ No newline at end of file diff --git "a/docs/tags/\345\267\245\345\205\267/index.html" "b/docs/tags/\345\267\245\345\205\267/index.html" index 11830e9..e69de29 100644 --- "a/docs/tags/\345\267\245\345\205\267/index.html" +++ "b/docs/tags/\345\267\245\345\205\267/index.html" @@ -1,782 +0,0 @@ - - - - - - 标签: 工具 | 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - -
    - - - - -
    -
    -
    - -

    #工具

    -
    - -
    - -
    - - -

    - MathJax用于易学领域 -

    - - - -
    -
    - -
    - -
    - - -

    - 用TypeScript编写JS函数库 -

    - - - -
    -
    - -
    - -
    - - -

    - 还在用七牛? -

    - - - -
    -
    - -
    - -
    - - -

    - Gitbook攻略 -

    - - - -
    -
    - -
    - -
    - - -

    - 配置服务器端MySQL -

    - - - -
    -
    - -
    - -
    - - -

    - 有用的Shell命令 -

    - - - -
    -
    - -
    - -
    - - -

    - 编辑器工具使用技巧汇总 -

    - - - -
    -
    - -
    - -
    - - -

    - Ubuntu重设root用户密码 -

    - - - -
    -
    - -
    - -
    - - -

    - 坚果云有关 -

    - - - -
    -
    - -
    - -
    - - -

    - 使用Github维护知识库 -

    - - - -
    -
    - -
    -
    -
    -
    -
    - -
    -
    - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - - - \ No newline at end of file diff --git "a/docs/tags/\345\275\261\350\247\206/index.html" "b/docs/tags/\345\275\261\350\247\206/index.html" index 2acf189..e69de29 100644 --- "a/docs/tags/\345\275\261\350\247\206/index.html" +++ "b/docs/tags/\345\275\261\350\247\206/index.html" @@ -1,494 +0,0 @@ - - - - - - 标签: 影视 | 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - -
    - - - - -
    -
    -
    - -

    #影视

    -
    - -
    - -
    - - -

    - 《驴得水》——影评 -

    - - - -
    -
    - -
    - -
    - - -

    - 爱乐之城——影评 -

    - - - -
    -
    - -
    -
    -
    -
    -
    - -
    -
    - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - - - \ No newline at end of file diff --git "a/docs/tags/\345\277\203\347\220\206/index.html" "b/docs/tags/\345\277\203\347\220\206/index.html" index 7b9e560..e69de29 100644 --- "a/docs/tags/\345\277\203\347\220\206/index.html" +++ "b/docs/tags/\345\277\203\347\220\206/index.html" @@ -1,458 +0,0 @@ - - - - - - 标签: 心理 | 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - -
    - - - - -
    -
    -
    - -

    #心理

    -
    - -
    - -
    - - -

    - 《少有人走的路》笔记 -

    - - - -
    -
    - -
    -
    -
    -
    -
    - -
    -
    - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - - - \ No newline at end of file diff --git "a/docs/tags/\346\210\220\351\225\277/index.html" "b/docs/tags/\346\210\220\351\225\277/index.html" index 9f7687a..e69de29 100644 --- "a/docs/tags/\346\210\220\351\225\277/index.html" +++ "b/docs/tags/\346\210\220\351\225\277/index.html" @@ -1,494 +0,0 @@ - - - - - - 标签: 成长 | 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - -
    - - - - -
    -
    -
    - -

    #成长

    -
    - -
    - -
    - - -

    - 财富自由之路-李笑来 -

    - - - -
    -
    - -
    - -
    - - -

    - 《少有人走的路》笔记 -

    - - - -
    -
    - -
    -
    -
    -
    -
    - -
    -
    - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - - - \ No newline at end of file diff --git "a/docs/tags/\346\226\207\345\255\246/index.html" "b/docs/tags/\346\226\207\345\255\246/index.html" index 433f9b1..e69de29 100644 --- "a/docs/tags/\346\226\207\345\255\246/index.html" +++ "b/docs/tags/\346\226\207\345\255\246/index.html" @@ -1,602 +0,0 @@ - - - - - - 标签: 文学 | 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - -
    - - - - -
    -
    -
    - -

    #文学

    -
    - -
    - -
    - - -

    - 佛偈集合 -

    - - - -
    -
    - -
    - -
    - - -

    - 简短书摘 -

    - - - -
    -
    - -
    - -
    - - -

    - 零散句子 -

    - - - -
    -
    - -
    - -
    - - -

    - 名人语录 -

    - - - -
    -
    - -
    - -
    - - -

    - 缠中说禅 -

    - - - -
    -
    - -
    -
    -
    -
    -
    - -
    -
    - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - - - \ No newline at end of file diff --git "a/docs/tags/\347\273\217\346\265\216/index.html" "b/docs/tags/\347\273\217\346\265\216/index.html" index 0bd503a..e69de29 100644 --- "a/docs/tags/\347\273\217\346\265\216/index.html" +++ "b/docs/tags/\347\273\217\346\265\216/index.html" @@ -1,458 +0,0 @@ - - - - - - 标签: 经济 | 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - -
    - - - - -
    -
    -
    - -

    #经济

    -
    - -
    - -
    - - -

    - 财富自由之路-李笑来 -

    - - - -
    -
    - -
    -
    -
    -
    -
    - -
    -
    - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - - - \ No newline at end of file diff --git a/docs/ubuntu-reset-root-pw.html b/docs/ubuntu-reset-root-pw.html index a57abb4..e69de29 100644 --- a/docs/ubuntu-reset-root-pw.html +++ b/docs/ubuntu-reset-root-pw.html @@ -1,573 +0,0 @@ - - - - - - Ubuntu重设root用户密码 | 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - -
    - - - - -
    -
    - - -
    - - - - - -

    - Ubuntu重设root用户密码 -

    - - -
    - - -
    - - - -
    - 文章目录 -
    1. 1. 重设密码
    2. 2. 设置公共SSH
    -
    - - - -

    重设密码

    -

    原理上参考这份中文指引就好。由于我的服务器是IONOS公司的,这里主要记录IONOS的官方指引。(严格按照步骤)

    -
    1
    2
    网址 www.ionos.de/hilfe
    # 选择 Server & Cloud Infrastructure
    -
      -
    1. 打开 KVM-Konsole
    2. -
    3. 在用户管理平台软重启系统 Soft-Restart
    4. -
    5. 在 KVM-Konsole 这边按 ESC
    6. -
    7. 当出现类似一下界面,按 E
    8. -
    -

    -
      -
    1. -

      然后会来到这个界面。

      -
    2. -
    3. -

      -
    4. -
    5. -

      用上下键移动到“linux。。。”开始的那一行,并左右键移动到这行的末尾,空格,输入 init=/bin/bash

      -
    6. -
    -

    -
      -
    1. -

      F10 开始重启。等完成,进入命令模式后,输入以下命令。

      -
      1
      2
      3
      4
      5
      mount -o remount,rw /
      passwd
      Enter new UNIX password:
      Retype new UNIX password:
      passwd: password updated successfull
      -
    2. -
    3. -

      最后输入命令重启系统!

      -
      1
      reboot -f
      -
    4. -
    -

    设置公共SSH

    -

    在配置 github 的时候已经生成了 ssh-key ,可以用以下方法。

    -
    1
    2
    3
    4
    5
    6
    cd ~/.ssh
    cp id_rsa.pub authorized_keys
    ssh-copy-id -i ~/.ssh/id_rsa.pub root@217.160.61.19 # 我的用户名和服务器地址,默认端口 22
    # 指定端口号为2212:ssh-copy-id -i ~/.ssh/id_rsa.pub -p 2212 user@ip

    ssh root@217.160.61.19 # 登录并输入密码,第二次就不再需要密码了。
    -
    - -
    - -
    -
    -
    -
    - - - - - - - - - - - -
    -
    - -
    -
    - - - - - - - -
    -
    -
    -
    - -
    -
    - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - - - \ No newline at end of file diff --git a/docs/use-github-in-wiki.html b/docs/use-github-in-wiki.html index 24fddb9..e69de29 100644 --- a/docs/use-github-in-wiki.html +++ b/docs/use-github-in-wiki.html @@ -1,616 +0,0 @@ - - - - - - 使用Github维护知识库 | 天涯的维基 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - -
    - - - - -
    -
    - - -
    - - - - - -

    - 使用Github维护知识库 -

    - - -
    - - -
    - - - -
    - 文章目录 -
    1. 1. 部署以及更新
      1. 1.1. 详细指令
    2. 2. 设置git身份信息
    3. 3. 密码和凭证
      1. 3.1. 保存 Github 用户名和密码
      2. 3.2. SSH Key 凭证
    4. 4. 删除仓库
    5. 5. 恢复所有修改
      1. 5.1. 清除历史记录
    6. 6. 私人仓库
  • 文摘资源 -
  • - - - -

    部署以及更新

    -
      -
    • -

      初建:将文件夹设置为仓库。只是第一次需要,以后就基本不用。
      -git init

      -
    • -
    • -

      更新:更新所有的文件。
      -git add .

      -
    • -
    • -

      描述:更新描述(optional 不是必须的)
      -git commit -m "my command..."

      -
    • -
    • -

      推送:上传到云仓库
      -git push -u origin master

      -
    • -
    - -

    详细指令

    -
    1
    2
    3
    4
    5
    6
    7
    8
    git remote add origin https://github.com/maiernte/NewAngular.git

    git push -u origin master

    # For the next commit
    $ git add . # add to index only files created/modified and not those deleted
    $ git add -u # add to index only files deleted/modified and not those created
    $ git add -A # do both operation at once, add to index all files
    -

    下载及更新

    -
    1
    2
    3
    4
    5
    6
    7
    #下载整个项目
    git clone XXXXX
    #从服务器更新
    git pull [xxxxxx]
    #Help
    git hepl VERB
    git VERB -h
    -

    克隆指定 Branch, 因为有时候 master 和 gh-pages 上存放的是不同的文档。

    -
    1
    git clone https://github.com/maiernte/gitbook_python_finance.git --branch master new_fold
    -

    设置忽略文件夹以及文件

    -
    1
    2
    touch .gitignore
    vim .gitignore
    -

    并添加类似的行

    -
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    # See https://help.github.com/ignore-files/ for more about ignoring files.
    # dependencies
    /node_modules

    # testing
    /coverage
    # production
    /build
    # misc
    .DS_Store
    .env.local
    npm-debug.log*
    yarn-debug.log*
    -

    设置git身份信息

    -
    1
    2
    git config --global user.name "你的用户名"
    git config --global user.email "你的邮箱"
    -

    密码和凭证

    -

    保存 Github 用户名和密码

    -

    Mac 下面每次 push 都要询问用户名和密码,很麻烦。而且将来不利于用脚本控制部署。有个解决的办法:进入项目根目录,执行一下命令

    -
    1
    git config --global credential.helper store
    -

    然后推送一次,输入账号和密码后,第二次推送就不需要了!

    -

    SSH Key 凭证

    -
    1
    2
    # 加入 SSH Agent
    ssh-agent -s
    -

    如果出现类似Agent pid XXXX这样的字样,则跳过下一步,否则输入:

    -
    1
    eval `ssh-agent -s`
    -

    直到出现Agent pid XXXX这样的提示之后,输入:

    -
    1
    ssh-add ~/.ssh/id_rsa
    -

    这样,你成功的在本地生成了一个可用的SSH key。

    -

    下面将这个key添加到github网站。 打开https://github.com/settings/ssh,点击Add SSH Key,复制id_rsa.pub中的所有内容到Key框中,在Title框中输入方便自己记忆的名字(建议输入能让自己明白是哪台电脑的名字,方便以后管理)。 当网页显示添加成功后,就已经完成了全部的操作。 下面进行一些测试,同样是打开Git Bash,输入:

    -
    1
    ssh -T git@github.com
    -

    bash中会显示如下字样:

    -
    1
    2
    3
    The authenticity of host 'github.com (207.97.227.239)' can't be established.
    RSA key fingerprint is 16:27:ac:a5:76:28:2d:36:63:1b:56:4d:eb:df:a6:48.
    Are you sure you want to continue connecting (yes/no)?
    -

    输入yes之后,计算机会自动将github.com列入已知的host,然后会出现如下提示:

    -
    1
    2
    Hi username! You've successfully authenticated, but GitHub does not
    provide shell access.
    -

    如果成功看见,说明你已经配置好了,快去享受爽快的hexo一键部署吧; 如果出现任何错误提示,请仔细检查自己的操作,或者将错误信息发给我。

    -

    参阅:十步轻松搞定Hexo

    -

    如果要多台电脑共同使用同一个SSH-Key,先在第二台电脑上用这个key的相同邮件生成一个新的key

    -
    1
    ssh-keygen -t rsa -b 4096 -C "username@gmail.com"
    -

    用第一台电脑上的两个key文件 id_rsa, id_rsa.pub 覆盖第二台电脑的文件(注意备份)。确保NEW上的两个文件的权限是正确的,id_rsa是600,id_rsa.pub是644,比如:

    -
    1
    2
    3
    4
    5
    6
    7
    -rw------- 1 fancy fancy 1675 2013-03-19 12:55 id_rsa
    -rw-r--r-- 1 fancy fancy 406 2013-03-19 12:55 id_rsa.pub
    # 查看权限命令是
    ls -l
    # 更改权限命令是
    chmod 600 ~/.ssh/id_rsa
    chmod 644 ~/.ssh/id_rsa.pub
    -

    删除仓库

    -
      -
    1. 点开仓库
    2. -
    3. 点击右上角的 Settings
    4. -
    5. 滚动到最下面 Done Zone, 选择 Delete this repository
    6. -
    -

    恢复所有修改

    -
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    git checkout . #本地所有修改的。没有的提交的,都返回到原来的状态
    git stash #把所有没有提交的修改暂存到stash里面。可用git stash pop回复。
    git reset --hard HASH #返回到HASH点,不保留修改。
    git reset --soft HASH #同上,保留修改。HASH 是节点号,z.B. 7d593c5

    git clean -df #返回到某个节点
    git clean 参数
    -n 显示 将要 删除的 文件 和 目录
    -f 删除 文件
    -df 删除 文件 和 目录
    ---------------------
    git describe --always # 查看当前节点号
    git log # 查看所有HEAD号和Commit描述
    -

    更加暴力的方式是

    -
    1
    it checkout . && git clean -xdf
    -

    清除历史记录

    -
    代码
    -
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    1. Checkout
    git checkout --orphan latest_branch

    2. Add all the files
    git add -A

    3. Commit the changes
    git commit -am "commit message"

    4. Delete the branch
    git branch -D master

    5. Rename the current branch to master
    git branch -m master

    6. Finally, force update your repository

    git push -f origin master
    - -
    -

    私人仓库

    -

    作为个人笔记,不应该设为public,这样别人可以浏览。==2019== 年Github更新了新的政策

    -
    -

    GitHub Free:包含无限制的私人存储库。有了 GitHub Free,开发人员可以将 GitHub 用于私有项目,每个存储库最多可以有三个协作者。许多开发人员希望使用私人仓库申请工作,做一些 side project,或者在公开发布之前先私下尝试一些东西。从今天开始,这些场景在 GitHub 上可以免费实现(未来可能有更多场景)。 公共存储库仍然是免费的,并包括无限合作者。

    -
    -
      -
    1. 点开仓库
    2. -
    3. 点击右上角的 Settings
    4. -
    5. 滚动到最下面 Done Zone, 选择 Make this repository private
    6. -
    -

    文摘资源

    -

    Git submodule 子模块的管理和使用

    - -
    - -
    -
    -
    -
    - - - - - - - - - - - -
    -
    - -
    -
    - - - - - - - -
    -
    -
    -
    - -
    -
    - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - - - - \ No newline at end of file diff --git a/public/Editor-Skills-Summary.html b/public/Editor-Skills-Summary.html new file mode 100644 index 0000000..e69de29 diff --git a/public/TypeScript-build-JS-Package.html b/public/TypeScript-build-JS-Package.html new file mode 100644 index 0000000..e69de29 diff --git a/public/about-jianguoyu.html b/public/about-jianguoyu.html new file mode 100644 index 0000000..e69de29 diff --git a/public/about/index.html b/public/about/index.html new file mode 100644 index 0000000..e69de29 diff --git a/public/archives/2019/06/index.html b/public/archives/2019/06/index.html new file mode 100644 index 0000000..e69de29 diff --git a/public/archives/2019/07/index.html b/public/archives/2019/07/index.html new file mode 100644 index 0000000..e69de29 diff --git a/public/archives/2019/07/page/2/index.html b/public/archives/2019/07/page/2/index.html new file mode 100644 index 0000000..e69de29 diff --git a/public/archives/2019/07/page/3/index.html b/public/archives/2019/07/page/3/index.html new file mode 100644 index 0000000..e69de29 diff --git a/public/archives/2019/08/index.html b/public/archives/2019/08/index.html new file mode 100644 index 0000000..e69de29 diff --git a/public/archives/2019/09/index.html b/public/archives/2019/09/index.html new file mode 100644 index 0000000..e69de29 diff --git a/public/archives/2019/index.html b/public/archives/2019/index.html new file mode 100644 index 0000000..e69de29 diff --git a/public/archives/2019/page/2/index.html b/public/archives/2019/page/2/index.html new file mode 100644 index 0000000..e69de29 diff --git a/public/archives/2019/page/3/index.html b/public/archives/2019/page/3/index.html new file mode 100644 index 0000000..e69de29 diff --git a/public/archives/2019/page/4/index.html b/public/archives/2019/page/4/index.html new file mode 100644 index 0000000..e69de29 diff --git a/public/archives/2021/07/index.html b/public/archives/2021/07/index.html new file mode 100644 index 0000000..e69de29 diff --git a/public/archives/2021/index.html b/public/archives/2021/index.html new file mode 100644 index 0000000..e69de29 diff --git a/public/archives/index.html b/public/archives/index.html new file mode 100644 index 0000000..e69de29 diff --git a/public/archives/page/2/index.html b/public/archives/page/2/index.html new file mode 100644 index 0000000..e69de29 diff --git a/public/archives/page/3/index.html b/public/archives/page/3/index.html new file mode 100644 index 0000000..e69de29 diff --git a/public/archives/page/4/index.html b/public/archives/page/4/index.html new file mode 100644 index 0000000..e69de29 diff --git a/public/atom.xml b/public/atom.xml new file mode 100644 index 0000000..e69de29 diff --git a/public/brief-notions-collection.html b/public/brief-notions-collection.html new file mode 100644 index 0000000..e69de29 diff --git a/public/budahlisisch-poeim-collection.html b/public/budahlisisch-poeim-collection.html new file mode 100644 index 0000000..e69de29 diff --git a/public/categories/IT/Blog/index.html b/public/categories/IT/Blog/index.html new file mode 100644 index 0000000..e69de29 diff --git a/public/categories/IT/Code/index.html b/public/categories/IT/Code/index.html new file mode 100644 index 0000000..e69de29 diff --git a/public/categories/IT/Mac/index.html b/public/categories/IT/Mac/index.html new file mode 100644 index 0000000..e69de29 diff --git a/public/categories/IT/Tools/index.html b/public/categories/IT/Tools/index.html new file mode 100644 index 0000000..e69de29 diff --git a/public/categories/IT/Web/index.html b/public/categories/IT/Web/index.html new file mode 100644 index 0000000..e69de29 diff --git a/public/categories/IT/index.html b/public/categories/IT/index.html new file mode 100644 index 0000000..e69de29 diff --git a/public/categories/IT/page/2/index.html b/public/categories/IT/page/2/index.html new file mode 100644 index 0000000..e69de29 diff --git a/public/categories/IT/skill/index.html b/public/categories/IT/skill/index.html new file mode 100644 index 0000000..e69de29 diff --git a/public/categories/index.html b/public/categories/index.html new file mode 100644 index 0000000..e69de29 diff --git "a/public/categories/\345\270\270\347\224\250\346\226\207\344\273\266/index.html" "b/public/categories/\345\270\270\347\224\250\346\226\207\344\273\266/index.html" new file mode 100644 index 0000000..e69de29 diff --git "a/public/categories/\346\221\230\345\275\225/index.html" "b/public/categories/\346\221\230\345\275\225/index.html" new file mode 100644 index 0000000..e69de29 diff --git "a/public/categories/\346\221\230\345\275\225/\345\250\261\344\271\220/index.html" "b/public/categories/\346\221\230\345\275\225/\345\250\261\344\271\220/index.html" new file mode 100644 index 0000000..e69de29 diff --git "a/public/categories/\346\221\230\345\275\225/\347\211\207\346\256\265/index.html" "b/public/categories/\346\221\230\345\275\225/\347\211\207\346\256\265/index.html" new file mode 100644 index 0000000..e69de29 diff --git "a/public/categories/\346\226\207\346\241\243/index.html" "b/public/categories/\346\226\207\346\241\243/index.html" new file mode 100644 index 0000000..e69de29 diff --git "a/public/categories/\350\257\273\344\271\246\347\254\224\350\256\260/index.html" "b/public/categories/\350\257\273\344\271\246\347\254\224\350\256\260/index.html" new file mode 100644 index 0000000..e69de29 diff --git "a/public/categories/\351\232\217\347\254\224/index.html" "b/public/categories/\351\232\217\347\254\224/index.html" new file mode 100644 index 0000000..e69de29 diff --git a/public/config-mysql-access-privileges-on-vps.html b/public/config-mysql-access-privileges-on-vps.html new file mode 100644 index 0000000..e69de29 diff --git a/public/content.json b/public/content.json new file mode 100644 index 0000000..e69de29 diff --git a/public/css/blog-encrypt.css b/public/css/blog-encrypt.css new file mode 100644 index 0000000..e69de29 diff --git a/public/css/images/favicon.ico b/public/css/images/favicon.ico new file mode 100644 index 0000000..e69de29 diff --git a/public/css/images/logo.png b/public/css/images/logo.png new file mode 100644 index 0000000..e69de29 diff --git a/public/css/images/thumb-default-small.png b/public/css/images/thumb-default-small.png new file mode 100644 index 0000000..e69de29 diff --git a/public/css/style.css b/public/css/style.css new file mode 100644 index 0000000..e69de29 diff --git a/public/funny-sloga-collection.html b/public/funny-sloga-collection.html new file mode 100644 index 0000000..e69de29 diff --git a/public/funny-things-collection.html b/public/funny-things-collection.html new file mode 100644 index 0000000..e69de29 diff --git a/public/gitbook_with_typora_gh-pages.html b/public/gitbook_with_typora_gh-pages.html new file mode 100644 index 0000000..e69de29 diff --git a/public/hellow-world.html b/public/hellow-world.html new file mode 100644 index 0000000..e69de29 diff --git a/public/helpfull-shell-command.html b/public/helpfull-shell-command.html new file mode 100644 index 0000000..e69de29 diff --git a/public/hexo-blog-alltag-verwalten.html b/public/hexo-blog-alltag-verwalten.html new file mode 100644 index 0000000..e69de29 diff --git a/public/hexo-onlineeditor.html b/public/hexo-onlineeditor.html new file mode 100644 index 0000000..e69de29 diff --git a/public/how-build-my-hexo-blog.html b/public/how-build-my-hexo-blog.html new file mode 100644 index 0000000..e69de29 diff --git a/public/how-to-manage-big-hexo-blog.html b/public/how-to-manage-big-hexo-blog.html new file mode 100644 index 0000000..e69de29 diff --git a/public/images/SitePreview.png b/public/images/SitePreview.png new file mode 100644 index 0000000..e69de29 diff --git a/public/images/mobile1.png b/public/images/mobile1.png new file mode 100644 index 0000000..e69de29 diff --git a/public/images/mobile2.png b/public/images/mobile2.png new file mode 100644 index 0000000..e69de29 diff --git a/public/index.html b/public/index.html new file mode 100644 index 0000000..e69de29 diff --git a/public/javascript-typescript-skills.html b/public/javascript-typescript-skills.html new file mode 100644 index 0000000..e69de29 diff --git a/public/js/insight.js b/public/js/insight.js new file mode 100644 index 0000000..e69de29 diff --git a/public/js/main.js b/public/js/main.js new file mode 100644 index 0000000..e69de29 diff --git a/public/lalaland-film.html b/public/lalaland-film.html new file mode 100644 index 0000000..e69de29 diff --git a/public/lib/blog-encrypt.js b/public/lib/blog-encrypt.js new file mode 100644 index 0000000..e69de29 diff --git a/public/lib/crypto-js.js b/public/lib/crypto-js.js new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/font-awesome/css/font-awesome.css b/public/libs/font-awesome/css/font-awesome.css new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/font-awesome/css/font-awesome.min.css b/public/libs/font-awesome/css/font-awesome.min.css new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/font-awesome/fonts/FontAwesome.otf b/public/libs/font-awesome/fonts/FontAwesome.otf new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/font-awesome/fonts/fontawesome-webfont.eot b/public/libs/font-awesome/fonts/fontawesome-webfont.eot new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/font-awesome/fonts/fontawesome-webfont.svg b/public/libs/font-awesome/fonts/fontawesome-webfont.svg new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/font-awesome/fonts/fontawesome-webfont.ttf b/public/libs/font-awesome/fonts/fontawesome-webfont.ttf new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/font-awesome/fonts/fontawesome-webfont.woff b/public/libs/font-awesome/fonts/fontawesome-webfont.woff new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/font-awesome/fonts/fontawesome-webfont.woff2 b/public/libs/font-awesome/fonts/fontawesome-webfont.woff2 new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/fonts/glyphicons-halflings-regular.eot b/public/libs/fonts/glyphicons-halflings-regular.eot new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/fonts/glyphicons-halflings-regular.svg b/public/libs/fonts/glyphicons-halflings-regular.svg new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/fonts/glyphicons-halflings-regular.ttf b/public/libs/fonts/glyphicons-halflings-regular.ttf new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/fonts/glyphicons-halflings-regular.woff b/public/libs/fonts/glyphicons-halflings-regular.woff new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/fonts/glyphicons-halflings-regular.woff2 b/public/libs/fonts/glyphicons-halflings-regular.woff2 new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/jquery/2.1.3/jquery.min.js b/public/libs/jquery/2.1.3/jquery.min.js new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/jquery/plugins/cookie/1.4.1/jquery.cookie.js b/public/libs/jquery/plugins/cookie/1.4.1/jquery.cookie.js new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/justified-gallery/jquery.justifiedGallery.min.js b/public/libs/justified-gallery/jquery.justifiedGallery.min.js new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/justified-gallery/justifiedGallery.min.css b/public/libs/justified-gallery/justifiedGallery.min.css new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/lightgallery/css/lg-fb-comment-box.css b/public/libs/lightgallery/css/lg-fb-comment-box.css new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/lightgallery/css/lg-fb-comment-box.css.map b/public/libs/lightgallery/css/lg-fb-comment-box.css.map new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/lightgallery/css/lg-fb-comment-box.min.css b/public/libs/lightgallery/css/lg-fb-comment-box.min.css new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/lightgallery/css/lg-transitions.css b/public/libs/lightgallery/css/lg-transitions.css new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/lightgallery/css/lg-transitions.css.map b/public/libs/lightgallery/css/lg-transitions.css.map new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/lightgallery/css/lg-transitions.min.css b/public/libs/lightgallery/css/lg-transitions.min.css new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/lightgallery/css/lightgallery.css b/public/libs/lightgallery/css/lightgallery.css new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/lightgallery/css/lightgallery.css.map b/public/libs/lightgallery/css/lightgallery.css.map new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/lightgallery/css/lightgallery.min.css b/public/libs/lightgallery/css/lightgallery.min.css new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/lightgallery/fonts/lg.eot b/public/libs/lightgallery/fonts/lg.eot new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/lightgallery/fonts/lg.svg b/public/libs/lightgallery/fonts/lg.svg new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/lightgallery/fonts/lg.ttf b/public/libs/lightgallery/fonts/lg.ttf new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/lightgallery/fonts/lg.woff b/public/libs/lightgallery/fonts/lg.woff new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/lightgallery/img/loading.gif b/public/libs/lightgallery/img/loading.gif new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/lightgallery/img/video-play.png b/public/libs/lightgallery/img/video-play.png new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/lightgallery/img/vimeo-play.png b/public/libs/lightgallery/img/vimeo-play.png new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/lightgallery/img/youtube-play.png b/public/libs/lightgallery/img/youtube-play.png new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/lightgallery/js/lg-autoplay.js b/public/libs/lightgallery/js/lg-autoplay.js new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/lightgallery/js/lg-autoplay.min.js b/public/libs/lightgallery/js/lg-autoplay.min.js new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/lightgallery/js/lg-fullscreen.js b/public/libs/lightgallery/js/lg-fullscreen.js new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/lightgallery/js/lg-fullscreen.min.js b/public/libs/lightgallery/js/lg-fullscreen.min.js new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/lightgallery/js/lg-hash.js b/public/libs/lightgallery/js/lg-hash.js new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/lightgallery/js/lg-hash.min.js b/public/libs/lightgallery/js/lg-hash.min.js new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/lightgallery/js/lg-pager.js b/public/libs/lightgallery/js/lg-pager.js new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/lightgallery/js/lg-pager.min.js b/public/libs/lightgallery/js/lg-pager.min.js new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/lightgallery/js/lg-share.js b/public/libs/lightgallery/js/lg-share.js new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/lightgallery/js/lg-share.min.js b/public/libs/lightgallery/js/lg-share.min.js new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/lightgallery/js/lg-thumbnail.js b/public/libs/lightgallery/js/lg-thumbnail.js new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/lightgallery/js/lg-thumbnail.min.js b/public/libs/lightgallery/js/lg-thumbnail.min.js new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/lightgallery/js/lg-video.js b/public/libs/lightgallery/js/lg-video.js new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/lightgallery/js/lg-video.min.js b/public/libs/lightgallery/js/lg-video.min.js new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/lightgallery/js/lg-zoom.js b/public/libs/lightgallery/js/lg-zoom.js new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/lightgallery/js/lg-zoom.min.js b/public/libs/lightgallery/js/lg-zoom.min.js new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/lightgallery/js/lightgallery.js b/public/libs/lightgallery/js/lightgallery.js new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/lightgallery/js/lightgallery.min.js b/public/libs/lightgallery/js/lightgallery.min.js new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/open-sans/fonts/59ZRklaO5bWGqF5A9baEERJtnKITppOI_IvcXXDNrsc.woff2 b/public/libs/open-sans/fonts/59ZRklaO5bWGqF5A9baEERJtnKITppOI_IvcXXDNrsc.woff2 new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/open-sans/fonts/K88pR3goAWT7BTt32Z01mxJtnKITppOI_IvcXXDNrsc.woff2 b/public/libs/open-sans/fonts/K88pR3goAWT7BTt32Z01mxJtnKITppOI_IvcXXDNrsc.woff2 new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/open-sans/fonts/LWCjsQkB6EMdfHrEVqA1KRJtnKITppOI_IvcXXDNrsc.woff2 b/public/libs/open-sans/fonts/LWCjsQkB6EMdfHrEVqA1KRJtnKITppOI_IvcXXDNrsc.woff2 new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/open-sans/fonts/MTP_ySUJH_bn48VBG8sNShWV49_lSm1NYrwo-zkhivY.woff2 b/public/libs/open-sans/fonts/MTP_ySUJH_bn48VBG8sNShWV49_lSm1NYrwo-zkhivY.woff2 new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/open-sans/fonts/MTP_ySUJH_bn48VBG8sNSj0LW-43aMEzIO6XUTLjad8.woff2 b/public/libs/open-sans/fonts/MTP_ySUJH_bn48VBG8sNSj0LW-43aMEzIO6XUTLjad8.woff2 new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/open-sans/fonts/MTP_ySUJH_bn48VBG8sNSpX5f-9o1vgP2EXwfjgl7AY.woff2 b/public/libs/open-sans/fonts/MTP_ySUJH_bn48VBG8sNSpX5f-9o1vgP2EXwfjgl7AY.woff2 new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/open-sans/fonts/MTP_ySUJH_bn48VBG8sNSq-j2U0lmluP9RWlSytm3ho.woff2 b/public/libs/open-sans/fonts/MTP_ySUJH_bn48VBG8sNSq-j2U0lmluP9RWlSytm3ho.woff2 new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/open-sans/fonts/MTP_ySUJH_bn48VBG8sNSqaRobkAwv3vxw3jMhVENGA.woff2 b/public/libs/open-sans/fonts/MTP_ySUJH_bn48VBG8sNSqaRobkAwv3vxw3jMhVENGA.woff2 new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/open-sans/fonts/MTP_ySUJH_bn48VBG8sNSugdm0LZdjqr5-oayXSOefg.woff2 b/public/libs/open-sans/fonts/MTP_ySUJH_bn48VBG8sNSugdm0LZdjqr5-oayXSOefg.woff2 new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/open-sans/fonts/MTP_ySUJH_bn48VBG8sNSv8zf_FOSsgRmwsS7Aa9k2w.woff2 b/public/libs/open-sans/fonts/MTP_ySUJH_bn48VBG8sNSv8zf_FOSsgRmwsS7Aa9k2w.woff2 new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/open-sans/fonts/RjgO7rYTmqiVp7vzi-Q5URJtnKITppOI_IvcXXDNrsc.woff2 b/public/libs/open-sans/fonts/RjgO7rYTmqiVp7vzi-Q5URJtnKITppOI_IvcXXDNrsc.woff2 new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/open-sans/fonts/cJZKeOuBrn4kERxqtaUH3VtXRa8TVwTICgirnJhmVJw.woff2 b/public/libs/open-sans/fonts/cJZKeOuBrn4kERxqtaUH3VtXRa8TVwTICgirnJhmVJw.woff2 new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/open-sans/fonts/u-WUoqrET9fUeobQW7jkRRJtnKITppOI_IvcXXDNrsc.woff2 b/public/libs/open-sans/fonts/u-WUoqrET9fUeobQW7jkRRJtnKITppOI_IvcXXDNrsc.woff2 new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/open-sans/fonts/xjAJXh38I15wypJXxuGMBiYE0-AqJ3nfInTTiDXDjU4.woff2 b/public/libs/open-sans/fonts/xjAJXh38I15wypJXxuGMBiYE0-AqJ3nfInTTiDXDjU4.woff2 new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/open-sans/fonts/xjAJXh38I15wypJXxuGMBjTOQ_MqJVwkKsUn0wKzc2I.woff2 b/public/libs/open-sans/fonts/xjAJXh38I15wypJXxuGMBjTOQ_MqJVwkKsUn0wKzc2I.woff2 new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/open-sans/fonts/xjAJXh38I15wypJXxuGMBjUj_cnvWIuuBMVgbX098Mw.woff2 b/public/libs/open-sans/fonts/xjAJXh38I15wypJXxuGMBjUj_cnvWIuuBMVgbX098Mw.woff2 new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/open-sans/fonts/xjAJXh38I15wypJXxuGMBkbcKLIaa1LC45dFaAfauRA.woff2 b/public/libs/open-sans/fonts/xjAJXh38I15wypJXxuGMBkbcKLIaa1LC45dFaAfauRA.woff2 new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/open-sans/fonts/xjAJXh38I15wypJXxuGMBmo_sUJ8uO4YLWRInS22T3Y.woff2 b/public/libs/open-sans/fonts/xjAJXh38I15wypJXxuGMBmo_sUJ8uO4YLWRInS22T3Y.woff2 new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/open-sans/fonts/xjAJXh38I15wypJXxuGMBo4P5ICox8Kq3LLUNMylGO4.woff2 b/public/libs/open-sans/fonts/xjAJXh38I15wypJXxuGMBo4P5ICox8Kq3LLUNMylGO4.woff2 new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/open-sans/fonts/xjAJXh38I15wypJXxuGMBr6up8jxqWt8HVA3mDhkV_0.woff2 b/public/libs/open-sans/fonts/xjAJXh38I15wypJXxuGMBr6up8jxqWt8HVA3mDhkV_0.woff2 new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/open-sans/fonts/xozscpT2726on7jbcb_pAhJtnKITppOI_IvcXXDNrsc.woff2 b/public/libs/open-sans/fonts/xozscpT2726on7jbcb_pAhJtnKITppOI_IvcXXDNrsc.woff2 new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/open-sans/styles.css b/public/libs/open-sans/styles.css new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/source-code-pro/fonts/mrl8jkM18OlOQN8JLgasD9V_2ngZ8dMf8fLgjYEouxg.woff2 b/public/libs/source-code-pro/fonts/mrl8jkM18OlOQN8JLgasD9V_2ngZ8dMf8fLgjYEouxg.woff2 new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/source-code-pro/fonts/mrl8jkM18OlOQN8JLgasDy2Q8seG17bfDXYR_jUsrzg.woff2 b/public/libs/source-code-pro/fonts/mrl8jkM18OlOQN8JLgasDy2Q8seG17bfDXYR_jUsrzg.woff2 new file mode 100644 index 0000000..e69de29 diff --git a/public/libs/source-code-pro/styles.css b/public/libs/source-code-pro/styles.css new file mode 100644 index 0000000..e69de29 diff --git a/public/lvdeshui-film.html b/public/lvdeshui-film.html new file mode 100644 index 0000000..e69de29 diff --git a/public/mac-memo.html b/public/mac-memo.html new file mode 100644 index 0000000..e69de29 diff --git a/public/mac-using-tags.html b/public/mac-using-tags.html new file mode 100644 index 0000000..e69de29 diff --git a/public/mathjax-yixue-usage.html b/public/mathjax-yixue-usage.html new file mode 100644 index 0000000..e69de29 diff --git a/public/next-collapse-block.html b/public/next-collapse-block.html new file mode 100644 index 0000000..e69de29 diff --git a/public/old-stories-collection.html b/public/old-stories-collection.html new file mode 100644 index 0000000..e69de29 diff --git a/public/page/2/index.html b/public/page/2/index.html new file mode 100644 index 0000000..e69de29 diff --git a/public/page/3/index.html b/public/page/3/index.html new file mode 100644 index 0000000..e69de29 diff --git a/public/page/4/index.html b/public/page/4/index.html new file mode 100644 index 0000000..e69de29 diff --git a/public/prominaent-slogen-collection.html b/public/prominaent-slogen-collection.html new file mode 100644 index 0000000..e69de29 diff --git a/public/road-less-traveled-summary.html b/public/road-less-traveled-summary.html new file mode 100644 index 0000000..e69de29 diff --git a/public/road-to-asset-freedom.html b/public/road-to-asset-freedom.html new file mode 100644 index 0000000..e69de29 diff --git a/public/rzf-organisation.html b/public/rzf-organisation.html new file mode 100644 index 0000000..e69de29 diff --git a/public/search.xml b/public/search.xml new file mode 100644 index 0000000..e69de29 diff --git a/public/sitemap.xml b/public/sitemap.xml new file mode 100644 index 0000000..e69de29 diff --git a/public/still-using-qiniu.html b/public/still-using-qiniu.html new file mode 100644 index 0000000..e69de29 diff --git a/public/storic-summary.html b/public/storic-summary.html new file mode 100644 index 0000000..e69de29 diff --git a/public/synchron-the-tag-and-categories-btw-pc-hexo.html b/public/synchron-the-tag-and-categories-btw-pc-hexo.html new file mode 100644 index 0000000..e69de29 diff --git a/public/tags/Hexo/index.html b/public/tags/Hexo/index.html new file mode 100644 index 0000000..e69de29 diff --git a/public/tags/Mac/index.html b/public/tags/Mac/index.html new file mode 100644 index 0000000..e69de29 diff --git a/public/tags/index.html b/public/tags/index.html new file mode 100644 index 0000000..e69de29 diff --git "a/public/tags/\344\271\246\347\261\215/index.html" "b/public/tags/\344\271\246\347\261\215/index.html" new file mode 100644 index 0000000..e69de29 diff --git "a/public/tags/\345\216\206\345\217\262\346\224\277\346\262\273/index.html" "b/public/tags/\345\216\206\345\217\262\346\224\277\346\262\273/index.html" new file mode 100644 index 0000000..e69de29 diff --git "a/public/tags/\345\223\262\347\220\206/index.html" "b/public/tags/\345\223\262\347\220\206/index.html" new file mode 100644 index 0000000..e69de29 diff --git "a/public/tags/\345\250\261\344\271\220/index.html" "b/public/tags/\345\250\261\344\271\220/index.html" new file mode 100644 index 0000000..e69de29 diff --git "a/public/tags/\345\267\245\344\275\234/index.html" "b/public/tags/\345\267\245\344\275\234/index.html" new file mode 100644 index 0000000..e69de29 diff --git "a/public/tags/\345\267\245\345\205\267/index.html" "b/public/tags/\345\267\245\345\205\267/index.html" new file mode 100644 index 0000000..e69de29 diff --git "a/public/tags/\345\275\261\350\247\206/index.html" "b/public/tags/\345\275\261\350\247\206/index.html" new file mode 100644 index 0000000..e69de29 diff --git "a/public/tags/\345\277\203\347\220\206/index.html" "b/public/tags/\345\277\203\347\220\206/index.html" new file mode 100644 index 0000000..e69de29 diff --git "a/public/tags/\346\210\220\351\225\277/index.html" "b/public/tags/\346\210\220\351\225\277/index.html" new file mode 100644 index 0000000..e69de29 diff --git "a/public/tags/\346\226\207\345\255\246/index.html" "b/public/tags/\346\226\207\345\255\246/index.html" new file mode 100644 index 0000000..e69de29 diff --git "a/public/tags/\347\273\217\346\265\216/index.html" "b/public/tags/\347\273\217\346\265\216/index.html" new file mode 100644 index 0000000..e69de29 diff --git a/public/ubuntu-reset-root-pw.html b/public/ubuntu-reset-root-pw.html new file mode 100644 index 0000000..e69de29 diff --git a/public/uploads/road-to-asset-freedom-mindmap.html b/public/uploads/road-to-asset-freedom-mindmap.html new file mode 100644 index 0000000..e69de29 diff --git a/public/uploads/tianya.png b/public/uploads/tianya.png new file mode 100644 index 0000000..e69de29 diff --git a/public/use-github-in-wiki.html b/public/use-github-in-wiki.html new file mode 100644 index 0000000..e69de29