vue2.0的contextmenu右键弹出菜单的实例代码


Posted in Javascript onJuly 24, 2017

整理文档,搜刮出一个vue2.0的contextmenu右键弹出菜单的实例代码,稍微整理精简一下做下分享。

1.事情对象

<!DOCTYPE html>
<html>
<head>
  <title></title>
  <meta charset="utf-8">
  <script src="http://unpkg.com/vue/dist/vue.js"></script>

  <script type="text/javascript">
    window.onload = function(){
      var vm = new Vue({
        el:'#box',
        methods:{
          show:function(event){
            console.log(event);  //event  这个就是事件对象了
          }
        }
      });
    }
  </script>
</head>
<body>
  <div id="box">
    <input type="button" value="按钮" @click="show($event)"> 
  </div>
</body>
</html>

通过show($event)把事件对象传到方法里

2.事件冒泡

<!DOCTYPE html>
<html>
<head>
  <title></title>
  <meta charset="utf-8">
  <script src="http://unpkg.com/vue/dist/vue.js"></script>

  <script type="text/javascript">
    window.onload = function(){
      var vm = new Vue({
        el:'#box',
        methods:{
          show:function(){
            alert(1);
          },
          show1:function(){
            alert(2);
          }
        }
      });
    }
  </script>
</head>
<body>
  <div id="box">
    <div @click="show1()">
      <input type="button" value="按钮" @click="show()"> 
    </div>
  </div>
</body>
</html>

点击按钮的话他会,执行show ,show1方法,依次弹出1,2。

怎么来阻止

<1> 利用我们上面讲过的event对象:  event.cancelBubble = true;   //这种就阻止了

<!DOCTYPE html>
<html>
<head>
  <title></title>
  <meta charset="utf-8">
  <script src="http://unpkg.com/vue/dist/vue.js"></script>

  <script type="text/javascript">
    window.onload = function(){
      var vm = new Vue({
        el:'#box',
        methods:{
          show:function(event){
            alert(1);
            event.cancelBubble = true;
          },
          show1:function(){
            alert(2);
          }
        }
      });
    }
  </script>
</head>
<body>
  <div id="box">
    <div @click="show1()">
      <input type="button" value="按钮" @click="show($event)"> 
    </div>
  </div>
</body>
</html>

<2>利用vue的方法阻止冒泡:给HTML元素绑定click事件的时候,改为@click.stop="show()"

<!DOCTYPE html>
<html>
<head>
  <title></title>
  <meta charset="utf-8">
  <script src="http://unpkg.com/vue/dist/vue.js"></script>

  <script type="text/javascript">
    window.onload = function(){
      var vm = new Vue({
        el:'#box',
        methods:{
          show:function(event){
            alert(1);
            //event.cancelBubble = true;
          },
          show1:function(){
            alert(2);
          }
        }
      });
    }
  </script>
</head>
<body>
  <div id="box">
    <div @click="show1()">
      <input type="button" value="按钮" @click.stop="show()"> 
    </div>
  </div>
</body>
</html>

3.默认行为

比如contextmenu右键菜单

<!DOCTYPE html>
<html>
<head>
  <title></title>
  <meta charset="utf-8">
  <!-- // <script src="vue.js"></script> -->
  <script src="http://unpkg.com/vue/dist/vue.js"></script>

  <script type="text/javascript">
    window.onload = function(){
      var vm = new Vue({
        el:'#box',
        methods:{
          show:function(){
            alert(1);
          },
          show1:function(){
            alert(2);
          }
        }
      });
    }
  </script>
</head>
<body>
  <div id="box">
    <input type="button" value="按钮" @contextmenu="show()"> 
    <input type="button" value="按钮1" @contextmenu.prevent="show1()"> 

    <p>//按钮右击点下去会依次出现 弹窗 1, 还有右击的默认菜单</p>
    <p>//按钮1右击只出现 弹窗 2</p>
  </div>
</body>
</html>

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

