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

vue各種事件監(jiān)聽實(shí)例(小結(jié))

 更新時(shí)間:2020年06月24日 09:18:15   作者:理想的亡命之徒  
這篇文章主要介紹了vue各種事件監(jiān)聽實(shí)例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

計(jì)算屬性的Get方法和Set方法

看代碼說(shuō)話:

<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title>vue小練習(xí)</title>
</head>
<body>
  <div id="calc">
    <a v-cloak="">{{name}}</a>
  </div>
</body>
</html>
<script src="./js/vue.js"></script>
<script>
  let app = new Vue({
    el: '#calc'
    ,data: {
      counter:0
    }
    ,methods:{
    }
    ,computed: {
      name: {
        get: function(){
          console.log("得值");
          return 'AAAa';
        },
        set: function(){
          console.log("設(shè)值");
          
        }
      }
    }

  })

</script>

運(yùn)行后如下:


可以知道,在計(jì)算屬性對(duì)象中,里面定義一個(gè)name,通過(guò)定義name的set和get方法來(lái)對(duì)其值進(jìn)行設(shè)置和獲取,name獲得get函數(shù)return的值,name通過(guò)set函數(shù)進(jìn)行設(shè)置其值,或者說(shuō)改變他的值。從運(yùn)行圖可以看到,當(dāng)頁(yè)面加載的時(shí)候,當(dāng)我用到name的變量的時(shí)候,他會(huì)默認(rèn)執(zhí)行g(shù)et方法,當(dāng)我在控制臺(tái)中改變其值,他會(huì)默認(rèn)執(zhí)行set方法。

methods中函數(shù)執(zhí)行和computer計(jì)算的對(duì)比

這兩個(gè)方式都可以對(duì)值進(jìn)行拼接或者進(jìn)行復(fù)雜操作。那么哪個(gè)方法性能比較好呢?答案是computed,原因在于computed內(nèi)部有緩存??创a如下來(lái)計(jì)算分別調(diào)用了函數(shù)多少次:

<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title>vue小練習(xí)</title>
</head>
<body>
  <div id="calc">
    <a v-cloak="">{{name}}</a>
    <a v-cloak="">{{name}}</a>
    <a v-cloak="">{{name}}</a>
    <a v-cloak="">{{name}}</a>
    <hr>
    <a v-cloak="">{{a()}}</a>
    <a v-cloak="">{{a()}}</a>
    <a v-cloak="">{{a()}}</a>
    <a v-cloak="">{{a()}}</a>
  </div>
</body>
</html>
<script src="./js/vue.js"></script>
<script>
  let app = new Vue({
    el: '#calc'
    ,data: {
      counter:0
    }
    ,methods:{
      a :function(){
        console.log("執(zhí)行了一次函數(shù)");
        return 'AAAa';
      }
    }
    ,computed: {
      name: {
        get: function(){
          console.log("得值");
          console.log("執(zhí)行了一次 計(jì)算屬性的get方法");
          return 'AAAa';
        },
        set: function(){
          console.log("設(shè)值");
          
        }
      }
    }

  })

</script>

塊級(jí)作用域

那什么時(shí)候改用let,什么時(shí)候用const呢。是變量則用let,靜態(tài)常量則是const。

事件監(jiān)聽

上面已經(jīng)數(shù)說(shuō)了,標(biāo)簽點(diǎn)擊事件,下面我們來(lái)說(shuō)一下,v-on的語(yǔ)法糖,也就是類似v-bind的語(yǔ)法糖為:,, v-on的語(yǔ)法糖為@。代碼如下:

<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title>vue事件監(jiān)聽練習(xí)</title>
</head>
<body>
  <div id="calc">
    <a id="num">{{num}}</a>
    <button @click="add">+1</button>
  </div>
</body>
</html>
<script src="./js/vue.js"></script>
<script>
  let app = new Vue({
    el: '#calc'
    ,data: {
      num: 0
    }
    ,methods:{
      add: function(){
        this.num ++;
      }
    }
    ,computed: {
    }
  })

</script>

運(yùn)行效果如下:

**傳參情況,**代碼如下:

<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title>vue事件監(jiān)聽練習(xí)</title>
</head>
<body>
  <div id="calc">
    <a id="num">{{num}}</a>
    <button @click="add(num,$event)">*2</button>
  </div>
