event事件详解-焦点事件、event对象、键盘事件、右键菜单事件

1、焦点事件

获取焦点事件onfocus \ 失去焦点事件 onblur

例子:输入框里的提示文字

<body>
    <input type="text" id="text1" value="请输入内容" />
    <script type="text/javascript">
        var oText=document.getElementById("text1");

        oText.onfocus=function(){
            if (this.value=='请输入内容') {
                this.value='';
            }
        }

        oText.onblur=function(){
            if (this.value=='') {
                this.value='请输入内容';
            }
        }   
    </script>
</body>

js中的三种方法:
event.focus(); //自动获取焦点
event.blur(); //自动失去焦点
event.select(); //全选文字

<body>
    <input type="text" id="text2" value="自动获取焦点" />
    <input type="text" id="text3" value="全选文字内容" />
    <script type="text/javascript">
        var oText2=document.getElementById("text2");
        var oText3=document.getElementById("text3");

        oText2.focus();
        oText2.blur();
        oText3.select();
    </script>
</body>

2、event对象

兼容写法: ev = ev || window.event

functin fn( ev ){
    var ev = ev || window.event;
}

标准ie/chrome:event是一个内置全局对象
ie:var event=null;
chrome: var event;

事件函数:事件调用的函数。事件对象必须在时间函数里面使用才有内容。

例子:随鼠标移动的div

<body>
    <div id="div1" style="width: 100px; height: 100px; background: #333333; position: absolute;"></div>
    <script type="text/javascript">
        var oDiv=document.getElementById("div1");

        document.onmousemove=function(ev){
            var ev= ev || window.event;
            var scrollTop=document.documentElement.scrollTop || document.body.scrollTop; //滚动条距离

            oDiv.style.left=ev.clientX+'px';
            oDiv.style.top=ev.clientY+scrollTop+'px';

        }
    </script>
</body>

3、键盘事件

onkeydown : 当键盘按键按下的时候触发
onkeyup : 当键盘按键抬起的时候触发
event.keyCode : 数字类型 键盘按键的值 键值
ctrlKey,shiftKey,altKey :当一个事件发生的时候,如果ctrl || shift || alt 是按下的状态,返回true,否则返回false

例子1:ctrl+enter键输出留言

<body>
    <input type="text" id="input1" />
    <ul id="ul1"></ul>  
    <script type="text/javascript">
        var oText=document.getElementById("input1");
        var oUl=document.getElementById("ul1");

        oText.onkeyup=function(ev){
            var ev = ev || window.event;

            if (this.value!='') {
                if (ev.keyCode==13 && ev.ctrlKey) {  //在按着ctrl键的时候敲enter键
                    var oLi=document.createElement('li');
                    oLi.innerHTML=this.value;

                    if (oUl.children[0]) {
                        oUl.insertBefore(oLi,oUl.children[0]);
                    }else{
                        oUl.appendChild(oLi);
                    }
                }
            }
        }
    </script>
</body>

例子2:键盘方向键控制div盒子的上下左右移动

<body>
    <div id="div1" style="width: 100px; height: 100px; background: orangered; position: absolute;"></div>
    <script type="text/javascript">
        var oDiv=document.getElementById("div1");
        document.onkeydown=function(ev){ //div不能接收键盘事件,用document
            var ev = ev || window.event;
            switch (ev.keyCode){
                case 37:
                    oDiv.style.left=oDiv.offsetLeft-10+'px';
                    break;
                case 38:
                    oDiv.style.top=oDiv.offsetTop-10+'px';
                    break;
                case 39:
                    oDiv.style.left=oDiv.offsetLeft+10+'px';
                    break;
                case 40:
                    oDiv.style.top=oDiv.offsetTop+10+'px';
                    break;  
            }
        }
    </script>
</body>

4、右键菜单事件
右键菜单:上下文菜单、环境菜单 oncontextmenu

例子:自定义右键菜单

 <body style="height: 3000px;">
    <div id="div1" style="width: 60px; height: 120px; background: #999; position: absolute; display: none;"></div>
    <script type="text/javascript">
        var oDiv=document.getElementById("div1");
        document.oncontextmenu=function(ev){
            var ev = ev || window.event;
            var scrollTop=document.documentElement.scrollTop || document.body.scrollTop;

            oDiv.style.display='block';
            oDiv.style.left=ev.clientX+'px';
            oDiv.style.top=ev.clientY+scrollTop+'px';
            return false;
        }
        document.onclick=function(){
            oDiv.style.display='none';
        }
    </script>
</body>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Vue中实现右键菜单展示和隐藏的事件可以通过以下步骤来实现: 1. 在Vue组件中,首先需要定义一个data属性,用于控制右键菜单的显示与隐藏,例如`isContextMenuVisible: false`。 2. 在需要显示右键菜单的元素上绑定右键单击事件,可以使用`@contextmenu`修饰符,例如`@contextmenu="showContextMenu"`。 3. 在对应的Vue组件中,定义一个`showContextMenu`方法来处理右键单击事件。在该方法中,可以通过event.preventDefault()来阻止默认的右键菜单弹出,然后设置`isContextMenuVisible`属性为`true`,即`this.isContextMenuVisible = true`。 4. 在Vue组件中,使用`v-show`或`v-if`指令来根据`isContextMenuVisible`属性的值决定是否显示右键菜单。例如: ``` <div class="context-menu" v-show="isContextMenuVisible"> <!-- 右键菜单内容 --> </div> ``` 5. 在Vue组件中,还需要绑定一个事件监听器,用于点击其他区域隐藏右键菜单。可以在Vue的`mounted`生命周期钩子函数中,在全局`document`对象上绑定`click`事件,并在事件处理程序中将`isContextMenuVisible`属性设置为`false`,即: ``` mounted() { document.addEventListener('click', this.hideContextMenu); }, methods: { hideContextMenu() { this.isContextMenuVisible = false; } } ``` 通过以上步骤,我们就可以在Vue中实现右键菜单的展示和隐藏事件了。当我们右键单击对应的元素时,右键菜单会显示出来;点击其他区域时,右键菜单会隐藏。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值