美文网首页
vue实现点击其他地方隐藏div(事件冒泡)

vue实现点击其他地方隐藏div(事件冒泡)

作者: Hello杨先生 | 来源:发表于2019-12-06 12:26 被阅读0次

    vue实现点击其他地方隐藏div

    方法一:

    通过监听事件

    <pre style="margin-top: 0px; margin-bottom: 0px; white-space: pre-wrap; overflow-wrap: break-word; font-family: "Courier New" !important; font-size: 12px !important;">document.addEventListener('click',function(e){
    if(e.target.className!='usermessage'){
    that.userClick=false;
    }
    })</pre>

    方法二(比较好):

    给最外层的div加个点击事件 @click="userClick=false"

    给点击的元素上面加上:@click.stop="userClick=!userClick"

    方法三:

    <template>

    <div class="page" @click="hide">


    <button @click.stop="show">点击显示div</button>


    <div @click.stop>
    ...
    </div>

    </div>
    <template>

    <script>
    export default {
    methods:{
    show(){},
    hide(){}
    }

    }
    </script>

    总结:

    通过vue.js 事件的.stop修饰符可以阻止事件继续冒泡传播,也可以使用原生js事件的event.stopPropagation()方法。
    通过向指定的div添加.stop,可以实现只有点击非该div内的元素时,才会往上冒泡至page,从而实现点击其他地方隐藏div。
    要向触发显示div的按钮添加.stop,否则一点击按钮,触发show()之后传播到page,立马就会触发hide(),div就无法显示。

    复制过来的
    这是原网页
    https://www.cnblogs.com/wasbg/p/11395611.html

    相关文章

      网友评论

          本文标题:vue实现点击其他地方隐藏div(事件冒泡)

          本文链接:https://www.haomeiwen.com/subject/gnasgctx.html