Vue?h函數(shù)的使用詳解
一、認(rèn)識(shí)
文檔:https://v3.cn.vuejs.org/guide/render-function.html#dom-%E6%A0%91
? h() 到底會(huì)返回什么呢?其實(shí)不是一個(gè)實(shí)際的 DOM 元素。它更準(zhǔn)確的名字可能是 createNodeDescription,因?yàn)樗男畔?huì)告訴 Vue 頁(yè)面上需要渲染什么樣的節(jié)點(diǎn),包括及其子節(jié)點(diǎn)的描述信息。我們把這樣的節(jié)點(diǎn)描述為“虛擬節(jié)點(diǎn) (virtual node)”,也常簡(jiǎn)寫(xiě)它為 VNode 。“虛擬 DOM”是我們對(duì)由 Vue 組件樹(shù)建立起來(lái)的整個(gè) VNode 樹(shù)的稱呼。
二、使用
文檔:https://v3.cn.vuejs.org/guide/render-function.html#h-%E5%8F%82%E6%95%B0
1、h() 參數(shù)
h() 函數(shù)是一個(gè)用于創(chuàng)建 VNode 的實(shí)用程序。也許可以更準(zhǔn)確地將其命名為 createVNode(),但由于頻繁使用和簡(jiǎn)潔,它被稱為 h() 。它接受三個(gè)參數(shù):
// @returns {VNode} h( // {String | Object | Function} tag // 一個(gè) HTML 標(biāo)簽名、一個(gè)組件、一個(gè)異步組件、或 // 一個(gè)函數(shù)式組件。 // // 必需的。 'div', // {Object} props // 與 attribute、prop 和事件相對(duì)應(yīng)的對(duì)象。 // 這會(huì)在模板中用到。 // // 可選的(在開(kāi)發(fā)時(shí)。建議傳,實(shí)在沒(méi)有傳的時(shí)候,傳入 null) {}, // {String | Array | Object} children // 子 VNodes, 使用 `h()` 構(gòu)建, // 或使用字符串獲取 "文本 VNode" 或者 // 有插槽的對(duì)象。 // // 可選的。 [ 'Some text comes first.', h('h1', 'A headline'), h(MyComponent, { someProp: 'foobar' }) ] )
2、簡(jiǎn)單的使用
3、實(shí)現(xiàn)一個(gè)計(jì)數(shù)器案例
<script> /* 設(shè)置樣式需要在這引入,如果使用style標(biāo)簽,則不能寫(xiě)scoped,不利于設(shè)置局部樣式,所以不建議 */ import "./style.css" import { h, ref } from "vue"; export default { // data 的寫(xiě)法 // data() { // return { // counter: 0 // } // }, setup() { const counter = ref(0) return { counter } }, /** * 使用setup的時(shí)候,下面也可以用this,引入render有綁定this,所以下面取值,要用this */ render() { return h("div", null, [ h("h1", null, `當(dāng)前計(jì)數(shù):${this.counter}`), h("button", { onClick: () => this.counter++, class: "button" }, "加 1"), h("button", { onClick: () => this.counter--, class: "button" }, "減 1") ]) } } </script>
修改成純setup的寫(xiě)法:
<script> /* 設(shè)置樣式需要在這引入,如果使用style標(biāo)簽,則不能寫(xiě)scoped,不利于設(shè)置局部樣式,所以不建議 */ import "./style.css" import { h, ref } from "vue"; export default { // data 的寫(xiě)法 // data() { // return { // counter: 0 // } // }, setup() { const counter = ref(0) return () => { return h("div", null, [ h("h1", null, `當(dāng)前計(jì)數(shù):${counter.value}`), h("button", { onClick: () => counter.value++, class: "button" }, "加 1"), h("button", { onClick: () => counter.value--, class: "button" }, "減 1") ]) } } } </script>
4、函數(shù)組件和插槽的使用
1)父組件
<script> import { h, ref } from "vue"; import Test from "./components/Test.vue" export default { setup() { return {} }, render() { return h(Test, null, { // default 對(duì)應(yīng)的是一個(gè)函數(shù),default是默認(rèn)插槽 default: props => h("span", null, "父?jìng)魅氲浇M件中的內(nèi)容:" + props.name) }) } } </script>
2)子組件
<script> import { h } from "vue"; export default { /** * 接收夫傳入的內(nèi)容 */ render() { return h("div", null, [ h("div", null, "我是子組件"), /** * 在這判斷別人是否傳入 * 也可以寫(xiě) null,啥也不展示 * 也可以在傳入一個(gè)參數(shù),使用的是 函數(shù)傳參 */ this.$slots.default ? this.$slots.default({ name: "哈哈哈" }) : h("div", null, "我是子組件的默認(rèn)值") ]) } } </script>
注:在項(xiàng)目中,如果你像上面一樣寫(xiě)代碼,就太苦逼了,所以這個(gè)時(shí)候就要用 JSX。
三、jsx的使用
1、jsx的認(rèn)識(shí)
jsx我們通常會(huì)通過(guò)Babel來(lái)進(jìn)行轉(zhuǎn)換(React編寫(xiě)的jsx就是通過(guò)babel轉(zhuǎn)換的);
對(duì)于Vue來(lái)說(shuō),我們只需要在Babel中配置對(duì)應(yīng)的插件即可;
文檔:https://v3.cn.vuejs.org/guide/render-function.html#jsx
2、下載Babel插件支持vue(現(xiàn)在貌似腳手架直接支持)
npm install @vue/babel-plugin-jsx -D
3、配置babel
1)在根目錄下創(chuàng)建 .babel.config.js
2)在.babel.config.js 里面加入,如下代碼
module.exports = { presets: [ "@/vue/cli-plugin-babel/preset" ], plugins: [ "@vue/babel-plugin-jsx" ] }
4、簡(jiǎn)單的使用
<script> import { ref } from 'vue' export default { setup() { let counter = ref(0) return { counter } }, render() { return ( <div> <div>JSX的使用</div> <h2>當(dāng)前數(shù)字:{this.counter}</h2> </div> ) } } </script>
5、計(jì)數(shù)器案例
<script> import { ref } from '@vue/reactivity' export default { setup() { let counter = ref(0) function add() { counter.value++ } function decrement() { counter.value-- } return { counter, add, decrement } }, render() { return ( <div> <div>JSX的使用</div> <h2>當(dāng)前數(shù)字:{this.counter}</h2> <button onClick={this.add}>加 1</button> <button onClick={this.decrement} >減 1</button> </div > ) } } </script>
6、組件和插槽的使用
1)父組件
<script> import { ref } from '@vue/reactivity' import Test from "./components/Test.vue" export default { setup() { let counter = ref(0) function add() { counter.value++ } function decrement() { counter.value-- } return { counter, add, decrement } }, render() { return ( <div> <div>JSX的使用</div> {/* 如果這塊使用setup里面的變量、方法 要加this */} <h2>當(dāng)前數(shù)字:{this.counter}</h2> <button onClick={this.add}>加 1</button> <button onClick={this.decrement} >減 1</button> <hr /> <Test> {/* 這個(gè)里面寫(xiě)入傳入的內(nèi)容,也就是傳入一個(gè)插槽 */} {{ default: props => <p>我是父?jìng)魅胱拥?lt;/p> }} </Test> </div > ) } } </script>
2)子組件
<script> export default { /** * 接收夫傳入的內(nèi)容 */ render() { return ( <div> <p>我是組件</p> {/* 這塊也有可能沒(méi)穿,你要顯示一個(gè)默認(rèn)值,這個(gè)時(shí)候,你就要用三元運(yùn)算符 */} {this.$slots.default()} </div> ) } } </script>
注:如果你要h函數(shù)來(lái)寫(xiě)組件,請(qǐng)仔細(xì)查看文檔,以上講解,只是入門(mén)級(jí)。
到此這篇關(guān)于Vue h函數(shù)的使用詳解的文章就介紹到這了,更多相關(guān)Vue h函數(shù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Vue實(shí)現(xiàn)當(dāng)前頁(yè)面刷新的七種方法總結(jié)
大家在vue項(xiàng)目中當(dāng)刪除或者增加一條記錄的時(shí)候希望當(dāng)前頁(yè)面可以重新刷新,但是vue框架自帶的router是不支持刷新當(dāng)前頁(yè)面功能,所以本文就給大家分享了七種vue實(shí)現(xiàn)當(dāng)前頁(yè)面刷新的方法,需要的朋友可以參考下2023-07-07解決vue項(xiàng)目axios每次請(qǐng)求session不一致的問(wèn)題
這篇文章主要介紹了解決vue項(xiàng)目axios每次請(qǐng)求session不一致的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-10-10Nuxt 嵌套路由nuxt-child組件用法(父子頁(yè)面組件的傳值)
這篇文章主要介紹了Nuxt 嵌套路由nuxt-child組件用法(父子頁(yè)面組件的傳值),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-11-11Vue注冊(cè)組件命名時(shí)不能用大寫(xiě)的原因淺析
這段時(shí)間一直在弄vue,當(dāng)然也遇到很多問(wèn)題,這里就來(lái)跟大家分享一些注冊(cè)自定義模板組件的心得 ,需要的朋友可以參考下2019-04-04vue :style設(shè)置背景圖片方式backgroundImage
這篇文章主要介紹了vue :style設(shè)置背景圖片方式backgroundImage,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-10-10vue 實(shí)現(xiàn)tab切換保持?jǐn)?shù)據(jù)狀態(tài)
這篇文章主要介紹了vue 實(shí)現(xiàn)tab切換保持?jǐn)?shù)據(jù)狀態(tài),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-07-07vue實(shí)現(xiàn)簡(jiǎn)單無(wú)縫滾動(dòng)效果
這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)簡(jiǎn)單無(wú)縫滾動(dòng)效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-04-04vue實(shí)現(xiàn)在進(jìn)行增刪改操作后刷新頁(yè)面
這篇文章主要介紹了vue實(shí)現(xiàn)在進(jìn)行增刪改操作后刷新頁(yè)面,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-08-08