Docsify 兼容 Vue:修订间差异
(创建页面,内容为“ 你可以直接在 Markdown 文件里写 Vue 代码,它将被执行。我们可以用它写一些 Vue 的 Demo 或者示例代码。 首先,将 Vue[https://vuejs.org 2.x] 或 [https://v3.vuejs.org 3.x] 添加到你的<code>index.html</code>文件中。 为你的站点选择合适的生产版本或开发版本,以获得有用的控制台警告和 [https://github.com/vuejs/vue-devtools Vue.js devtools] 支持。 <span id="vue-2.x"></span> ==== Vue 2.x =…”) |
无编辑摘要 |
||
(未显示同一用户的1个中间版本) | |||
第36行: | 第36行: | ||
<!-- JavaScript expressions --> | <!-- JavaScript expressions --> | ||
<p>2 + 2 = {{ 2 + 2 }}</p></pre> | <p>2 + 2 = {{ 2 + 2 }}</p></pre> | ||
[https://github.com/docsifyjs/docsify/blob/develop/docs/vue.md#template-syntax 在GitHub上查看输出] | [https://github.com/docsifyjs/docsify/blob/develop/docs/vue.md#template-syntax 在GitHub上查看输出] | ||
第72行: | 第60行: | ||
<!-- 在docsify中显示消息,在其他地方显示 text(例如GitHub) --> | <!-- 在docsify中显示消息,在其他地方显示 text(例如GitHub) --> | ||
<p v-text="message">Text for GitHub</p></pre> | <p v-text="message">Text for GitHub</p></pre> | ||
[https://github.com/docsifyjs/docsify/blob/develop/docs/vue.md#data 在GitHub上查看输出] | [https://github.com/docsifyjs/docsify/blob/develop/docs/vue.md#data 在GitHub上查看输出] | ||
第106行: | 第85行: | ||
}</pre> | }</pre> | ||
<pre class="markdown">Good {{ timeOfDay }}!</pre> | <pre class="markdown">Good {{ timeOfDay }}!</pre> | ||
<span id="methods"></span> | <span id="methods"></span> | ||
=== Methods === | === Methods === | ||
第126行: | 第102行: | ||
}</pre> | }</pre> | ||
<pre class="markdown"><button @click="hello">Say Hello</button></pre> | <pre class="markdown"><button @click="hello">Say Hello</button></pre> | ||
<span id="lifecycle-hooks"></span> | <span id="lifecycle-hooks"></span> | ||
=== Lifecycle Hooks === | === Lifecycle Hooks === | ||
第160行: | 第132行: | ||
</figure> | </figure> | ||
</div></pre> | </div></pre> | ||
<span id="global-options"></span> | <span id="global-options"></span> | ||
== Global options == | == Global options == | ||
第189行: | 第152行: | ||
<button @click="count += 1">+</button> | <button @click="count += 1">+</button> | ||
</p></pre> | </p></pre> | ||
对一个计数器的更改会影响两个计数器。这是因为两个实例都引用了相同的全局<code>count</code>值。现在,导航到一个新的页面,并返回本节,查看对全局数据的更改如何在页面加载之间持久化。 | 对一个计数器的更改会影响两个计数器。这是因为两个实例都引用了相同的全局<code>count</code>值。现在,导航到一个新的页面,并返回本节,查看对全局数据的更改如何在页面加载之间持久化。 | ||
第224行: | 第177行: | ||
<button @click="count += 1">+</button> | <button @click="count += 1">+</button> | ||
</div></pre> | </div></pre> | ||
<span id="components"></span> | <span id="components"></span> | ||
== Components == | == Components == | ||
第250行: | 第201行: | ||
<pre class="markdown"><button-counter></button-counter> | <pre class="markdown"><button-counter></button-counter> | ||
<button-counter></button-counter></pre> | <button-counter></button-counter></pre> | ||
<span id="markdown-script"></span> | <span id="markdown-script"></span> | ||
== Markdown script == | == Markdown script == | ||
第274行: | 第223行: | ||
</script></pre> | </script></pre> | ||
<span id="technical-notes"></span> | <span id="technical-notes"></span> | ||
== | |||
== 说明 == | |||
<ul> | <ul> | ||
<li><p>Docsify | <li><p>Docsify 在每次加载页面时按以下顺序处理Vue内容: | ||
1.执行 Markdown <code><script></code> | |||
2.注册全局 <code>vueComponents</code> | |||
3.挂载 <code>vueMounts</code> | |||
4.自动挂载未安装的 <code>vueComponents</code> | |||
5.使用 <code>vueGlobalOptions</code> 自动挂载未安装的Vue模板语法</p></li> | |||
<li><p>自动挂载Vue内容时,docsify将挂载Markdown中包含模板语法或组件的每个顶级元素。例如,在以下HTML中,将安装顶级<code><p></code>,<code><my-component /></code>和<code><div></code>元素。</p> | <li><p>自动挂载Vue内容时,docsify将挂载Markdown中包含模板语法或组件的每个顶级元素。例如,在以下HTML中,将安装顶级<code><p></code>,<code><my-component /></code>和<code><div></code>元素。</p> | ||
<pre lang="html"><p>{{ foo }}</p> | <pre lang="html"><p>{{ foo }}</p> |
2023年8月3日 (四) 03:40的最新版本
你可以直接在 Markdown 文件里写 Vue 代码,它将被执行。我们可以用它写一些 Vue 的 Demo 或者示例代码。
首先,将 Vue2.x 或 3.x 添加到你的index.html
文件中。
为你的站点选择合适的生产版本或开发版本,以获得有用的控制台警告和 Vue.js devtools 支持。
Vue 2.x
<!-- Production -->
<script src="//cdn.jsdelivr.net/npm/vue@2/dist/vue.min.js"></script>
<!-- Development -->
<script src="//cdn.jsdelivr.net/npm/vue@2/dist/vue.js"></script>
Vue 3.x
<!-- Production -->
<script src="//cdn.jsdelivr.net/npm/vue@3/dist/vue.global.prod.js"></script>
<!-- Development -->
<script src="//cdn.jsdelivr.net/npm/vue@3/dist/vue.global.js"></script>
模板语法
Vue模板语法 用于创建动态内容。无需额外的配置,这种语法提供了一些有用的功能,如支持 JavaScript表达式 和 Vue指令 的循环和条件渲染。
<!-- 在docsify中隐藏,在其他地方显示(如GitHub)。 --> <p v-if="false">Text for GitHub</p> <!-- Sequenced content (i.e. loop)--> <ul> <li v-for="i in 3">Item {{ i }}</li> </ul> <!-- JavaScript expressions --> <p>2 + 2 = {{ 2 + 2 }}</p>
当使用data、computed properties、methods和lifecycle hooks时,Vue内容会变得更加有趣。这些选项可以作为全局选项或在DOM中的mounts和component来指定。
Data
{
data() {
return {
message: 'Hello, World!'
};
}
}
<!-- 在docsify中显示消息,在其他地方显示 "{{ message }}"(例如GitHub) --> {{ message }} <!-- 在docsify中显示消息,在其他地方隐藏(例如GitHub) --> <p v-text="message"></p> <!-- 在docsify中显示消息,在其他地方显示 text(例如GitHub) --> <p v-text="message">Text for GitHub</p>
Computed properties
{
computed: {
timeOfDay() {
const date = new Date();
const hours = date.getHours();
if (hours < 12) {
return 'morning';
}
else if (hours < 18) {
return 'afternoon';
}
else {
return 'evening'
}
}
},
}
Good {{ timeOfDay }}!
Methods
{
data() {
return {
message: 'Hello, World!'
};
},
methods: {
hello() {
alert(this.message);
}
},
}
<button @click="hello">Say Hello</button>
Lifecycle Hooks
{
data() {
return {
images: null,
};
},
created() {
fetch('https://api.domain.com/')
.then(response => response.json())
.then(data => (this.images = data))
.catch(err => console.log(err));
}
}
// API response:
// [
// { title: 'Image 1', url: 'https://domain.com/1.jpg' },
// { title: 'Image 2', url: 'https://domain.com/2.jpg' },
// { title: 'Image 3', url: 'https://domain.com/3.jpg' },
// ];
<div style="display: flex;"> <figure style="flex: 1;"> <img v-for="image in images" :src="image.url" :title="image.title"> <figcaption>{{ image.title }}</figcaption> </figure> </div>
Global options
使用vueGlobalOptions
来指定 Vue options ,用于未明确挂载vueMounts、vueComponents或markdown脚本的Vue内容。对全局data
的更改将持续存在,并反映在任何使用全局引用的地方。
window.$docsify = {
vueGlobalOptions: {
data() {
return {
count: 0,
};
},
},
};
<p> <button @click="count -= 1">-</button> {{ count }} <button @click="count += 1">+</button> </p>
对一个计数器的更改会影响两个计数器。这是因为两个实例都引用了相同的全局count
值。现在,导航到一个新的页面,并返回本节,查看对全局数据的更改如何在页面加载之间持久化。
Mounts
使用vueMounts
来指定要挂载为 Vue实例 的DOM元素及其相关选项。挂载元素使用 CSS选择器 作为键,并使用一个包含Vue选项的对象作为其值。每次加载新页面时,Docsify将挂载主内容区域中第一个匹配的元素。挂载元素data
对每个实例来说都是唯一的,并且在用户浏览网站时不会持久。
window.$docsify = {
vueMounts: {
'#counter': {
data() {
return {
count: 0,
};
},
},
},
};
<div id="counter"> <button @click="count -= 1">-</button> {{ count }} <button @click="count += 1">+</button> </div>
Components
使用vueComponents
创建和注册全局Vue组件 。组件是以组件名称为键,以包含Vue选项的对象为值来指定的。组件data
对每个实例来说都是唯一的,并且在用户浏览网站时不会持久存在。
window.$docsify = {
vueComponents: {
'button-counter': {
template: `
<button @click="count += 1">
You clicked me {{ count }} times
</button>
`,
data() {
return {
count: 0,
};
},
},
},
};
<button-counter></button-counter> <button-counter></button-counter>
Markdown script
Vue内容可以使用 Markdown 页面中的<script>
标签进行挂载。
!> 只有 Markdown 文件中的第一个<script>
标签会被执行。如果你想使用脚本标签挂载多个Vue实例,所有实例必须挂载在Markdown的第一个脚本标签内。
<!-- Vue 2.x -->
<script>
new Vue({
el: '#example',
// Options...
});
</script>
<!-- Vue 3.x -->
<script>
Vue.createApp({
// Options...
}).mount('#example');
</script>
说明
Docsify 在每次加载页面时按以下顺序处理Vue内容: 1.执行 Markdown
<script>
2.注册全局vueComponents
3.挂载vueMounts
4.自动挂载未安装的vueComponents
5.使用vueGlobalOptions
自动挂载未安装的Vue模板语法自动挂载Vue内容时,docsify将挂载Markdown中包含模板语法或组件的每个顶级元素。例如,在以下HTML中,将安装顶级
<p>
,<my-component />
和<div>
元素。<p>{{ foo }}</p> <my-component /> <div> <span>{{ bar }}</span> <some-other-component /> </div>
Docsify将不会挂载现有Vue实例或包含现有Vue实例的元素。
Docsify将在每次加载页面之前自动销毁/卸载其创建的所有Vue实例。