欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

關(guān)于Vue.js一些問題和思考學(xué)習(xí)筆記(1)

 更新時間:2016年12月02日 10:55:40   作者:小小滄海  
這篇文章主要為大家分享了關(guān)于Vue.js一些問題和思考的學(xué)習(xí)筆記,具有一定的參考價值,感興趣的小伙伴們可以參考一下

前言

本文不是Vue.js的教程,只是一邊看官網(wǎng)Vue的教程文檔一邊記錄并總結(jié)學(xué)習(xí)過程中遇到的一些問題和思考的筆記。

1、vue和avalon一樣,都不支持VM初始時不存在的屬性

而在Angular里是可以支持的,因?yàn)閍ngular采用臟檢查的方式實(shí)現(xiàn)雙向綁定,vue和avalon都是采用setter和getter實(shí)現(xiàn)雙向綁定

例,如下代碼在一秒后不會顯示出“xxcanghai”的字樣

<div id="app">
 <h1>{{obj.text}}</h1>
</div>

<script>
 var v = new Vue({
 el: '#app',
 data: {
 obj:{}
 }
 });
 setTimeout(function(){
 v.obj.text="xxcanghai";//無效
 },1000);
</script>

若給定初始值,則可生效,如下:

<div id="app">
 <h1>{{obj.text}}</h1>
</div>

<script>
 var v = new Vue({
 el: '#app',
 data: {
 obj:{
 text:"default Text" //給定初始值
 }
 }
 });
 setTimeout(function(){
 v.obj.text="xxcanghai";//有效
 },1000);
</script>

不過Vue其中比avalon好的一點(diǎn)是,Vue在只是對初始化時不存在的屬性賦值無效,但顯示是不會報錯的。而avalon則根本無法顯示,對于上述第一段代碼運(yùn)行都會報錯(不知道最新的avalon是否修改此問題)

好在vue中提供了$set方法來解決這種賦值失敗的問題,如下:

<div i<div id="app">
 <h1>{{obj.text}}</h1>
</div>

<script>
 var v = new Vue({
 el: '#app',
 data: {
 obj: {}
 }
 });
 setTimeout(function() {
 v.$set("obj.text", "xxcanghai");//有效
 }, 1000);
</script>

雖然這種采用字符串來表示變量名的方式會導(dǎo)致無法使用強(qiáng)類型的預(yù)編譯檢查(TypeScript),但也至少算能解決問題吧。

注意:Vue2.0已經(jīng)廢棄了vm.$set的用法,應(yīng)該使用Vm.set()全局方法。

2、input元素中屬性與v-model同時存在以屬性為優(yōu)先

如下代碼:當(dāng)文本框中的value屬性與v-model沖突時會以input的value屬性為優(yōu)先,并覆蓋v-model的屬性
最終console.log輸出的也是“inputText”

<div id="app">
 <input type="text" v-model="a" value="inputText">
</div>
<script>
 var v = new Vue({
 el: '#app',
 data: {
 a: "vueText"
 }
 });
 console.log(v.a);//inputText
</script>

對于復(fù)選框類型的input上述結(jié)論也同樣適用,如下:

<div id="app">
 <input type="checkbox" v-model="isCheck" checked>
</div>
<script>
 var v = new Vue({
 el: '#app',
 data: {
 isCheck: false
 }
 });
 console.log(v.isCheck);//true
</script>

復(fù)選框的v-model設(shè)定為false不選中,同時設(shè)定checked屬性選中,最終效果為以checked屬性優(yōu)先,復(fù)選框被選中,同時v.isCheck屬性被改寫為true。

3、VM中的函數(shù)放到data屬性和methods屬性中的區(qū)別,以及函數(shù)調(diào)用時帶括號與不帶括號的區(qū)別

Vue在實(shí)例化的時候有一個特殊的屬性即methods,我看官方文檔中把所有VM中的函數(shù)都放到methods屬性里面,經(jīng)測試把函數(shù)寫在data和methods中都可以正常運(yùn)行,那么兩者有何區(qū)別?
通過官方demo可知,在綁定函數(shù)的時候可以帶括號也可以不帶括號,對于有參數(shù)的函數(shù)那必須帶括號調(diào)用,但是對于無參函數(shù)帶括號調(diào)用與不帶括號調(diào)用的區(qū)別是什么? 以下測試:

<div id="app">
 <button @click="dataFn">1.dataFn</button> 
 <!--輸出:<button>,[MouseEvent]-->
 
 <button @click="dataFn()">2.dataFn()</button> 
 <!--輸出:Vue,[]-->
 
 <button @click="methodsFn">3.methodsFn</button> 
 <!--輸出:Vue,[MouseEvent]-->
 
 <button @click="methodsFn()">4.methodsFn()</button> 
 <!--輸出:Vue,[]-->
