zoukankan      html  css  js  c++  java
  • mui---事件小结

    给单个HTML DOM绑定事件应使用原生js的addEventListener()方法

    格式:<js对象>.addEventListener('事件',<回调函数>)

    document.getElementById("button1").addEventListener('tap',function() {
        //...
    })

    格式:<jq对象>.on('事件',<回调函数>)

    $("#button1").on('click',function  () {
          alert(2);
    })

    注意:

    mui('选择器').on() 方法适合mui对象中的给多个子对象绑定事件,如果给单个对象绑定事件,不能使用

    mui('选择器').on('事件',<回调函数>)   (错误)

    mui('选择器').addEventListener('事件',<回调函数>)   (错误)

    给多个对象绑定事件使用mui().on()方法

    格式:mui('选择器').on('事件名','选择器',<回调函数>)

    mui(".mui-table-view").on('tap','a',function(){
        //...
    })

    触发自定义事件

    1、window监听自定义事件

    window.addEventListener('自定义事件名',function(e) {
        //e.detail.参数名可接受fire方法中传来的参数;
    });

    2、mui.fire触发自定义事件 

    mui.fire(webview对象,'自定义事件名',{key:value});

    完整的代码如下:

    a.html

    <!doctype html>
    <html>
    
        <head>
            <meta charset="UTF-8">
            <title></title>
            <meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no" />
            <link href="css/mui.min.css" rel="stylesheet" />
        </head>
    
        <body>
            <div id="div1">类型</div>
            <button id="button1" type="button" class="mui-btn mui-btn-blue">选择</button>
            <script src="js/mui.min.js"></script>
            <script type="text/javascript">
                mui.init();
                
                document.getElementById("button1").addEventListener('tap',function() {
                    mui.openWindow({
                        url:'b.html',
                        id:'b.html',
                        extras:{
                            pid:'a'
                        }//这整个的都属于b这个webview
                    })
                })
                window.addEventListener('getProductType',function(e) {
                    console.log('myevent');
                    document.getElementById("div1").innerText=e.detail.productType;
                });
            </script>
        </body>
    
    </html>

    b.html

    <!doctype html>
    <html>
    
        <head>
            <meta charset="UTF-8">
            <title></title>
            <meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no" />
            <link href="css/mui.min.css" rel="stylesheet" />
        </head>
    
        <body>
            <ul class="mui-table-view">
                    <li class="mui-table-view-cell">
                        <a class="mui-navigate-right">
                            白酒
                        </a>
                    </li>
                    <li class="mui-table-view-cell">
                        <a class="mui-navigate-right">
                            啤酒
                        </a>
                    </li>
                    <li class="mui-table-view-cell">
                        <a class="mui-navigate-right">
                             红酒
                        </a>
                    </li>
                </ul>
            <script src="js/mui.min.js"></script>
            <script type="text/javascript">
                mui.init();
                mui.plusReady(function() {
                    mui(".mui-table-view").on('tap','a',function(){
                        var mainView=plus.webview.currentWebview().opener();
                        console.log(plus.webview.currentWebview().pid);
                        mui.fire(mainView,'getProductType',{productType:this.innerText});
                        mui.back();
                    });
                })
            </script>
        </body>
    
    </html>
  • 相关阅读:
    arduino入门学习实现语音控制LED灯
    c# 实现串口编程-操作LED屏幕
    腾讯地图 获取各种情况的总距离
    js播放wav文件,兼容主流浏览器,兼容多浏览器
    工厂方法模式
    依赖倒转模式
    设计模式——开放封闭原则
    设计模式——单一职责原则
    策略模式
    简单工厂模式
  • 原文地址:https://www.cnblogs.com/beast-king/p/9417316.html
Copyright © 2011-2022 走看看