Vue的基本知識你都了解嗎
1. Vue的基本知識
1.1 Vue的使用
- 可以導入Vue文件或者是通過CDN引入
- 想要讓Vue工作就必須要創(chuàng)建一個Vue的實例對象,并且配置對象
- 在真實的開發(fā)中只有一個Vue的實例,并且配合組件一起使用
1.2 插值語法
<div>
<h1>
Hello!{{name}} {{Date.now()}} {{address}}
</h1>
</div>
<script>
Vue.config.productionTip = false //阻止vue在生成時自動產生提示
//創(chuàng)建Vue實例
new Vue({
el:'#root', //el用于指定當前Vue實例為哪個容器服務,值通常為css選擇器字符串。
data:{ //data中用于存儲數據,數據供el所指定的容器去使用,值我們暫時先寫成一個對象。
name:'Tree',
address:'China'
}
})
</script>
注意點:
1.{ { xxx } } 這里的xxx要寫的是js表達式,并且它會自動讀取到data中所有的屬性
2.一旦data中的數據發(fā)生改變,那么頁面用帶該數據的地方也會自動更新
3.插值語法的功能:用于去解析標簽體內容,標簽體就是起始標簽和結束標簽中間的內容,例如:<h1> xxx </h1> xxx就是標簽體
4.要區(qū)分什么是js表達式?什么是js代碼?
1. 什么是js表達式?
表達式可以產生一個值或者返回一個值
(1) a = 1
(2) a+b
(3) Date.now() 函數
(4) x = Y ? 1 : 2
2. 什么是js代碼?(語句)
(1) if(){}
(2) for(){}
js表達式就是一種特殊的js代碼
1.3 v-bind(單向綁定)
? 指令語法有很多,下面例子只是其中一個 v-bind: ===> 可以簡寫為 :
? 加入該指令后 " " 里的內容就會變成js表達式,而不是字符串(這個知識點很重要后面使用的地方會很多)
? 該方法是解析標簽得屬性,指令的功能很強大可以解析標簽(例如:解析標簽體,標簽屬性,綁定事件)
<div class="wrapper">
<h1>你好啊!{{name}}</h1>
<hr>
<a :href="school.url">點擊進入{{school.name}}</a>
<a v-bind:href="school.url">點擊進入{{school.name}}</a>
</div>
<script>
Vue.config.productionTip = false
new Vue({
el:".wrapper",
data:{
name:"Tree",
school:{
name: "bilibili",
url:"https://www.bilibili.com/"
}
}
})
</script>
1.4 v-model(雙向綁定)
1.4.1 v-model和v-bind的區(qū)別
- v-bind(單項綁定):數據只能從data流向頁面
- v-model(雙向綁定):不僅數據從data流向頁面,而且可以從頁面流向data
- 雙向綁定一般用在表單類元素上面(input,select,含有value屬性值)
- 如果遇到像checkbox這種類型的沒有value值時,v-model/ v-bind 傳boolearn值可以去控制該類型的狀態(tài)
<div class="wrapper">
<!-- 普通寫法 -->
<!-- 單項數據綁定: <input type="text" v-bind:value="name"><br>
雙向數據綁定: <input type="text" v-model:value="name"> -->
<!-- 簡便寫法 -->
單項數據綁定: <input type="text" :value="name"><br>
雙向數據綁定: <input type="text" v-model="name">
</div>
<script>
Vue.config.productionTip = false
new Vue({
el:".wrapper",
data:{
name:"Hello"
}
})
</script>
1.4.2 v-model 簡單小例子
<div class="root">
<input type="text" v-model="message">
<p>{{message}}</p>
</div>
<script>
Vue.config.productionTip = false //阻止vue在生成時自動產生提示
new Vue({
el:".root",
data:{
message:'Hello! Vue'
}
})
</script>
1.4.3 v-model 收集表單案例
1.v-model的三個修飾符:
- v-model.trim: 去掉前后空格
- v-model.number:將收到的數據轉換為number類型
- v-model.lazy:表示當失去焦點的時候再接收數據
2.v-model收集的就是value的值
- 當input類型為radio,需要我們去手動配置一個value值
- 當input類型為checkbox,它返回的布爾值,根據情況進行是否配置value值
- 記住如果收集的是多個,屬性值要是一個空的數組
<div id="root">
<form @submit.prevent="demo"> <!-- 當點擊按鈕時,會有默認行為提交信息,刷新頁面-->
<!-- v-model.trim表示去掉前后空格 -->
賬號:<input type="text" v-model.trim="userinfo.account"><br><br>
密碼:<input type="password" v-model="userinfo.password"><br><br>
<!-- input類型的number是限制用戶的輸入,而v-model.number是將收到的數據轉換為number類型,二者配合使用 -->
年齡:<input type="number" v-model.number="userinfo.age"><br><br>
性別:
<!-- 對于單選項,我們通過取相同的名字來表示是一組的 -->
男<input type="radio" v-model="userinfo.sex" name="sex" value="男">
女<input type="radio" v-model="userinfo.sex" name="sex" value="女"><br><br>
愛好:
<input type="checkbox" v-model="userinfo.hobby" value="打籃球">打籃球
<input type="checkbox" v-model="userinfo.hobby" value="敲代碼">敲代碼
<input type="checkbox" v-model="userinfo.hobby" value="干飯">干飯
<br><br>
所屬校區(qū):
<select v-model="userinfo.address">
<option value="">請選擇地區(qū)</option>
<option value="北京">北京</option>
<option value="上海">上海</option>
<option value="廣州">廣州</option>
<option value="深圳">深圳</option>
</select><br><br>
<!-- v-model.lazy:表示當失去焦點的時候再接收數據 -->
其他信息:<textarea cols="20" rows="3" v-model.lazy="userinfo.other"></textarea>
<br><br>
<input type="checkbox" v-model="userinfo.agree">同意并接受
<a href="#" style="text-decoration: none;">《用戶協(xié)議》</a>
<br><br>
<button>提交</button>
</form>
</div>
<script>
Vue.config.productionTip = false
let vm = new Vue({
el: '#root',
data: {
userinfo:{
account:"",
password:"",
age:"",
sex:"",
hobby:[],
address:"",
other:"",
agree:""
},
},
methods: {
demo(){
console.log(JSON.stringify(this.userinfo));
}
},
})
</script>
1.5 理解MVVM