</div>
<script>
 var vm = new Vue({
 el: "#app",
 data: {
 dataFn: function() {
 console.log(this,arguments);
 }
 },
 methods: {
 methodsFn: function() {
 console.log(this,arguments);
 }
 }
 });
 //xxcanghai@博客園
</script>

通過上述代碼對比可以得到以下結(jié)論:

  • 若想要在事件響應(yīng)函數(shù)中獲得Event對象,那么事件綁定時不能加括號,參見上述1、3示例。
  • 若想在函數(shù)中this指向Vue實(shí)例化對象,函數(shù)調(diào)用時應(yīng)當(dāng)加括號。同時,所有在methods屬性中的函數(shù),無論如何調(diào)用,this都指向當(dāng)前Vue實(shí)例化對象。
  • 遂最終結(jié)論為:應(yīng)當(dāng)把所有VM中的函數(shù)都放在methods中,同時對于事件的綁定應(yīng)當(dāng)使用無括號方式。即上述示例3中為最優(yōu)方案。

PS:當(dāng)然你也可以使用vue內(nèi)置的$event來顯示的傳遞event對象,以保證函數(shù)寫在任何位置都可以正常使用this和event。

<div id="app">
 <button @click="dataFn($event)">5.dataFn($event)</button> 
 <!--輸出:Vue,[MouseEvent]-->
 
 <button @click="methodsFn($event)">6.methodsFn($event)</button> 
 <!--輸出:Vue,[MouseEvent]-->
</div>


相關(guān)筆記

Vue學(xué)習(xí)筆記-1(http://www.dbjr.com.cn/article/98869.htm)

Vue學(xué)習(xí)筆記-2(http://www.dbjr.com.cn/article/98878.htm)

本文已被整理到了《Vue.js前端組件學(xué)習(xí)教程》,歡迎大家學(xué)習(xí)閱讀。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • vue將時間戳轉(zhuǎn)換成自定義時間格式的方法

    vue將時間戳轉(zhuǎn)換成自定義時間格式的方法

    下面小編就為大家分享一篇vue將時間戳轉(zhuǎn)換成自定義時間格式的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-03-03
  • vue+vant 上傳圖片需要注意的地方

    vue+vant 上傳圖片需要注意的地方

    這篇文章主要介紹了vue+vant 上傳圖片需要注意的地方,幫助大家更好的理解和使用vue,感興趣的朋友可以了解下
    2021-01-01
  • vue-devtools 打開源碼位置實(shí)現(xiàn)過程

    vue-devtools 打開源碼位置實(shí)現(xiàn)過程

    這篇文章主要為大家介紹了vue-devtools 打開源碼位置實(shí)現(xiàn)過程詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-09-09
  • vue+canvas繪制時間軸的方法

    vue+canvas繪制時間軸的方法

    這篇文章主要為大家詳細(xì)介紹了vue+canvas繪制時間軸的方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-08-08
  • vue實(shí)現(xiàn)拖拽窗口功能

    vue實(shí)現(xiàn)拖拽窗口功能

    這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)拖拽窗口功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-04-04
  • vue中的插槽詳解

    vue中的插槽詳解

    這篇文章主要介紹了Vue中的插槽,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-10-10
  • vue導(dǎo)出html、word和pdf的實(shí)現(xiàn)代碼

    vue導(dǎo)出html、word和pdf的實(shí)現(xiàn)代碼

    這篇文章主要介紹了vue導(dǎo)出html、word和pdf的實(shí)現(xiàn)方法,文中完成了三種文件的導(dǎo)出但是還有很多種方法,小編就不給大家一一列舉了,需要的朋友可以參考下
    2018-07-07
  • 如何處理elementUI中表格多選框禁用的問題

    如何處理elementUI中表格多選框禁用的問題

    這篇文章主要介紹了如何處理elementUI中表格多選框禁用的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-09-09
  • Element InfiniteScroll無限滾動的具體使用方法

    Element InfiniteScroll無限滾動的具體使用方法

    這篇文章主要介紹了Element InfiniteScroll無限滾動的具體使用方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-07-07
  • vue圖片轉(zhuǎn)base64格式的方法示例

    vue圖片轉(zhuǎn)base64格式的方法示例

    對于前后端分離的項(xiàng)目,為了統(tǒng)一響應(yīng)參數(shù),需要將圖片轉(zhuǎn)換成base64的格式,下面這篇文章主要給大家介紹了關(guān)于vue圖片轉(zhuǎn)base64格式的相關(guān)資料,需要的朋友可以參考下
    2022-12-12

最新評論