</body>
</html>
<script src="./js/vue.js"></script>
<script>
  let app = new Vue({
    el: '#calc'
    ,data: {
      num: 1
    }
    ,methods:{
      add: function(param,event){
        console.log(param);
        console.log(event);
        this.num = param * 2;
      }
    }
    ,computed: {
    }
  })

</script>

運(yùn)行如下:

監(jiān)聽獲得event對(duì)象,里面可以有點(diǎn)擊事件詳情,代碼如下:

說(shuō)明:

在上面的代碼中,

<button @click="add(num,$event)">*2</button>

num則被vue解釋成變量,$event帶有美元符號(hào)的修飾的變量,則被視為是事件。就是說(shuō),當(dāng)你在網(wǎng)頁(yè)上對(duì)鍵盤或者鼠標(biāo)有動(dòng)作的時(shí)候,他會(huì)生成事件,這個(gè)事件可以被檢測(cè)到,可以進(jìn)行傳遞。

修飾符阻止冒泡

在vue中,我們?nèi)绻麤](méi)有組織冒泡,那么請(qǐng)看是下面這樣:

<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title>vue事件監(jiān)聽練習(xí)</title>
</head>
<body>
  <div id="calc" @click="adda">
    <button @click="add">點(diǎn)我</button>
  </div>
</body>
</html>
<script src="./js/vue.js"></script>
<script>
  let app = new Vue({
    el: '#calc'
    ,data: {
      num: 1
    }
    ,methods:{
      add: function(){
        console.log("點(diǎn)擊了按鈕")
      }
      ,adda: function(){
        console.log("點(diǎn)擊了div")
      }
    }
    ,computed: {
    }
  })

</script>

運(yùn)行結(jié)果如下:

那么vue的阻止事件冒泡方法很簡(jiǎn)答,代碼修改如下:

<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title>vue事件監(jiān)聽練習(xí)</title>
</head>
<body>
  <div id="calc" @click="adda">
    <a >我不是按鈕</a>
    <button @click.stop="add" >點(diǎn)我</button>
  </div>
</body>
</html>
<script src="./js/vue.js"></script>
<script>
  let app = new Vue({
    el: '#calc'
    ,data: {
      num: 1
    }
    ,methods:{
      add: function(){
        console.log("點(diǎn)擊了按鈕")
      }
      ,adda: function(){
        console.log("點(diǎn)擊了div")
      }
    }
    ,computed: {
    }
  })

</script>

運(yùn)行如下:

vue回車事件獲取輸入框的值

代碼如下:

<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title>vue事件監(jiān)聽練習(xí)</title>
</head>
<body>
  <div id="calc" @click="adda">
    <a >我不是按鈕</a>
    <button @click.stop="add" >點(diǎn)我</button>
    <input type="text" @keyup.enter="console">
  </div>
</body>
</html>
<script src="./js/vue.js"></script>
<script>
  let app = new Vue({
    el: '#calc'
    ,data: {
      num: 1
    }
    ,methods:{
      add: function(){
        console.log("點(diǎn)擊了按鈕")
      }
      ,adda: function(){
        console.log("點(diǎn)擊了div")
      }
      ,console: function(event){
        console.log(event.target.value);
      }
    }
    ,computed: {
    }
  })

</script>

運(yùn)行效果如下:

通過(guò)使用@Keyup.enter事件來(lái)進(jìn)行對(duì)輸入框input的事件監(jiān)聽。

Vue的阻止表單提交的監(jiān)聽

通常情況下,默認(rèn)form的submit一點(diǎn)擊提交,就立即跳轉(zhuǎn),情況如下:

我們有時(shí)候希望點(diǎn)擊提交submit類型的input按鈕的時(shí)候,不要立即跳轉(zhuǎn)到action頁(yè)面,那么我們可以通過(guò)如下代碼來(lái)實(shí)現(xiàn):

<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title>vue事件監(jiān)聽練習(xí)</title>
</head>
<body>
  <div id="calc">
    <form action="www.erremall.top" @click.prevent="judge" >
      <input type="submit">
    </form>
  </div>
