只渲染元素和组件一次。
随后的重新渲染,元素/组件及其所有的子节点将被视为静态内容并跳过。这可以用于优化更新性能。
<!DOCTYPE html><html lang="en"><head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title></head><body><div id="app"></div><template id="my-app"><!-- 这里的会变化 --><h2>{{counter}}</h2><!-- 这里的子元素只渲染1次,意味着不会变化 --><div v-once><h2>{{counter}}</h2><h2>{{message}}</h2></div><button @click="increment">+1</button></template><script src="https://unpkg.com/vue@next"></script><script>const App = {template: '#my-app',data() {return {counter: 100,message: "abc"}},methods: {// 让counter+1increment() {this.counter++;}}}Vue.createApp(App).mount('#app');</script></body></html>

