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-10
Nuxt 嵌套路由nuxt-child組件用法(父子頁(yè)面組件的傳值)
這篇文章主要介紹了Nuxt 嵌套路由nuxt-child組件用法(父子頁(yè)面組件的傳值),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-11-11
Vue注冊(cè)組件命名時(shí)不能用大寫(xiě)的原因淺析
這段時(shí)間一直在弄vue,當(dāng)然也遇到很多問(wèn)題,這里就來(lái)跟大家分享一些注冊(cè)自定義模板組件的心得 ,需要的朋友可以參考下2019-04-04
vue :style設(shè)置背景圖片方式backgroundImage
這篇文章主要介紹了vue :style設(shè)置背景圖片方式backgroundImage,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-10-10
vue 實(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-07
vue實(shí)現(xiàn)簡(jiǎn)單無(wú)縫滾動(dòng)效果
這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)簡(jiǎn)單無(wú)縫滾動(dòng)效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-04-04
vue實(shí)現(xiàn)在進(jìn)行增刪改操作后刷新頁(yè)面
這篇文章主要介紹了vue實(shí)現(xiàn)在進(jìn)行增刪改操作后刷新頁(yè)面,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-08-08