</body>
</html>
<script src="./js/vue.js"></script>
<script>
  let app = new Vue({
    el: '#calc'
    ,data: {
      num: 1
    }
    ,methods:{
      judge: function(){
        //在這里,對(duì)數(shù)據(jù)進(jìn)行校驗(yàn)。不先提交
        console.log("來(lái)了這里,沒(méi)有立即跳轉(zhuǎn)");
      }
    }
    ,computed: {
    }
  })

</script>

運(yùn)行效果如下:

到此這篇關(guān)于vue各種事件監(jiān)聽實(shí)例(小結(jié))的文章就介紹到這了,更多相關(guān)vue 事件監(jiān)聽內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • vue頁(yè)面使用阿里oss上傳功能的實(shí)例(二)

    vue頁(yè)面使用阿里oss上傳功能的實(shí)例(二)

    本篇文章主要介紹了vue頁(yè)面使用阿里oss上傳功能的實(shí)例(二),主要介紹OSS管理控制臺(tái)設(shè)置訪問(wèn)權(quán)限、角色等,有興趣的可以了解一下
    2017-08-08
  • 在Vue3中實(shí)現(xiàn)動(dòng)態(tài)路由的示例代碼

    在Vue3中實(shí)現(xiàn)動(dòng)態(tài)路由的示例代碼

    Vue3中的動(dòng)態(tài)路由是一種高級(jí)功能,它允許你在URL中包含變量,這些變量可以在組件內(nèi)部通過(guò)$route.params對(duì)象訪問(wèn),動(dòng)態(tài)路由通常用于構(gòu)建可配置性強(qiáng)、更具靈活性的應(yīng)用,本文詳細(xì)介紹了如何在vue3中實(shí)現(xiàn)動(dòng)態(tài)路由,需要的朋友可以參考下
    2024-07-07
  • Vite的createServer啟動(dòng)源碼解析

    Vite的createServer啟動(dòng)源碼解析

    這篇文章主要為大家介紹了Vite的createServer啟動(dòng)源碼解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-09-09
  • vue按住shift鍵多選方式(以element框架的table為例)

    vue按住shift鍵多選方式(以element框架的table為例)

    這篇文章主要介紹了vue按住shift鍵多選方式(以element框架的table為例),具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • vue計(jì)算屬性computed的使用方法示例

    vue計(jì)算屬性computed的使用方法示例

    這篇文章主要介紹了vue計(jì)算屬性computed的使用方法,結(jié)合實(shí)例形式分析了vue計(jì)算屬性computed的基本用法及相關(guān)操作注意事項(xiàng),需要的朋友可以參考下
    2019-03-03
  • vue操作dom并為dom增加點(diǎn)擊事件方式

    vue操作dom并為dom增加點(diǎn)擊事件方式

    這篇文章主要介紹了vue操作dom并為dom增加點(diǎn)擊事件方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-04-04
  • Vue利用廣度優(yōu)先搜索實(shí)現(xiàn)watch

    Vue利用廣度優(yōu)先搜索實(shí)現(xiàn)watch

    這篇文章主要為大家學(xué)習(xí)介紹了Vue如何利用廣度優(yōu)先搜索實(shí)現(xiàn)watch(有意思),文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2023-08-08
  • vue2.x引入threejs的實(shí)例代碼

    vue2.x引入threejs的實(shí)例代碼

    這篇文章主要介紹了vue2.x引入threejs,如果在開發(fā)過(guò)程中出現(xiàn)threejs生成的canvas出現(xiàn)外邊框,只需要用css樣式修改,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2022-09-09
  • Vue 項(xiàng)目分環(huán)境打包的方法示例

    Vue 項(xiàng)目分環(huán)境打包的方法示例

    這篇文章主要介紹了Vue 項(xiàng)目分環(huán)境打包的方法示例,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-08-08
  • vue3中effect函數(shù)到底是什么詳解

    vue3中effect函數(shù)到底是什么詳解

    Effect幾乎是Vue3.0中最重要的一個(gè)功能了,計(jì)算屬性監(jiān)聽函數(shù)都是基于effect實(shí)現(xiàn)的,下面這篇文章主要給大家介紹了關(guān)于vue3中effect函數(shù)到底是什么的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-06-06

最新評(píng)論