您好,登錄后才能下訂單哦!
這篇文章主要介紹了Vue中的watch偵聽(tīng)器、計(jì)算屬性、Vue-cli和組件怎么使用的相關(guān)知識(shí),內(nèi)容詳細(xì)易懂,操作簡(jiǎn)單快捷,具有一定借鑒價(jià)值,相信大家閱讀完這篇Vue中的watch偵聽(tīng)器、計(jì)算屬性、Vue-cli和組件怎么使用文章都會(huì)有所收獲,下面我們一起來(lái)看看吧。
watch 偵聽(tīng)器允許開(kāi)發(fā)者監(jiān)視數(shù)據(jù)的變化,從而針對(duì)數(shù)據(jù)的變化做特定的操作。
語(yǔ)法格式如下:
監(jiān)聽(tīng) username 值的變化,并使用 axios
發(fā)起 Ajax
請(qǐng)求,檢測(cè)當(dāng)前輸入的用戶(hù)名是否可用:
代碼演示如下:
watch: { // 監(jiān)聽(tīng) username 值的變化 async username( newVal ) { if (newVal === '') return // 使用 axios 發(fā)起請(qǐng)求,判斷用戶(hù)名是否可用 const { data: res } = await axios.get('https://www.escook.cn/api/finduser/' + newVal) console.log(res) } }
默認(rèn)情況下,組件在初次加載完畢后不會(huì)調(diào)用 watch 偵聽(tīng)器。如果想讓 watch
偵聽(tīng)器立即被調(diào)用,則需要使用 immediate
選項(xiàng)。
代碼演示如下:
watch: { username: { // handler 是固定寫(xiě)法,表示當(dāng) username 的值變化時(shí),自動(dòng)調(diào)用 handler 處理函數(shù) handler: async function ( newVal ) { if (newVal === '') return const { data: res } = await axios.get('https://www.escook.cn/api/finduser/' + newVal) console.log(res) }, // 表示頁(yè)面初次渲染好之后,就立即觸發(fā)當(dāng)前的 watch 偵聽(tīng)器 immediate: true } }
如果 watch
偵聽(tīng)的是一個(gè)對(duì)象,如果對(duì)象中的屬性值發(fā)生了變化,則無(wú)法被監(jiān)聽(tīng)到。此時(shí)需要使用 deep
選項(xiàng)。
代碼演示如下:
如果只想監(jiān)聽(tīng)對(duì)象中單個(gè)屬性的變化,則可以按照如下的方式定義watch
偵聽(tīng)器:
代碼演示如下:
1?? 計(jì)算屬性指的是通過(guò)一系列運(yùn)算之后,最終得到一個(gè)屬性值。
2?? 這個(gè)動(dòng)態(tài)計(jì)算出來(lái)的屬性值可以被模板結(jié)構(gòu)或 methods 方法使用。
代碼演示如下:
1?? 雖然計(jì)算屬性在聲明的時(shí)候被定義為方法,但是計(jì)算屬性的本質(zhì)是一個(gè)屬性;
2?? 計(jì)算屬性會(huì)緩存計(jì)算的結(jié)果,只有計(jì)算屬性依賴(lài)的數(shù)據(jù)變化時(shí),才會(huì)重新進(jìn)行運(yùn)算;
1?? vue-cli 是 Vue.js 開(kāi)發(fā)的標(biāo)準(zhǔn)工具。它簡(jiǎn)化了程序員基于 webpack 創(chuàng)建工程化的 Vue 項(xiàng)目的過(guò)程。
2?? 引用自 vue-cli 官網(wǎng)上的一句話(huà):程序員可以專(zhuān)注在撰寫(xiě)應(yīng)用上,而不必花好幾天去糾結(jié) webpack 配置的問(wèn)題;
3?? 中文官網(wǎng):https://cli.vuejs.org/zh/
1?? vue-cli 是 npm 上的一個(gè)全局包,使用 npm install 命令,即可方便的把它安裝到自己的電腦上:npm install -g @vue/cli
2?? 檢查其版本是否正確:vue --version
3?? 在終端下運(yùn)行如下的命令,創(chuàng)建指定名稱(chēng)的項(xiàng)目:vue create 項(xiàng)目的名稱(chēng)
assets 文件夾
:存放項(xiàng)目中用到的靜態(tài)資源文件,例如:css 樣式表、圖片資源;
components 文件夾
:程序員封裝的、可復(fù)用的組件,都要放到 components 目錄下;
main.js
是項(xiàng)目的入口文件。整個(gè)項(xiàng)目的運(yùn)行,要先執(zhí)行 main.js;
App.vue
是項(xiàng)目的根組件;
在工程化的項(xiàng)目中,vue 要做的事情很單純:通過(guò) main.js 把 App.vue 渲染到 index.html 的指定區(qū)域中。
App.vue
用來(lái)編寫(xiě)待渲染的模板結(jié)構(gòu);
index.html
中需要預(yù)留一個(gè) el 區(qū)域;
main.js
把 App.vue
渲染到了 index.html
所預(yù)留的區(qū)域中;
組件化開(kāi)發(fā)指的是:根據(jù)封裝的思想,把頁(yè)面上可重用的 UI 結(jié)構(gòu)封裝為組件,從而方便項(xiàng)目的開(kāi)發(fā)和維護(hù)。
1?? vue 是一個(gè)支持組件化開(kāi)發(fā)的前端框架;
2?? vue 中規(guī)定:組件的后綴名是.vue
。之前接觸到的 App.vue 文件本質(zhì)上就是一個(gè) vue 的組件;
每個(gè) .vue
組件都由 3 部分構(gòu)成,分別是:
template
→ 組件的模板結(jié)構(gòu)
script
→ 組件的 JavaScript 行為
style
→ 組件的樣式
其中,每個(gè)組件中必須包含 template 模板結(jié)構(gòu),而 script 行為和 style 樣式是可選的組成部分。
vue 規(guī)定:每個(gè)組件對(duì)應(yīng)的模板結(jié)構(gòu),需要定義到 <template>
節(jié)點(diǎn)中。
?溫馨提醒?:
template 是 vue 提供的容器標(biāo)簽,只起到包裹性質(zhì)的作用,它不會(huì)被渲染為真正的 DOM 元素;
template 中只能包含唯一的根節(jié)點(diǎn);
1?? vue 規(guī)定:開(kāi)發(fā)者可以在 <script>
節(jié)點(diǎn)中封裝組件的 JavaScript 業(yè)務(wù)邏輯。
<script >
節(jié)點(diǎn)的基本結(jié)構(gòu)如下:
2?? vue 規(guī)定:.vue
組件中的 data 必須是一個(gè)函數(shù),不能直接指向一個(gè)數(shù)據(jù)對(duì)象。
因此在組件中定義 data 數(shù)據(jù)節(jié)點(diǎn)時(shí),下面的方式是錯(cuò)誤的:
vue 規(guī)定:組件內(nèi)的 <style>
節(jié)點(diǎn)是可選的,開(kāi)發(fā)者可以在 <style>
節(jié)點(diǎn)中編寫(xiě)樣式美化當(dāng)前組件的 UI 結(jié)構(gòu)。
<script>
節(jié)點(diǎn)的基本結(jié)構(gòu)如下:
在 <style>
標(biāo)簽上添加 lang="less"
屬性,即可使用 less
語(yǔ)法編寫(xiě)組件的樣式:
1?? 通過(guò) components
注冊(cè)的是私有子組件;例如:在組件 A 的 components
節(jié)點(diǎn)下,注冊(cè)了組件 F。則組件 F 只能用在組件 A 中;不能被用在組件C 中。
2?? 在 vue 項(xiàng)目的 main.js
入口文件中,通過(guò) Vue.component()
方法,可以注冊(cè)全局組件。
代碼演示如下:
props
是組件的自定義屬性,在封裝通用組件的時(shí)候,合理地使用props
可以極大的提高組件的復(fù)用性!
語(yǔ)法演示如下:
1?? vue 規(guī)定:組件中封裝的自定義屬性是只讀的,程序員不能直接修改 props
的值。否則會(huì)直接報(bào)錯(cuò);
2?? 要想修改 props 的值,可以把 props
的值轉(zhuǎn)存到 data
中,因?yàn)?data
中的數(shù)據(jù)都是可讀可寫(xiě)的!
在聲明自定義屬性時(shí),可以通過(guò) default 來(lái)定義屬性的默認(rèn)值。示例代碼如下:
在聲明自定義屬性時(shí),可以通過(guò) type 來(lái)定義屬性的值類(lèi)型。示例代碼如下:
在聲明自定義屬性時(shí),可以通過(guò) required 選項(xiàng),將屬性設(shè)置為必填項(xiàng),強(qiáng)制用戶(hù)必須傳遞屬性的值。示例代碼如下:
1?? 默認(rèn)情況下,寫(xiě)在 .vue
組件中的樣式會(huì)全局生效,因此很容易造成多個(gè)組件之間的樣式?jīng)_突問(wèn)題。
2?? 導(dǎo)致組件之間樣式?jīng)_突的根本原因是:
單頁(yè)面應(yīng)用程序中,所有組件的 DOM 結(jié)構(gòu),都是基于唯一的 index.html 頁(yè)面進(jìn)行呈現(xiàn)的;
每個(gè)組件中的樣式,都會(huì)影響整個(gè) index.html 頁(yè)面中的 DOM 元素
為每個(gè)組件分配唯一的自定義屬性,在編寫(xiě)組件樣式時(shí),通過(guò)屬性選擇器來(lái)控制樣式的作用域,示例代碼如下:
為了提高開(kāi)發(fā)效率和開(kāi)發(fā)體驗(yàn),vue 為 style 節(jié)點(diǎn)提供了 scoped
屬性,從而防止組件之間的樣式?jīng)_突問(wèn)題:
如果給當(dāng)前組件的 style 節(jié)點(diǎn)添加了 scoped 屬性,則當(dāng)前組件的樣式對(duì)其子組件是不生效的。如果想讓某些樣式對(duì)子組件生效,可以使用 /deep/ 深度選擇器。
關(guān)于“Vue中的watch偵聽(tīng)器、計(jì)算屬性、Vue-cli和組件怎么使用”這篇文章的內(nèi)容就介紹到這里,感謝各位的閱讀!相信大家對(duì)“Vue中的watch偵聽(tīng)器、計(jì)算屬性、Vue-cli和組件怎么使用”知識(shí)都有一定的了解,大家如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀(guān)點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。