Javascript 相关文章推荐
javascript动态改变img的src属性图片不显示的解决方法
Oct 20 Javascript
Javascript的并行运算实现代码
Nov 19 Javascript
javascript跨域方法、原理以及出现问题解决方法(详解)
Aug 06 Javascript
jQuery实现折叠、展开的菜单组效果代码
Sep 16 Javascript
localStorage的黑科技-js和css缓存机制
Feb 06 Javascript
浅谈原生JS实现jQuery的animate()动画示例
Mar 08 Javascript
AngularJS中$http的交互问题
Mar 29 Javascript
详解如何构建Angular项目目录结构
Jul 13 Javascript
js禁止Backspace键使浏览器后退的实现方法
Sep 01 Javascript
利用js给datalist或select动态添加option选项的方法
Jan 25 Javascript
vue实现form表单与table表格的数据关联功能示例
Jan 29 Javascript
Vue替代marquee标签超出宽度文字横向滚动效果
Dec 09 Javascript
关于vue-resource报错450的解决方案
Jul 24 #Javascript
JavaScript中的FileReader图片预览上传功能实现代码
Jul 24 #Javascript
react-router4 嵌套路由的使用方法
Jul 24 #Javascript
关于react-router的几种配置方式详解
Jul 24 #Javascript
简单实现js放大镜效果
Jul 24 #Javascript
Vue列表页渲染优化详解
Jul 24 #Javascript
javascript cookie的基本操作(添加和删除)
Jul 24 #Javascript
You might like
DOTA2 无惧惊涛骇浪 昆卡大型水友攻略
2020/04/20 DOTA
php下目前为目最全的CURL中文说明
2010/08/01 PHP
php循环table实现一行两列显示的方法
2015/06/04 PHP
php连接oracle数据库的核心步骤
2016/05/26 PHP
Laravel多域名下字段验证的方法
2019/04/04 PHP
Javascript算符的优先级介绍
2013/03/20 Javascript
jQuery中的val()示例应用
2014/02/26 Javascript
jQuery学习笔记之jQuery中的$
2015/01/19 Javascript
bootstrap与Jquery UI 按钮样式冲突的解决办法
2016/09/23 Javascript
bootstrap常用组件之头部导航实现代码
2017/04/20 Javascript
Vue自定义事件(详解)
2017/08/19 Javascript
利用纯js + transition动画实现移动端web轮播图详解
2017/09/10 Javascript
通过源码分析Vue的双向数据绑定详解
2017/09/24 Javascript
vue2.0实现音乐/视频播放进度条组件
2018/06/06 Javascript
解决layer.confirm选择完之后消息框不消失的问题
2019/09/16 Javascript
layui 上传文件_批量导入数据UI的方法
2019/09/23 Javascript
vue页面跳转实现页面缓存操作
2020/07/22 Javascript
vue实现前端列表多条件筛选
2020/10/26 Javascript
[11:12]2018DOTA2国际邀请赛寻真——绿色长城OpTic
2018/08/10 DOTA
解析Python中的变量、引用、拷贝和作用域的问题
2015/04/07 Python
Python处理字符串之isspace()方法的使用
2015/05/19 Python
python制作最美应用的爬虫
2015/10/28 Python
对python 通过ssh访问数据库的实例详解
2019/02/19 Python
浅析Python 引号、注释、字符串
2019/07/25 Python
Python使用Turtle模块绘制国旗的方法示例
2021/02/28 Python
Nike比利时官网:Nike.com (BE)
2019/02/07 全球购物
罗技美国官网:Logitech美国
2020/01/22 全球购物
计算机应用专业毕业生求职信
2013/10/24 职场文书
愚人节活动策划方案
2014/03/11 职场文书
霸王洗发水广告词
2014/03/14 职场文书
宪法宣传周工作方案
2014/05/26 职场文书
竞聘演讲稿怎么写
2014/08/28 职场文书
教育项目合作协议书格式
2014/10/17 职场文书
服务员岗位职责范本
2015/04/09 职场文书
贷款收入证明范本
2015/06/12 职场文书
SQL Server 中的事务介绍
2022/05/20 SQL Server