首頁  >  文章  >  web前端  >  Vue方法與事件處理器詳解

Vue方法與事件處理器詳解

高洛峰
高洛峰原創
2016-12-03 09:33:501328瀏覽

本文實例為大家分享了Vue方法與事件處理器的使用,供大家參考,具體內容如下

按鍵修飾符

在監聽鍵盤事件時,我們經常需要檢測 keyCode。 Vue.js 允許為v-on 添加按鍵修飾符:

<!-- 只有在 keyCode 是 13 时调用 vm.submit() -->
<input v-on:keyup.13="submit">

記住所有的keyCode 比較困難,Vue.js 為最常用的按鍵提供別名:

<!-- 同上 -->
<input v-on:keyup.enter="submit">
<!-- 缩写语法 -->
<input @keyup.enter="submit">

全部的按鍵別名:enter 、tab 、delete、 esc

<template>
<div class="home-body">
 <div class="project-all">
 <template v-for=&#39;project in projectData&#39;>
 <div class="name" v-on:click=&#39;successT($index)&#39; v-bind:class="{&#39;success&#39;:project.success}">{{project.projectName}}</div>
 </template>
 <div class="name" v-if=&#39;addp&#39; v-on:click=&#39;addproject&#39;>新增项目</div>
 <div class="name" v-if=&#39;!addp&#39;>
 <input type="text" class=&#39;name-input&#39; placeholder=&#39;请填写项目名称&#39; v-on:keyup.enter=&#39;saveProjectFun&#39; v-el:addProject>
 </div>
 <div class="name">
 <input type="text" class=&#39;name-input&#39; placeholder=&#39;esc&#39; v-on:keyup.esc=&#39;escFun&#39;>
 </div>
 <div class="name">
 <input type="text" class=&#39;name-input&#39; placeholder=&#39;delete&#39; v-on:keyup.delete=&#39;deleteFun&#39;>
 </div>
 <div class="name">
 <input type="text" class=&#39;name-input&#39; placeholder=&#39;space&#39; v-on:keyup.space=&#39;spaceFun&#39;>
 </div>
 <div class="name">
 <input type="text" class=&#39;name-input&#39; placeholder=&#39;up&#39; v-on:keyup.up=&#39;upFun&#39;>
 </div>
 <div class="name">
 <input type="text" class=&#39;name-input&#39; placeholder=&#39;down&#39; v-on:keyup.down=&#39;downFun&#39;>
 </div>
 <div class="name">
 <input type="text" class=&#39;name-input&#39; placeholder=&#39;left&#39; v-on:keyup.left=&#39;leftFun&#39;>
 </div>
 <div class="name"> 
 <input type="text" class=&#39;name-input&#39; placeholder=&#39;right&#39; v-on:keyup.right=&#39;rightFun&#39;>
 </div>
 </div>
</div>
</template>

全部的按鍵別名:enter 、tab 、delete、 esc
<script>
export default {
 components: {
 
 },
 ready: function() {
  
 },
 methods: {
 //当你选种某个项目时,将其success属性改为true,为其class添加 success 
 successT:function(index){
 this.projectData.forEach(function(item){
 item.success=false;
 });
 this.projectData[index].success=true;
 },
 //点击添加项目后让其不显示
 addproject:function(){
 this.addp=false;
 }, 
 //当用户按回车后,保存添加的项目
 saveProjectFun:function(){
 var obj={}
 obj.success=false;
 let name=this.$els.addproject.value;
 obj.projectName=name.replace(/\s+/g,""); 
 this.projectData.push(obj);
 this.addp=true;
 },
 escFun:function(){
 alert("esc");
 },
 deleteFun:function(){
 alert("delete");
 },
 spaceFun:function(){
 alert("space空格键");
 },
 upFun:function(){
 alert("up");
 },
 downFun:function(){
 alert("down");
 },
 leftFun:function(){
 alert("left");
 },
 rightFun:function(){
 alert("right");
 }
 },
 data() {
 return {
 addp:true,//是否显示添加项目
 projectData:[{
  success:false,
  projectName: &#39;人员管理系统&#39;
  }, { 
  success:false,
  projectName: &#39;管理系统&#39;
  },{
  success:false,
  projectName: &#39;假数据1&#39;
  },{
  success:false,
  projectName: &#39;假数据2&#39;
  }, {
  success:false,
  projectName: &#39;假数据3&#39;
  }
 ],
 }
 }
}
</script>

全部的按鍵別名:enter 、tab 、delete、 escrrreee 、space、 up 、down、 left 、right。

eg:

HTML如下:

rrreee

JS代碼:

rrreee

頁面最開始:Vue方法與事件處理器詳解

Vue方法與事件處理器詳解豆框按下回車鍵後頁面

Vue方法與事件處理器詳解當你按下回車鍵後觸發  keyup.enter事件調saveProjectFun方法,在此方法中進行資料儲存。

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn