掃二維碼與項目經(jīng)理溝通
我們在微信上24小時期待你的聲音
解答本文疑問/技術(shù)咨詢/運(yùn)營咨詢/技術(shù)建議/互聯(lián)網(wǎng)交流
在學(xué)習(xí)之前,我們先通過引入JS文件的方式快速初始化一個 Vue 項目,首先我們先打開 VsCode 編輯器,具體步驟如下:

創(chuàng)新互聯(lián)建站是專業(yè)的觀山湖網(wǎng)站建設(shè)公司,觀山湖接單;提供成都網(wǎng)站設(shè)計、網(wǎng)站建設(shè)、外貿(mào)網(wǎng)站建設(shè),網(wǎng)頁設(shè)計,網(wǎng)站設(shè)計,建網(wǎng)站,PHP網(wǎng)站建設(shè)等專業(yè)做網(wǎng)站服務(wù);采用PHP框架,可快速的進(jìn)行觀山湖網(wǎng)站開發(fā)網(wǎng)頁制作和功能擴(kuò)展;專業(yè)做搜索引擎喜愛的網(wǎng)站,專業(yè)的做網(wǎng)站團(tuán)隊,希望更多企業(yè)前來合作!
新建一個文件夾。
新建index.html、style.css 和 index.js 文件。
新建個lib目錄,把下載好的 vue.global.js 文件放在這個目錄下(下載地址:https://unpkg.com/[email protected]/dist/vue.global.js)。
完成后的目錄結(jié)構(gòu)如下:
--- index.html
--- index.js
--- lib
---vue.global.js
--- style.css然后回到 index.html 做一些代碼編寫工作:
Vue項目初始化
接下來回到 index.js 文件初始化 vue 實例,掛載到 id 等于 app 的實例中,代碼如下:
const app = Vue.createApp();
app.mount("#app");到這里一個簡單的 Vue3 項目就創(chuàng)建完了,接下來我們進(jìn)入 data() 函數(shù)的學(xué)習(xí)。
在 Vue.js 中,data 函數(shù)用于定義組件實例的狀態(tài)。組件實例中定義的數(shù)據(jù)可以在模板中使用,也可以在組件的 JavaScript 邏輯中使用。
下面是一個例子,該組件有一個名為 message 的 data 屬性:
{{ message }}
在上面的例子中,data 函數(shù)返回了一個對象,該對象中有一個名為 message 的屬性。在模板中,可以使用 {{ message }} 來顯示這個屬性的值。
注意,data 屬性必須是函數(shù),這是固定用法。如果 data 屬性是一個普通對象,那么所有組件實例將共享同一個數(shù)據(jù)對象,在多個組件實例中使用同一個 data 對象將會導(dǎo)致問題。
另外,組件實例中定義的數(shù)據(jù)屬性是響應(yīng)式的,這意味著如果數(shù)據(jù)屬性的值改變,那么對應(yīng)的模板中的內(nèi)容也將自動更新(響應(yīng)式機(jī)制,稍后會介紹)。
通過data函數(shù)返回的對象,組件內(nèi)部都能使用 this 訪問到,如:
在 Vue.js 中,data 函數(shù)用于定義組件實例的狀態(tài),返回的對象中的屬性可以是任意類型的值,包括:
例如:
data() {
return {
message: 'Hello, Vue!',
count: 0,
todos: [],
user: {
name: 'John Doe',
age: 30
},
print: function(){
console.log("data function")
}
}
},在上面的例子中, 定義了message,count,todos,user,print五個數(shù)據(jù),分別是字符串,數(shù)字,數(shù)組,對象,函數(shù)。
在 Vue 3 中,可以使用 setup() 函數(shù)來定義組件的邏輯和狀態(tài)。在 setup() 函數(shù)中,可以使用 reactive() 函數(shù)來創(chuàng)建一個響應(yīng)式對象,它可以用來存儲組件的狀態(tài)。下面是一個示例:
Vue 3 數(shù)據(jù)狀態(tài)示例
{{ message }}
當(dāng)你想要綁定一個鏈接的 href 屬性到 Vue 實例中的數(shù)據(jù)時,你可以這樣做:
Link這里的 v-bind:href 指令綁定了 Vue 實例中的 url 數(shù)據(jù)到鏈接的 href 屬性上。當(dāng) url 數(shù)據(jù)更新時,鏈接的 href 也會更新。
同樣也可以使用縮寫:
Link需要注意的是,當(dāng)你綁定一個數(shù)據(jù)到 href 時,確保你綁定的是完整的URL,不然可能會被瀏覽器理解成相對路徑。
在 Vue 中展示列表數(shù)據(jù)可以使用 v-for 指令。v-for 指令用于遍歷數(shù)組中的數(shù)據(jù)并將其渲染到頁面上。
假設(shè)你有一個名為 items 的數(shù)組,其中包含了要展示在頁面上的數(shù)據(jù),那么你可以在模板中使用 v-for 指令來遍歷 items 數(shù)組并將每一項數(shù)據(jù)渲染到頁面上。
例如:
- {{ item.name }}
當(dāng)你使用 v-for 指令來遍歷數(shù)組中的數(shù)據(jù)時,你需要在指令中指定兩個值:
在指令中你可以使用這兩個值來定義要渲染在頁面上的元素。在上面的例子中,我們使用了一個 li 標(biāo)簽來渲染每一項數(shù)據(jù),并在里面使用了一個插值表達(dá)式來展示每一項的 name。
在遍歷數(shù)組時,為了避免vue重復(fù)渲染,你需要給每一個元素賦予一個唯一標(biāo)識符。可以使用 v-bind 指令和 key 特性來為每一項綁定一個唯一的標(biāo)識符,比如上面的例子中用了每一項的 id 來標(biāo)識。
整體來說,使用 v-for 指令可以讓你很容易地在 Vue 中遍歷數(shù)組并將數(shù)據(jù)渲染到頁面上。
在真實項目中還會經(jīng)常使用 computed 和 methods 來獲取數(shù)據(jù)進(jìn)行展示, 也可以使用vuex進(jìn)行狀態(tài)管理。(在稍后的文章里會詳細(xì)介紹)
在 Vue 中一共有 4 種方式可以基于條件展示 Data 中的數(shù)據(jù)。
v-if 指令用于根據(jù)條件判斷是否渲染元素。當(dāng)條件為 true 時,元素會被渲染,否則元素不會被渲染。
{{ data }}
v-show 指令與 v-if 指令類似,也用于根據(jù)條件判斷是否渲染元素。唯一的區(qū)別是,v-show 指令會始終渲染元素,只是在條件為 false 時將元素隱藏。
{{ data }}
三元運(yùn)算符可以在模板中直接使用條件判斷并返回對應(yīng)的值,從而達(dá)到條件展示數(shù)據(jù)的目的.
{{showData ? data : "loading"}}
可以在 computed 里面進(jìn)行條件判斷,并返回對應(yīng)的數(shù)據(jù)。
{{computedData}}
這四種方法都可以在 Vue 中基于條件展示數(shù)據(jù)。
你可以根據(jù)自己的需求來選擇使用哪一種方法。
v-if指令和v-show的區(qū)別在于,v-if會在第一次加載的時候,真正的去除不需要的元素,而v-show只是用CSS來控制元素的顯示和隱藏。所以v-if會在第一次加載時對性能有影響,而v-show在第一次加載時不會對性能產(chǎn)生影響。
計算屬性 computed 可以在數(shù)據(jù)發(fā)生改變時自動更新,性能會比在模板中使用三元運(yùn)算符和方法好。

我們在微信上24小時期待你的聲音
解答本文疑問/技術(shù)咨詢/運(yùn)營咨詢/技術(shù)建議/互聯(lián)網(wǎng)交流