Vue方法与事件处理器详解


Posted in Javascript onDecember 01, 2016

本文实例为大家分享了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 、space、 up 、down、 left 、right。

eg:

HTML如下:

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

JS代码:

<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: '人员管理系统'
  }, { 
  success:false,
  projectName: '管理系统'
  },{
  success:false,
  projectName: '假数据1'
  },{
  success:false,
  projectName: '假数据2'
  }, {
  success:false,
  projectName: '假数据3'
  }
 ],
 }
 }
}
</script>

页面最开始:

Vue方法与事件处理器详解

当你点击新增项目后:

Vue方法与事件处理器详解

在文本框中输入  “豆豆”后按回车键后页面

Vue方法与事件处理器详解

当你按回车键后触发  keyup.enter事件调saveProjectFun方法,在此方法中进行数据保存。

本文已被整理到了《Vue.js前端组件学习教程》,欢迎大家学习阅读。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
jquery移动listbox的值原理及代码
May 03 Javascript
简洁Ajax函数处理(示例代码)
Nov 15 Javascript
让html页面不缓存js的实现方法
Oct 31 Javascript
Jquery实现由下向上展开效果的例子
Dec 08 Javascript
手机开发必备技巧:javascript及CSS功能代码分享
May 25 Javascript
jQuery组件easyui对话框实现代码
Aug 25 Javascript
Javascript中this绑定的3种方法与比较
Oct 13 Javascript
微信开发 消息推送实现代码
Oct 21 Javascript
JavaScript中document.referrer的用法详解
Jul 04 Javascript
vue+elementUi图片上传组件使用详解
Aug 20 Javascript
解决layer弹出层msg的文字不显示的问题
Sep 11 Javascript
vue-cli基础配置及webpack配置修改的完整步骤
Oct 20 Javascript
简单理解vue中实例属性vm.$els
Dec 01 #Javascript
jsp 自动编译机制详细介绍
Dec 01 #Javascript
基于vue.js实现图片轮播效果
Dec 01 #Javascript
JQuery学习总结【一】
Dec 01 #Javascript
Vue.js第一天学习笔记(数据的双向绑定、常用指令)
Dec 01 #Javascript
jQuery 如何实现一个滑动按钮开关
Dec 01 #Javascript
有趣的bootstrap走动进度条
Dec 01 #Javascript
You might like
浅谈电磁辐射对健康的影响
2021/03/01 无线电
php的mail函数发送UTF-8编码中文邮件时标题乱码的解决办法
2015/10/20 PHP
PHP使用new StdClass()创建空对象的方法分析
2017/06/06 PHP
基于ThinkPHP5.0实现图片上传插件
2017/09/25 PHP
PHP实现的服务器一致性hash分布算法示例
2018/08/09 PHP
laravel框架使用极光推送消息操作示例
2020/02/15 PHP
使用js获取QueryString的方法小结
2010/02/28 Javascript
NodeJS的模块写法入门(实例代码)
2012/03/07 NodeJs
基于jQuery判断两个元素是否有重叠部分的代码
2012/07/25 Javascript
JavaScript页面模板库handlebars的简单用法
2015/03/02 Javascript
Servlet实现文件上传,可多文件上传示例
2016/12/05 Javascript
vue2.0嵌套路由实现豆瓣电影分页功能(附demo)
2017/03/13 Javascript
Angular 1.x个人使用的经验小结
2017/07/19 Javascript
详解vue-cli 接口代理配置
2017/12/13 Javascript
Node.js成为Web应用开发最佳选择的原因
2018/02/05 Javascript
vue单页应用在页面刷新时保留状态数据的方法
2018/09/21 Javascript
详解微信小程序之scroll-view的flex布局问题
2019/01/16 Javascript
基于vue-cli3和element实现登陆页面
2019/11/13 Javascript
angular inputNumber指令输入框只能输入数字的实现
2019/12/03 Javascript
python使用内存zipfile对象在内存中打包文件示例
2014/04/30 Python
Python中SOAP项目的介绍及其在web开发中的应用
2015/04/14 Python
Python使用MONGODB入门实例
2015/05/11 Python
Python 如何访问外围作用域中的变量
2016/09/11 Python
用生成器来改写直接返回列表的函数方法
2017/05/25 Python
利用Python查看目录中的文件示例详解
2017/08/28 Python
Python 装饰器实现DRY(不重复代码)原则
2018/03/05 Python
python如何求解两数的最大公约数
2018/09/27 Python
django 使用 PIL 压缩图片的例子
2019/08/16 Python
python处理RSTP视频流过程解析
2020/01/11 Python
基于HTML5的齿轮动画特效
2016/02/29 HTML / CSS
法人委托书
2014/07/31 职场文书
励志演讲稿大全
2014/08/21 职场文书
2016新年致辞
2015/08/01 职场文书
python 如何获取页面所有a标签下href的值
2021/05/06 Python
深入理解Pytorch微调torchvision模型
2021/11/11 Python
MySQL 分区表中分区键为什么必须是主键的一部分
2022/03/17 MySQL