mirror of
https://github.com/KieSun/all-of-frontend.git
synced 2024-11-25 08:18:14 +08:00
feat: 类型判断
This commit is contained in:
parent
0d997a8490
commit
02356af755
3
.obsidian/app.json
vendored
Normal file
3
.obsidian/app.json
vendored
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
{
|
||||||
|
"spellcheck": true
|
||||||
|
}
|
6
.obsidian/appearance.json
vendored
Normal file
6
.obsidian/appearance.json
vendored
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
{
|
||||||
|
"baseFontSize": 16,
|
||||||
|
"translucency": false,
|
||||||
|
"cssTheme": "Yin and Yang",
|
||||||
|
"theme": "obsidian"
|
||||||
|
}
|
5
.obsidian/community-plugins.json
vendored
Normal file
5
.obsidian/community-plugins.json
vendored
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
[
|
||||||
|
"oz-image-plugin",
|
||||||
|
"cm-editor-syntax-highlight-obsidian",
|
||||||
|
"url-into-selection"
|
||||||
|
]
|
14
.obsidian/core-plugins.json
vendored
Normal file
14
.obsidian/core-plugins.json
vendored
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
[
|
||||||
|
"file-explorer",
|
||||||
|
"global-search",
|
||||||
|
"switcher",
|
||||||
|
"graph",
|
||||||
|
"backlink",
|
||||||
|
"page-preview",
|
||||||
|
"note-composer",
|
||||||
|
"command-palette",
|
||||||
|
"markdown-importer",
|
||||||
|
"word-count",
|
||||||
|
"open-with-default-app",
|
||||||
|
"file-recovery"
|
||||||
|
]
|
1
.obsidian/hotkeys.json
vendored
Normal file
1
.obsidian/hotkeys.json
vendored
Normal file
@ -0,0 +1 @@
|
|||||||
|
{}
|
30272
.obsidian/plugins/cm-editor-syntax-highlight-obsidian/main.js
vendored
Normal file
30272
.obsidian/plugins/cm-editor-syntax-highlight-obsidian/main.js
vendored
Normal file
File diff suppressed because one or more lines are too long
10
.obsidian/plugins/cm-editor-syntax-highlight-obsidian/manifest.json
vendored
Normal file
10
.obsidian/plugins/cm-editor-syntax-highlight-obsidian/manifest.json
vendored
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
{
|
||||||
|
"id": "cm-editor-syntax-highlight-obsidian",
|
||||||
|
"name": "Editor Syntax Highlight",
|
||||||
|
"author": "death_au",
|
||||||
|
"authorUrl": "https://github.com/deathau",
|
||||||
|
"description": "Show syntax highlighing in code blocks the editor",
|
||||||
|
"isDesktopOnly": false,
|
||||||
|
"version": "0.1.2",
|
||||||
|
"minAppVersion": "0.10.0"
|
||||||
|
}
|
177
.obsidian/plugins/cm-editor-syntax-highlight-obsidian/styles.css
vendored
Normal file
177
.obsidian/plugins/cm-editor-syntax-highlight-obsidian/styles.css
vendored
Normal file
@ -0,0 +1,177 @@
|
|||||||
|
@charset "UTF-8";
|
||||||
|
.cm-s-obsidian pre.HyperMD-codeblock span.cm-formatting-code-block {
|
||||||
|
color: var(--text-muted);
|
||||||
|
}
|
||||||
|
|
||||||
|
.cm-s-obsidian pre.HyperMD-codeblock .cm-keyword {
|
||||||
|
font-weight: normal;
|
||||||
|
}
|
||||||
|
|
||||||
|
.theme-dark .cm-s-obsidian {
|
||||||
|
/*
|
||||||
|
|
||||||
|
Name: yoncé
|
||||||
|
Author: Thomas MacLean (http://github.com/thomasmaclean)
|
||||||
|
|
||||||
|
Original yoncé color scheme by Mina Markham (https://github.com/minamarkham)
|
||||||
|
|
||||||
|
*/
|
||||||
|
/**/
|
||||||
|
}
|
||||||
|
.theme-dark .cm-s-obsidian .cm-hmd-frontmatter,
|
||||||
|
.theme-dark .cm-s-obsidian pre.HyperMD-codeblock {
|
||||||
|
color: #d4d4d4;
|
||||||
|
}
|
||||||
|
.theme-dark .cm-s-obsidian .cm-hmd-frontmatter.cm-keyword,
|
||||||
|
.theme-dark .cm-s-obsidian .cm-math.cm-keyword,
|
||||||
|
.theme-dark .cm-s-obsidian pre.HyperMD-codeblock .cm-keyword {
|
||||||
|
color: #00A7AA;
|
||||||
|
font-weight: normal;
|
||||||
|
}
|
||||||
|
.theme-dark .cm-s-obsidian .cm-hmd-frontmatter.cm-atom,
|
||||||
|
.theme-dark .cm-s-obsidian .cm-math.cm-atom,
|
||||||
|
.theme-dark .cm-s-obsidian pre.HyperMD-codeblock .cm-atom {
|
||||||
|
color: #F39B35;
|
||||||
|
}
|
||||||
|
.theme-dark .cm-s-obsidian .cm-hmd-frontmatter.cm-number,
|
||||||
|
.theme-dark .cm-s-obsidian .cm-math.cm-number,
|
||||||
|
.theme-dark .cm-s-obsidian pre.HyperMD-codeblock .cm-number {
|
||||||
|
color: #A06FCA;
|
||||||
|
}
|
||||||
|
.theme-dark .cm-s-obsidian span.cm-hmd-frontmatter.cm-type,
|
||||||
|
.theme-dark .cm-s-obsidian span.cm-math.cm-type,
|
||||||
|
.theme-dark .cm-s-obsidian pre.HyperMD-codeblock span.cm-type {
|
||||||
|
color: #A06FCA;
|
||||||
|
}
|
||||||
|
.theme-dark .cm-s-obsidian .cm-hmd-frontmatter.cm-def,
|
||||||
|
.theme-dark .cm-s-obsidian .cm-math.cm-def,
|
||||||
|
.theme-dark .cm-s-obsidian pre.HyperMD-codeblock .cm-def {
|
||||||
|
color: #98E342;
|
||||||
|
}
|
||||||
|
.theme-dark .cm-s-obsidian .cm-hmd-frontmatter.cm-property,
|
||||||
|
.theme-dark .cm-s-obsidian .cm-math.cm-property,
|
||||||
|
.theme-dark .cm-s-obsidian pre.HyperMD-codeblock .cm-property {
|
||||||
|
color: #D4D4D4;
|
||||||
|
}
|
||||||
|
.theme-dark .cm-s-obsidian span.cm-hmd-frontmatter.cm-variable,
|
||||||
|
.theme-dark .cm-s-obsidian span.cm-math.cm-variable,
|
||||||
|
.theme-dark .cm-s-obsidian pre.HyperMD-codeblock span.cm-variable {
|
||||||
|
color: #D4D4D4;
|
||||||
|
}
|
||||||
|
.theme-dark .cm-s-obsidian span.cm-hmd-frontmatter.cm-variable-2,
|
||||||
|
.theme-dark .cm-s-obsidian span.cm-math.cm-variable-2,
|
||||||
|
.theme-dark .cm-s-obsidian pre.HyperMD-codeblock span.cm-variable-2 {
|
||||||
|
color: #da7dae;
|
||||||
|
}
|
||||||
|
.theme-dark .cm-s-obsidian span.cm-hmd-frontmatter.cm-variable-3,
|
||||||
|
.theme-dark .cm-s-obsidian span.cm-math.cm-variable-3,
|
||||||
|
.theme-dark .cm-s-obsidian pre.HyperMD-codeblock span.cm-variable-3 {
|
||||||
|
color: #A06FCA;
|
||||||
|
}
|
||||||
|
.theme-dark .cm-s-obsidian .cm-hmd-frontmatter.cm-type.cm-def,
|
||||||
|
.theme-dark .cm-s-obsidian .cm-math.cm-type.cm-def,
|
||||||
|
.theme-dark .cm-s-obsidian pre.HyperMD-codeblock .cm-type.cm-def {
|
||||||
|
color: #FC4384;
|
||||||
|
}
|
||||||
|
.theme-dark .cm-s-obsidian .cm-hmd-frontmatter.cm-property.cm-def,
|
||||||
|
.theme-dark .cm-s-obsidian .cm-math.cm-property.cm-def,
|
||||||
|
.theme-dark .cm-s-obsidian pre.HyperMD-codeblock .cm-property.cm-def {
|
||||||
|
color: #FC4384;
|
||||||
|
}
|
||||||
|
.theme-dark .cm-s-obsidian .cm-hmd-frontmatter.cm-callee,
|
||||||
|
.theme-dark .cm-s-obsidian .cm-math.cm-callee,
|
||||||
|
.theme-dark .cm-s-obsidian pre.HyperMD-codeblock .cm-callee {
|
||||||
|
color: #FC4384;
|
||||||
|
}
|
||||||
|
.theme-dark .cm-s-obsidian .cm-hmd-frontmatter.cm-operator,
|
||||||
|
.theme-dark .cm-s-obsidian .cm-math.cm-operator,
|
||||||
|
.theme-dark .cm-s-obsidian pre.HyperMD-codeblock .cm-operator {
|
||||||
|
color: #FC4384;
|
||||||
|
}
|
||||||
|
.theme-dark .cm-s-obsidian .cm-hmd-frontmatter.cm-qualifier,
|
||||||
|
.theme-dark .cm-s-obsidian .cm-math.cm-qualifier,
|
||||||
|
.theme-dark .cm-s-obsidian pre.HyperMD-codeblock .cm-qualifier {
|
||||||
|
color: #FC4384;
|
||||||
|
}
|
||||||
|
.theme-dark .cm-s-obsidian .cm-hmd-frontmatter.cm-tag,
|
||||||
|
.theme-dark .cm-s-obsidian .cm-math.cm-tag,
|
||||||
|
.theme-dark .cm-s-obsidian pre.HyperMD-codeblock .cm-tag {
|
||||||
|
color: #FC4384;
|
||||||
|
}
|
||||||
|
.theme-dark .cm-s-obsidian .cm-hmd-frontmatter.cm-tag.cm-bracket,
|
||||||
|
.theme-dark .cm-s-obsidian .cm-math.cm-tag.cm-bracket,
|
||||||
|
.theme-dark .cm-s-obsidian pre.HyperMD-codeblock .cm-tag.cm-bracket {
|
||||||
|
color: #D4D4D4;
|
||||||
|
}
|
||||||
|
.theme-dark .cm-s-obsidian .cm-hmd-frontmatter.cm-attribute,
|
||||||
|
.theme-dark .cm-s-obsidian .cm-math.cm-attribute,
|
||||||
|
.theme-dark .cm-s-obsidian pre.HyperMD-codeblock .cm-attribute {
|
||||||
|
color: #A06FCA;
|
||||||
|
}
|
||||||
|
.theme-dark .cm-s-obsidian .cm-hmd-frontmatter.cm-comment,
|
||||||
|
.theme-dark .cm-s-obsidian .cm-math.cm-comment,
|
||||||
|
.theme-dark .cm-s-obsidian pre.HyperMD-codeblock .cm-comment {
|
||||||
|
color: #696d70;
|
||||||
|
}
|
||||||
|
.theme-dark .cm-s-obsidian .cm-hmd-frontmatter.cm-comment.cm-tag,
|
||||||
|
.theme-dark .cm-s-obsidian .cm-math.cm-comment.cm-tag,
|
||||||
|
.theme-dark .cm-s-obsidian pre.HyperMD-codeblock .cm-comment.cm-tag {
|
||||||
|
color: #FC4384;
|
||||||
|
}
|
||||||
|
.theme-dark .cm-s-obsidian .cm-hmd-frontmatter.cm-comment.cm-attribute,
|
||||||
|
.theme-dark .cm-s-obsidian .cm-math.cm-comment.cm-attribute,
|
||||||
|
.theme-dark .cm-s-obsidian pre.HyperMD-codeblock .cm-comment.cm-attribute {
|
||||||
|
color: #D4D4D4;
|
||||||
|
}
|
||||||
|
.theme-dark .cm-s-obsidian .cm-hmd-frontmatter.cm-string,
|
||||||
|
.theme-dark .cm-s-obsidian .cm-math.cm-string,
|
||||||
|
.theme-dark .cm-s-obsidian pre.HyperMD-codeblock .cm-string {
|
||||||
|
color: #E6DB74;
|
||||||
|
}
|
||||||
|
.theme-dark .cm-s-obsidian .cm-hmd-frontmatter.cm-string-2,
|
||||||
|
.theme-dark .cm-s-obsidian .cm-math.cm-string-2,
|
||||||
|
.theme-dark .cm-s-obsidian pre.HyperMD-codeblock .cm-string-2 {
|
||||||
|
color: #F39B35;
|
||||||
|
}
|
||||||
|
.theme-dark .cm-s-obsidian .cm-hmd-frontmatter.cm-meta,
|
||||||
|
.theme-dark .cm-s-obsidian .cm-math.cm-meta,
|
||||||
|
.theme-dark .cm-s-obsidian pre.HyperMD-codeblock .cm-meta {
|
||||||
|
color: #D4D4D4;
|
||||||
|
background: inherit;
|
||||||
|
}
|
||||||
|
.theme-dark .cm-s-obsidian .cm-hmd-frontmatter.cm-builtin,
|
||||||
|
.theme-dark .cm-s-obsidian .cm-math.cm-builtin,
|
||||||
|
.theme-dark .cm-s-obsidian pre.HyperMD-codeblock .cm-builtin {
|
||||||
|
color: #FC4384;
|
||||||
|
}
|
||||||
|
.theme-dark .cm-s-obsidian .cm-hmd-frontmatter.cm-header,
|
||||||
|
.theme-dark .cm-s-obsidian .cm-math.cm-header,
|
||||||
|
.theme-dark .cm-s-obsidian pre.HyperMD-codeblock .cm-header {
|
||||||
|
color: #da7dae;
|
||||||
|
}
|
||||||
|
.theme-dark .cm-s-obsidian .cm-hmd-frontmatter.cm-hr,
|
||||||
|
.theme-dark .cm-s-obsidian .cm-math.cm-hr,
|
||||||
|
.theme-dark .cm-s-obsidian pre.HyperMD-codeblock .cm-hr {
|
||||||
|
color: #98E342;
|
||||||
|
}
|
||||||
|
.theme-dark .cm-s-obsidian .cm-hmd-frontmatter.cm-link,
|
||||||
|
.theme-dark .cm-s-obsidian .cm-math.cm-link,
|
||||||
|
.theme-dark .cm-s-obsidian pre.HyperMD-codeblock .cm-link {
|
||||||
|
color: #696d70;
|
||||||
|
}
|
||||||
|
.theme-dark .cm-s-obsidian .cm-hmd-frontmatter.cm-error,
|
||||||
|
.theme-dark .cm-s-obsidian .cm-math.cm-error,
|
||||||
|
.theme-dark .cm-s-obsidian pre.HyperMD-codeblock .cm-error {
|
||||||
|
border-bottom: 1px solid #C42412;
|
||||||
|
}
|
||||||
|
.theme-dark .cm-s-obsidian .cm-hmd-frontmatter.CodeMirror-activeline-background,
|
||||||
|
.theme-dark .cm-s-obsidian .cm-math.CodeMirror-activeline-background,
|
||||||
|
.theme-dark .cm-s-obsidian pre.HyperMD-codeblock .CodeMirror-activeline-background {
|
||||||
|
background: #272727;
|
||||||
|
}
|
||||||
|
.theme-dark .cm-s-obsidian .cm-hmd-frontmatter.CodeMirror-matchingbracket,
|
||||||
|
.theme-dark .cm-s-obsidian .cm-math.CodeMirror-matchingbracket,
|
||||||
|
.theme-dark .cm-s-obsidian pre.HyperMD-codeblock .CodeMirror-matchingbracket {
|
||||||
|
outline: 1px solid grey;
|
||||||
|
color: #D4D4D4 !important;
|
||||||
|
}
|
8
.obsidian/plugins/oz-image-plugin/data.json
vendored
Normal file
8
.obsidian/plugins/oz-image-plugin/data.json
vendored
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
{
|
||||||
|
"renderAll": true,
|
||||||
|
"renderPDF": false,
|
||||||
|
"renderIframe": false,
|
||||||
|
"renderExcalidraw": false,
|
||||||
|
"refreshImagesAfterChange": false,
|
||||||
|
"WYSIWYG": true
|
||||||
|
}
|
829
.obsidian/plugins/oz-image-plugin/main.js
vendored
Normal file
829
.obsidian/plugins/oz-image-plugin/main.js
vendored
Normal file
File diff suppressed because one or more lines are too long
10
.obsidian/plugins/oz-image-plugin/manifest.json
vendored
Normal file
10
.obsidian/plugins/oz-image-plugin/manifest.json
vendored
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
{
|
||||||
|
"id": "oz-image-plugin",
|
||||||
|
"name": "Ozan's Image in Editor Plugin",
|
||||||
|
"version": "1.3.0",
|
||||||
|
"minAppVersion": "0.12.3",
|
||||||
|
"description": "You can view images inside of the Editor as soon as you paste without a necessity to preview the note.",
|
||||||
|
"author": "Ozan Tellioglu",
|
||||||
|
"authorUrl": "https://ozan.pl/aboutme/",
|
||||||
|
"isDesktopOnly": true
|
||||||
|
}
|
29
.obsidian/plugins/oz-image-plugin/styles.css
vendored
Normal file
29
.obsidian/plugins/oz-image-plugin/styles.css
vendored
Normal file
@ -0,0 +1,29 @@
|
|||||||
|
div.oz-image-widget > img {
|
||||||
|
max-width: 100%;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.oz-image-widget > img[alt$='#small'] {
|
||||||
|
max-width: 75% !important;
|
||||||
|
min-width: 200pt !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.oz-image-widget > img[alt$='#x-small'] {
|
||||||
|
max-width: 50% !important;
|
||||||
|
min-width: 100pt !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.oz-image-widget > img[alt$='#xx-small'] {
|
||||||
|
max-width: 25% !important;
|
||||||
|
min-width: 50pt !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.CodeMirror-linewidget > img {
|
||||||
|
margin-top: 5px !important;
|
||||||
|
margin-bottom: 5px !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.theme-dark img[alt$='#invert'],
|
||||||
|
.theme-dark div.oz-image-widget > img[alt$='#invert'] {
|
||||||
|
filter: invert(1) hue-rotate(180deg);
|
||||||
|
mix-blend-mode: screen;
|
||||||
|
}
|
721
.obsidian/plugins/url-into-selection/main.js
vendored
Normal file
721
.obsidian/plugins/url-into-selection/main.js
vendored
Normal file
File diff suppressed because one or more lines are too long
8
.obsidian/plugins/url-into-selection/manifest.json
vendored
Normal file
8
.obsidian/plugins/url-into-selection/manifest.json
vendored
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
{
|
||||||
|
"id": "url-into-selection",
|
||||||
|
"name": "Paste URL into selection",
|
||||||
|
"description": "Paste URL \"into\" selected text.",
|
||||||
|
"isDesktopOnly": false,
|
||||||
|
"js": "main.js",
|
||||||
|
"version": "1.6.0"
|
||||||
|
}
|
472
.obsidian/themes/Atom.css
vendored
Normal file
472
.obsidian/themes/Atom.css
vendored
Normal file
@ -0,0 +1,472 @@
|
|||||||
|
.theme-dark {
|
||||||
|
--background-primary: #272b34;
|
||||||
|
--background-primary-alt: #20242b;
|
||||||
|
--background-secondary: #20242b;
|
||||||
|
--background-secondary-alt: #1a1e24;
|
||||||
|
--background-accent: #000;
|
||||||
|
--background-modifier-border: #424958;
|
||||||
|
--background-modifier-form-field: rgba(0, 0, 0, 0.3);
|
||||||
|
--background-modifier-form-field-highlighted: rgba(0, 0, 0, 0.22);
|
||||||
|
--background-modifier-box-shadow: rgba(0, 0, 0, 0.3);
|
||||||
|
--background-modifier-success: #539126;
|
||||||
|
--background-modifier-error: #3d0000;
|
||||||
|
--background-modifier-error-rgb: 61, 0, 0;
|
||||||
|
--background-modifier-error-hover: #470000;
|
||||||
|
--background-modifier-cover: rgba(0, 0, 0, 0.6);
|
||||||
|
--text-accent: #61afef;
|
||||||
|
--text-accent-hover: #69bafd;
|
||||||
|
--text-normal: #dcddde;
|
||||||
|
--text-muted: #888;
|
||||||
|
--text-faint: rgb(81, 86, 99);
|
||||||
|
--text-error: #e16d76;
|
||||||
|
--text-error-hover: #c9626a;
|
||||||
|
--text-highlight-bg: rgba(255, 255, 0, 0.4);
|
||||||
|
--text-selection: rgba(0, 122, 255, 0.2);
|
||||||
|
--text-on-accent: #dcddde;
|
||||||
|
--interactive-normal: #20242b;
|
||||||
|
--interactive-hover: #353b47;
|
||||||
|
--interactive-accent: #4c78cc;
|
||||||
|
--interactive-accent-rgb: 76, 120, 204;
|
||||||
|
--interactive-accent-hover: #5082df;
|
||||||
|
--scrollbar-active-thumb-bg: rgba(255, 255, 255, 0.2);
|
||||||
|
--scrollbar-bg: rgba(255, 255, 255, 0.05);
|
||||||
|
--scrollbar-thumb-bg: rgba(255, 255, 255, 0.1);
|
||||||
|
--panel-border-color: #18191e;
|
||||||
|
--gray-1: #5C6370;
|
||||||
|
--gray-2: #abb2bf;
|
||||||
|
--red: #e06c75;
|
||||||
|
--orange: #d19a66;
|
||||||
|
--green: #98c379;
|
||||||
|
--aqua: #56b6c2;
|
||||||
|
--purple: #c678dd;
|
||||||
|
--blue: #61afef;
|
||||||
|
--yellow: #e5c07b;
|
||||||
|
}
|
||||||
|
|
||||||
|
.theme-light {
|
||||||
|
--background-primary: #fafafa;
|
||||||
|
--background-primary-alt: #eaeaeb;
|
||||||
|
--background-secondary: #eaeaeb;
|
||||||
|
--background-secondary-alt: #dbdbdc;
|
||||||
|
--background-accent: #fff;
|
||||||
|
--background-modifier-border: #dbdbdc;
|
||||||
|
--background-modifier-form-field: #fff;
|
||||||
|
--background-modifier-form-field-highlighted: #fff;
|
||||||
|
--background-modifier-box-shadow: rgba(0, 0, 0, 0.1);
|
||||||
|
--background-modifier-success: #A4E7C3;
|
||||||
|
--background-modifier-error: #e68787;
|
||||||
|
--background-modifier-error-rgb: 230, 135, 135;
|
||||||
|
--background-modifier-error-hover: #FF9494;
|
||||||
|
--background-modifier-cover: rgba(0, 0, 0, 0.8);
|
||||||
|
--text-accent: #1592ff;
|
||||||
|
--text-accent-hover: #2d9dff;
|
||||||
|
--text-normal: #383a42;
|
||||||
|
--text-muted: #8e8e90;
|
||||||
|
--text-faint: #999999;
|
||||||
|
--text-error: #e75545;
|
||||||
|
--text-error-hover: #f86959;
|
||||||
|
--text-highlight-bg: rgba(255, 255, 0, 0.4);
|
||||||
|
--text-selection: rgba(0, 122, 255, 0.15);
|
||||||
|
--text-on-accent: #f2f2f2;
|
||||||
|
--interactive-normal: #eaeaeb;
|
||||||
|
--interactive-hover: #dbdbdc;
|
||||||
|
--interactive-accent-rgb: 21, 146, 255;
|
||||||
|
--interactive-accent: #5871ef;
|
||||||
|
--interactive-accent-hover: #445bd1;
|
||||||
|
--scrollbar-active-thumb-bg: rgba(0, 0, 0, 0.2);
|
||||||
|
--scrollbar-bg: rgba(0, 0, 0, 0.05);
|
||||||
|
--scrollbar-thumb-bg: rgba(0, 0, 0, 0.1);
|
||||||
|
--panel-border-color: #dbdbdc;
|
||||||
|
--gray-1: #383a42;
|
||||||
|
--gray-2: #383a42;
|
||||||
|
--red: #e75545;
|
||||||
|
--green: #4ea24c;
|
||||||
|
--blue: #3d74f6;
|
||||||
|
--purple: #a625a4;
|
||||||
|
--aqua: #0084bc;
|
||||||
|
--yellow: #e35649;
|
||||||
|
--orange: #986800;
|
||||||
|
}
|
||||||
|
|
||||||
|
body {
|
||||||
|
-webkit-font-smoothing: auto;
|
||||||
|
}
|
||||||
|
|
||||||
|
.titlebar {
|
||||||
|
background-color: var(--background-secondary-alt);
|
||||||
|
}
|
||||||
|
|
||||||
|
.titlebar-inner {
|
||||||
|
color: var(--text-normal);
|
||||||
|
}
|
||||||
|
|
||||||
|
.tooltip {
|
||||||
|
background-color: var(--background-secondary-alt);
|
||||||
|
color: var(--text-muted);
|
||||||
|
}
|
||||||
|
|
||||||
|
.tooltip:not(.mod-right):not(.mod-left):not(.mod-top) .tooltip-arrow {
|
||||||
|
border-bottom-color: var(--background-secondary-alt) !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.mod-right .tooltip-arrow {
|
||||||
|
border-right-color: var(--background-secondary-alt) !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.mod-left .tooltip-arrow {
|
||||||
|
border-left-color: var(--background-secondary-alt) !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.mod-top .tooltip-arrow {
|
||||||
|
border-top-color: var(--background-secondary-alt) !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.dropdown {
|
||||||
|
cursor: pointer;
|
||||||
|
background-image: url(data:image/svg+xml;charset=US-ASCII,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%22292.4%22%20height%3D%22292.4%22%3E%3Cpath%20fill%3D%22%234c78cc%22%20d%3D%22M287%2069.4a17.6%2017.6%200%200%200-13-5.4H18.4c-5%200-9.3%201.8-12.9%205.4A17.6%2017.6%200%200%200%200%2082.2c0%205%201.8%209.3%205.4%2012.9l128%20127.9c3.6%203.6%207.8%205.4%2012.8%205.4s9.2-1.8%2012.8-5.4L287%2095c3.5-3.5%205.4-7.8%205.4-12.8%200-5-1.9-9.2-5.5-12.8z%22%2F%3E%3C%2Fsvg%3E);
|
||||||
|
}
|
||||||
|
|
||||||
|
.dropdown:hover {
|
||||||
|
background-color: var(--background-modifier-form-field);
|
||||||
|
}
|
||||||
|
|
||||||
|
.search-result-file-title {
|
||||||
|
color: var(--blue);
|
||||||
|
}
|
||||||
|
|
||||||
|
li {
|
||||||
|
padding-top: 0.5px;
|
||||||
|
padding-bottom: 0.5px;
|
||||||
|
}
|
||||||
|
|
||||||
|
a.tag, a.tag:hover {
|
||||||
|
color: var(--yellow);
|
||||||
|
background-color: var(--background-primary-alt);
|
||||||
|
padding: 2px 4px;
|
||||||
|
border-radius: 4px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.markdown-preview-view .task-list-item-checkbox {
|
||||||
|
-webkit-appearance: none;
|
||||||
|
box-sizing: border-box;
|
||||||
|
border: 1px solid var(--text-muted);
|
||||||
|
border-radius: 2px;
|
||||||
|
position: relative;
|
||||||
|
width: 1.3em;
|
||||||
|
height: 1.3em;
|
||||||
|
margin: 0;
|
||||||
|
filter: none;
|
||||||
|
outline: none;
|
||||||
|
margin-right: 4px;
|
||||||
|
margin-bottom: 2px;
|
||||||
|
cursor: pointer;
|
||||||
|
vertical-align: baseline;
|
||||||
|
}
|
||||||
|
|
||||||
|
.markdown-preview-view .task-list-item-checkbox:checked {
|
||||||
|
border: none;
|
||||||
|
background-color: var(--interactive-accent);
|
||||||
|
}
|
||||||
|
|
||||||
|
.markdown-preview-view .task-list-item-checkbox:checked::before {
|
||||||
|
content: ' ';
|
||||||
|
position: absolute;
|
||||||
|
background-color: white;
|
||||||
|
left: 2px;
|
||||||
|
top: 2px;
|
||||||
|
right: 2px;
|
||||||
|
bottom: 2px;
|
||||||
|
-webkit-mask-image: url('data:image/svg+xml,%3Csvg xmlns=\'http://www.w3.org/2000/svg\' viewBox=\'0 0 14 14\'%3E%3Cpolygon points=\'5.5 11.9993304 14 3.49933039 12.5 2 5.5 8.99933039 1.5 4.9968652 0 6.49933039\'%3E%3C/polygon%3E%3C/svg%3E');
|
||||||
|
}
|
||||||
|
|
||||||
|
.markdown-preview-view .task-list-item.is-checked a {
|
||||||
|
filter: saturate(0.8) brightness(0.7);
|
||||||
|
}
|
||||||
|
|
||||||
|
.cm-formatting-task {
|
||||||
|
font-family: var(--font-monospace);
|
||||||
|
}
|
||||||
|
|
||||||
|
.nav-file, .nav-folder {
|
||||||
|
padding: 1px 2px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.nav-file-title, .nav-folder-title {
|
||||||
|
width: 100%;
|
||||||
|
cursor: default;
|
||||||
|
display: flex;
|
||||||
|
align-items: baseline;
|
||||||
|
flex-direction: row;
|
||||||
|
--text-normal: var(--text-muted);
|
||||||
|
}
|
||||||
|
|
||||||
|
body:not(.is-grabbing) .nav-file .nav-file-title:hover:not(.is-active), body:not(.is-grabbing) .nav-folder .nav-folder-title:hover:not(.is-active) {
|
||||||
|
--background-secondary-alt: transparent;
|
||||||
|
}
|
||||||
|
|
||||||
|
.nav-file .is-active {
|
||||||
|
--background-secondary-alt: var(--interactive-accent);
|
||||||
|
--text-normal: #ffffff;
|
||||||
|
}
|
||||||
|
|
||||||
|
.nav-file-title-content, .nav-folder-title-content {
|
||||||
|
text-indent: 0;
|
||||||
|
white-space: nowrap;
|
||||||
|
text-overflow: ellipsis;
|
||||||
|
overflow: hidden;
|
||||||
|
display: block;
|
||||||
|
}
|
||||||
|
|
||||||
|
.markdown-preview-view.is-readable-line-width .markdown-preview-section, .markdown-source-view.is-readable-line-width .CodeMirror {
|
||||||
|
max-width: 900px !important;
|
||||||
|
line-height: 26px;
|
||||||
|
}
|
||||||
|
|
||||||
|
blockquote {
|
||||||
|
margin: 20px 0;
|
||||||
|
border-radius: 4px !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
body {
|
||||||
|
--font-monospace: 'Fira Code', 'Source Code Pro', monospace;
|
||||||
|
}
|
||||||
|
|
||||||
|
mjx-container[jax='CHTML'] {
|
||||||
|
text-align: left;
|
||||||
|
outline: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.math-block {
|
||||||
|
font-size: 1.25em;
|
||||||
|
}
|
||||||
|
|
||||||
|
.cm-s-obsidian pre.HyperMD-codeblock, .cm-s-obsidian span.cm-inline-code, .cm-s-obsidian span.cm-math:not(.cm-formatting-math-begin):not(.cm-formatting-math-end), .markdown-preview-view code {
|
||||||
|
/* fix `` tag color */
|
||||||
|
color: #98c379;
|
||||||
|
}
|
||||||
|
|
||||||
|
.cm-s-obsidian span.cm-inline-code, .cm-s-obsidian span.cm-math, .cm-s-obsidian span.hmd-fold-math-placeholder {
|
||||||
|
/* fix tag size */
|
||||||
|
font-weight: 100;
|
||||||
|
font-style: normal;
|
||||||
|
}
|
||||||
|
|
||||||
|
.markdown-preview-view code {
|
||||||
|
vertical-align: text-top;
|
||||||
|
word-break: break-word;
|
||||||
|
}
|
||||||
|
|
||||||
|
.markdown-preview-section:not(:first-child) h1, .markdown-preview-section:not(:first-child) h2, .markdown-preview-section:not(:first-child) h3, .markdown-preview-section:not(:first-child) h4, .markdown-preview-section:not(:first-child) h5, .markdown-preview-section:not(:first-child) h6 {
|
||||||
|
margin-top: 40px !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.markdown-preview-section h1, .markdown-preview-section h2, .markdown-preview-section h3, .markdown-preview-section h4, .markdown-preview-section h5, .markdown-preview-section h6 {
|
||||||
|
line-height: 1.2;
|
||||||
|
}
|
||||||
|
|
||||||
|
h1, h2, h3, h4, h5, h6, strong, b, .view-header-title {
|
||||||
|
font-weight: 600;
|
||||||
|
}
|
||||||
|
|
||||||
|
.workspace>.workspace-split>.workspace-leaf:first-of-type:last-of-type .view-header {
|
||||||
|
border: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.status-bar, .side-dock.mod-right, .side-dock.mod-left {
|
||||||
|
border-color: var(--panel-border-color);
|
||||||
|
border-width: 1px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.status-bar {
|
||||||
|
--bar-vertical-padding: 4px;
|
||||||
|
--bar-height: calc(22px + (var(--bar-vertical-padding) * 2));
|
||||||
|
line-height: 20px;
|
||||||
|
padding: 0 20px;
|
||||||
|
height: var(--bar-height);
|
||||||
|
max-height: var(--bar-height);
|
||||||
|
min-height: var(--bar-height);
|
||||||
|
overflow: hidden;
|
||||||
|
}
|
||||||
|
|
||||||
|
.status-bar-item {
|
||||||
|
margin: auto 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.status-bar-item>* {
|
||||||
|
padding-top: var(--bar-vertical-padding) !important;
|
||||||
|
padding-bottom: var(--bar-vertical-padding) !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.side-dock-plugin-panel-inner {
|
||||||
|
padding-left: 6px;
|
||||||
|
}
|
||||||
|
|
||||||
|
a, .markdown-preview-view .internal-link {
|
||||||
|
text-decoration: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
a:hover, .markdown-preview-view .internal-link:hover {
|
||||||
|
text-decoration: underline;
|
||||||
|
}
|
||||||
|
|
||||||
|
.theme-dark :not(pre)>code[class*='language-'], .theme-dark pre[class*='language-'] {
|
||||||
|
background: var(--background-primary-alt);
|
||||||
|
}
|
||||||
|
|
||||||
|
.theme-light :not(pre)>code[class*='language-'], .theme-light pre[class*='language-'] {
|
||||||
|
background: var(--background-primary);
|
||||||
|
box-shadow: inset 0 0 0 1px var(--background-primary-alt);
|
||||||
|
border-radius: 4px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.markdown-embed:not(.hover-popover .markdown-embed), .file-embed {
|
||||||
|
margin: 0;
|
||||||
|
border-radius: 4px;
|
||||||
|
margin: 0 !important;
|
||||||
|
margin-inline-start: 30px !important;
|
||||||
|
margin-inline-end: 30px !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.markdown-embed {
|
||||||
|
border: 1px solid var(--background-modifier-border);
|
||||||
|
border-left-width: 5px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.markdown-embed .markdown-preview-view {
|
||||||
|
padding: 0 20px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.markdown-embed-link, .file-embed-link {
|
||||||
|
left: 8px;
|
||||||
|
right: unset;
|
||||||
|
}
|
||||||
|
|
||||||
|
.theme-light .token.operator, .theme-light .token.entity, .theme-light .token.url, .theme-light .language-css .token.string, .theme-light .style .token.string {
|
||||||
|
background: transparent;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Source: https://github.com/AGMStudio/prism-theme-one-dark */
|
||||||
|
|
||||||
|
code[class*='language-'], pre[class*='language-'] {
|
||||||
|
text-align: left !important;
|
||||||
|
white-space: pre !important;
|
||||||
|
word-spacing: normal !important;
|
||||||
|
word-break: normal !important;
|
||||||
|
word-wrap: normal !important;
|
||||||
|
line-height: 1.5 !important;
|
||||||
|
-moz-tab-size: 4 !important;
|
||||||
|
-o-tab-size: 4 !important;
|
||||||
|
tab-size: 4 !important;
|
||||||
|
-webkit-hyphens: none !important;
|
||||||
|
-moz-hyphens: none !important;
|
||||||
|
-ms-hyphens: none !important;
|
||||||
|
hyphens: none !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Code blocks */
|
||||||
|
|
||||||
|
pre[class*='language-'] {
|
||||||
|
padding: 1em !important;
|
||||||
|
margin: .5em 0 !important;
|
||||||
|
overflow: auto !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Inline code */
|
||||||
|
|
||||||
|
:not(pre)>code[class*='language-'] {
|
||||||
|
padding: .1em !important;
|
||||||
|
border-radius: .3em !important;
|
||||||
|
white-space: normal !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.token.comment, .token.prolog, .token.doctype, .token.cdata {
|
||||||
|
color: var(--gray-1) !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.token.punctuation {
|
||||||
|
color: var(--gray-2) !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.token.selector, .token.tag {
|
||||||
|
color: var(--red) !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.token.property, .token.boolean, .token.number, .token.constant, .token.symbol, .token.attr-name, .token.deleted {
|
||||||
|
color: var(--orange) !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.token.string, .token.char, .token.attr-value, .token.builtin, .token.inserted {
|
||||||
|
color: var(--green) !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.token.operator, .token.entity, .token.url, .language-css .token.string, .style .token.string {
|
||||||
|
color: var(--aqua) !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.token.atrule, .token.keyword {
|
||||||
|
color: var(--purple) !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.token.function, .token.macro.property {
|
||||||
|
color: var(--blue) !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.token.class-name {
|
||||||
|
color: var(--yellow) !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.token.regex, .token.important, .token.variable {
|
||||||
|
color: var(--purple) !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.token.important, .token.bold {
|
||||||
|
font-weight: bold !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.token.italic {
|
||||||
|
font-style: italic !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.token.entity {
|
||||||
|
cursor: help !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
pre.line-numbers {
|
||||||
|
position: relative !important;
|
||||||
|
padding-left: 3.8em !important;
|
||||||
|
counter-reset: linenumber !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
pre.line-numbers>code {
|
||||||
|
position: relative !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.line-numbers .line-numbers-rows {
|
||||||
|
position: absolute !important;
|
||||||
|
pointer-events: none !important;
|
||||||
|
top: 0 !important;
|
||||||
|
font-size: 100% !important;
|
||||||
|
left: -3.8em !important;
|
||||||
|
width: 3em !important;
|
||||||
|
/* works for line-numbers below 1000 lines */
|
||||||
|
letter-spacing: -1px !important;
|
||||||
|
border-right: 0 !important;
|
||||||
|
-webkit-user-select: none !important;
|
||||||
|
-moz-user-select: none !important;
|
||||||
|
-ms-user-select: none !important;
|
||||||
|
user-select: none !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.line-numbers-rows>span {
|
||||||
|
pointer-events: none !important;
|
||||||
|
display: block !important;
|
||||||
|
counter-increment: linenumber !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.line-numbers-rows>span:before {
|
||||||
|
content: counter(linenumber) !important;
|
||||||
|
color: var(--syntax-gray-1) !important;
|
||||||
|
display: block !important;
|
||||||
|
padding-right: 0.8em !important;
|
||||||
|
text-align: right !important;
|
||||||
|
}
|
7317
.obsidian/themes/California Coast.css
vendored
Normal file
7317
.obsidian/themes/California Coast.css
vendored
Normal file
File diff suppressed because one or more lines are too long
9144
.obsidian/themes/Yin and Yang.css
vendored
Normal file
9144
.obsidian/themes/Yin and Yang.css
vendored
Normal file
File diff suppressed because one or more lines are too long
98
.obsidian/workspace
vendored
Normal file
98
.obsidian/workspace
vendored
Normal file
@ -0,0 +1,98 @@
|
|||||||
|
{
|
||||||
|
"main": {
|
||||||
|
"id": "401e7e6167813359",
|
||||||
|
"type": "split",
|
||||||
|
"children": [
|
||||||
|
{
|
||||||
|
"id": "4ab7c4f28523c7e2",
|
||||||
|
"type": "leaf",
|
||||||
|
"state": {
|
||||||
|
"type": "markdown",
|
||||||
|
"state": {
|
||||||
|
"file": "Answer/1 ~ 10/5.md",
|
||||||
|
"mode": "source"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"direction": "vertical"
|
||||||
|
},
|
||||||
|
"left": {
|
||||||
|
"id": "d26cd62d651df5eb",
|
||||||
|
"type": "split",
|
||||||
|
"children": [
|
||||||
|
{
|
||||||
|
"id": "c2e0081d8370b271",
|
||||||
|
"type": "tabs",
|
||||||
|
"children": [
|
||||||
|
{
|
||||||
|
"id": "fde13b4337a6e36d",
|
||||||
|
"type": "leaf",
|
||||||
|
"state": {
|
||||||
|
"type": "file-explorer",
|
||||||
|
"state": {}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"id": "9aebf1f8a27ba4fa",
|
||||||
|
"type": "leaf",
|
||||||
|
"state": {
|
||||||
|
"type": "search",
|
||||||
|
"state": {
|
||||||
|
"query": "",
|
||||||
|
"matchingCase": false,
|
||||||
|
"explainSearch": false,
|
||||||
|
"collapseAll": false,
|
||||||
|
"extraContext": false,
|
||||||
|
"sortOrder": "alphabetical"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"direction": "horizontal",
|
||||||
|
"width": 300
|
||||||
|
},
|
||||||
|
"right": {
|
||||||
|
"id": "946d6795c5a70c11",
|
||||||
|
"type": "split",
|
||||||
|
"children": [
|
||||||
|
{
|
||||||
|
"id": "e05eb20a739e228c",
|
||||||
|
"type": "tabs",
|
||||||
|
"children": [
|
||||||
|
{
|
||||||
|
"id": "68955fb38bd7fc66",
|
||||||
|
"type": "leaf",
|
||||||
|
"state": {
|
||||||
|
"type": "backlink",
|
||||||
|
"state": {
|
||||||
|
"file": "Answer/1 ~ 10/5.md",
|
||||||
|
"collapseAll": false,
|
||||||
|
"extraContext": false,
|
||||||
|
"sortOrder": "alphabetical",
|
||||||
|
"showSearch": false,
|
||||||
|
"searchQuery": "",
|
||||||
|
"backlinkCollapsed": false,
|
||||||
|
"unlinkedCollapsed": true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"direction": "horizontal",
|
||||||
|
"width": 300,
|
||||||
|
"collapsed": true
|
||||||
|
},
|
||||||
|
"active": "4ab7c4f28523c7e2",
|
||||||
|
"lastOpenFiles": [
|
||||||
|
"Answer/1 ~ 10/5.md",
|
||||||
|
"Answer/1 ~ 10/6.md",
|
||||||
|
"deep/第一期.md",
|
||||||
|
"Answer/1 ~ 10/2.md",
|
||||||
|
"Answer/1 ~ 10/4.md",
|
||||||
|
"Answer/1 ~ 10/1.md"
|
||||||
|
]
|
||||||
|
}
|
@ -41,3 +41,4 @@ Promise.all(queue)
|
|||||||
console.log(err);
|
console.log(err);
|
||||||
});
|
});
|
||||||
```
|
```
|
||||||
|
|
||||||
|
17
README.md
17
README.md
@ -57,6 +57,23 @@ JS 数据类型分为两大类及八种数据类型,注意别漏了 ES6 新增
|
|||||||
- [ ] 文档:
|
- [ ] 文档:
|
||||||
- [ ] [JavaScript 数据类型和数据结构](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Data_structures)
|
- [ ] [JavaScript 数据类型和数据结构](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Data_structures)
|
||||||
|
|
||||||
|
### 类型判断
|
||||||
|
|
||||||
|
类型判断有好几种方式,分别为:
|
||||||
|
|
||||||
|
- `typeof`
|
||||||
|
- `instanceof`
|
||||||
|
- `Object.prototype.toString`
|
||||||
|
- `isXXX`,比如 `isArray`
|
||||||
|
|
||||||
|
- [ ] 文档
|
||||||
|
- [ ] [typeof](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Operators/typeof)
|
||||||
|
- [ ] [instanceof](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Operators/instanceof)
|
||||||
|
- [ ] [Object.prototype.toString](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/toString#using_tostring_to_detect_object_class)
|
||||||
|
- [ ] 推荐文章
|
||||||
|
- [ ] [JavaScript专题之类型判断(上)](https://github.com/mqyqingfeng/Blog/issues/28)
|
||||||
|
- [ ] [JavaScript专题之类型判断(下)](https://github.com/mqyqingfeng/Blog/issues/30)
|
||||||
|
|
||||||
## 十五万字面试资料
|
## 十五万字面试资料
|
||||||
|
|
||||||
[在线阅读](https://yuchengkai.cn/home/)
|
[在线阅读](https://yuchengkai.cn/home/)
|
||||||
|
Loading…
Reference in New Issue
Block a user