M
模型(Model) :data中的數據
V
視圖(View) :模板代碼(不是靜態(tài)頁面)
VM
viewModel: 視圖模型(Vue的實例)
對MVVM的理解:
MVVM 本質上即模型-視圖-視圖模型。模型model指的是后端傳遞的數據,視圖view指的是所看到的頁面。視圖模型viewModel是 mvvm 模式的核心,它是連接 view 和 model 的橋梁。它有兩個方向:
將模型轉化成視圖,即將后端傳遞的數據轉化成所看到的頁面。實現的方式是:數據綁定
將視圖轉化成模型,即將所看到的頁面轉化成后端的數據。實現的方式是:DOM 事件監(jiān)聽
這兩個方向都實現的,我們稱之為數據的雙向綁定
1.6 Object.defineProperty(重要)
Object.defineProperty
- 第一個參數:指定的對象
- 第二個參數:要添加的屬性名
- 第三個參數:配置項
<script>
let number = 20
Vue.config.productionTip = false //阻止默認提示
var person = {
name : "jack",
address : "hgs"
}
Object.defineProperty(person,"age",{
// value: 18 ,
// enumerable:true, 控制屬性是否能夠進行枚舉,默認值false
// writable:true, 控制屬性是否能夠被修改,默認值false
// configurable:true 控制屬性是否能夠被刪除,默認值fasle
// 上面屬于基本配置,下面get和set很重要
//當有人讀取person的age屬性時get函數(getter)就會被調用,返回的值就是age的值
get(){
console.log("讀取成功!");
return number
},
//當有人修改Person的age屬性時set函數(setter)就會被調用,修改后的值就會被獲取到value
set(value){
console.log("修改的值: "+value);
number = value
}
})
1.7 數據代理(重要)
自我對于數據代理的理解:
- 當創(chuàng)建vm實例對象后,它會在里面添加很多屬性,它會將
data的數據傳入到vm下的_data中去,并且把_data的數據利用Object.defineProperty也就是數據代理到vm中去通過getter和setter去讀/修改,這樣做的目的是方便寫代碼,直接{{name}},不用{{_data.name}}. - vue中的數據代理通過vm對象去代理data對象的屬性的操作給每一個添加到vm上的屬性,配置一個getter和setter通過getter和setter去操作data里的屬性
<div id="root">
<h1>Hello!{{_data.name}}</h1>
<h1>Hello!{{_data.address}}</h1>
<h1>Hello!{{name}}</h1>
<h1>Hello!{{address}}</h1>
</div>
<script>
Vue.config.productionTip = false //阻止默認的提示
var vm = new Vue({
el: '#root',
data: {
name:"Jack",
address:"China"
}
})
</script>
總結
以上就是今天要講的內容,本文僅僅簡單介紹了Vue的一些基本知識,希望對大家有幫助!
相關文章
vue中{{}},v-text和v-html區(qū)別與應用詳解
這篇文章主要介紹了vue中{{}},v-text和v-html區(qū)別與應用詳解,本篇文章通過簡要的案例,講解了該項技術的了解與使用,以下就是詳細內容,需要的朋友可以參考下2021-09-09
vue+element開發(fā)使用el-select不能回顯的處理方案
這篇文章主要介紹了vue+element開發(fā)使用el-select不能回顯的處理方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-07-07

