zoukankan      html  css  js  c++  java
  • weui 多网页切换效果分析

    weui的文档写的不怎么详尽,简单的来讲WeUI 为微信 Web 服务量身设计的h5框架。

    WeUI是一套同微信原生视觉体验一致的基础样式库,由微信官方设计团队为微信 Web 开发量身设计,可以令用户的使用感知更加统一。包含button、cell、dialog、 progress、 toast、article、icon等各式元素。

    严格的讲它是一个css库。算一个精简的库。

    如果要用jQuery开发的话,head部分,需要加载如下信息:

    <head>
            <meta charset="UTF-8">
            <meta name="viewport" content="width=device-width,initial-scale=1,user-scalable=0" />
            <title>我的</title>
             <link rel="stylesheet" href="https://cdn.bootcss.com/weui/1.1.0/style/weui.min.css" />   //weui的压缩版css
             <link rel="stylesheet" href="https://cdn.bootcss.com/jquery-weui/0.8.0/css/jquery-weui.min.css">   //jQuery weui的压缩版css,因为这个UI会提供比较多的插件
            <link rel="stylesheet" href="../css/example.css"/>    //weui 官方demo提供的css
            <link rel="stylesheet" type="text/css" href="../css/jiaj.css" />    //我们实际场景使用的css
            <script src="../js/libs/storage.js"></script>    //我们开发中需要用到的storage方法
            <script src="../js/config.js"></script>    //我们开发中需要用到的服务器配置文件
            <script src="../js/interface.js"></script>   //我们开发中需要使用到的接口文件
        </head>

    body中根据官方文档,需要给body添加属性ontouchstart。

    多页操作的demo模板:

    <script type="text/html" id="tpl_myDoctor">   //每个模板id对应body中a标签的id,tpi_是模板id的前缀
               <div class="page">   //每个模板内容都要放在page里
                    <!--医生列表-->
                    <div class="weui-cells">
                        <div class="weui-panel__bd">
                            <div class="weui-media-box weui-media-box_appmsg">
                                <div class="weui-media-box__hd">
                                    <img class="weui-media-box__thumb" src="../img/doctor/55.jpg" alt="">
                                </div>
                                <div class="weui-media-box__bd">
                                    <h4 class="weui-media-box__title">潘仁和</h4>
                                    <p class="weui-media-box__desc">骨科</p>
                                    <p class="weui-media-box__desc">上海交通大学医学院附属瑞金医院</p>
                                </div>
                                <div class="weui_jia_cell_ft"></div>
                            </div>
                        </div>
                    </div>
                    <div class="weui-cells">
                        <div class="weui-panel__bd">
                            <div class="weui-media-box weui-media-box_appmsg">
                                <div class="weui-media-box__hd">
                                    <img class="weui-media-box__thumb" src="../img/doctor/55.jpg" alt="">
                                </div>
                                <div class="weui-media-box__bd">
                                    <h4 class="weui-media-box__title">潘仁和</h4>
                                    <p class="weui-media-box__desc">骨科</p>
                                    <p class="weui-media-box__desc">上海交通大学医学院附属瑞金医院</p>
                                </div>
                                <div class="weui_jia_cell_ft"></div>
                            </div>
                        </div>
                    </div>
                </div>
            </script>

    我们再看模板页面对应在body中的a标签:

    <body ontouchstart>   //wap上要触发按钮的active态,必须触发ontouchstart事件,可以在body上加上ontouchstart 全局触发
        <div class="container js_container">    //class 为 js_container,当触发点击事件时,实际上是在点击js_container
              <div class="page">
                    //这里是定义与响应模板内容的
                    
                    //以cell为我的医生为例
                    <div class="weui-cells">
                        <a href="javascript:;" class="weui-cell weui-cell_access js_cell" data-id="myDoctor">   //当点击这个a标签时,触发ontouchstart的js_container,会把class为js_cell绑定到这个触发事件上
                            <div class="weui-cell__bd">
                                <p>我的医生</p>
                            </div>
                            <div class="weui-cell__ft">
                            </div>
                        </a>
                    </div>
      
              </div>
        </div>
        <script src="https://res.wx.qq.com/open/libs/zepto/1.1.6/zepto.js"></script>   
        <script src="../js/libs/example.js"></script>   //官方提供的页面切换js
        <script src="https://res.wx.qq.com/open/libs/weuijs/1.0.0/weui.min.js"></script>   //weui js
            <!--tabbar-->
        <script type="text/javascript" src="../js/doctor/tab.js"></script>
    </body>

     凡跳转网页的效果定义与响应,给a标签添加:

    <a class="weui_cell js_cell" href="javascript:;" data-id="button">
        <span class="weui_cell_hd">
          <img src="/images/icon_nav_button.png" class="icon_nav" alt=""></span>
        <div class="weui_cell_bd weui_cell_primary">
            <p>Button</p>
        </div>
        <div class="weui_cell_ft">
        </div>
    </a>
    • class="weui_cell js_cell"
    • data-id="button"
    • href="javascript:;"
    // page stack
        var stack = [];
        var $container = $('.js_container');
        $container.on('click', '.js_cell[data-id]', function () {
            var id = $(this).data('id');
            go(id);
        });

    头几行,定义了一个stack,我们想一下那个推进来的效果,

    • 默认显示,为栈的第一个元素
    • 如果push进来就,stack里push一个,设置为当前显示的
    • 如果点击返回呢,stack里pop出去最后一个,设置上一个为显示的
    • 如果返回了栈顶,点返回就没效果了

    这里的click事件,它的事件是.js_cell[data-id]

    也就是class=js_cell,并且有data-id属性。

    对比一下button的按钮

    <a class="weui_cell js_cell" href="javascript:;" data-id="button">

    如此,大概你就该明白了。

    那么事件里面是

    var id = $(this).data('id');
    go(id);

    就用button这个例子讲,这个id应该是data-id="button"里的button,对吧?

    然后go就跳转了,也就是push的效果应该是它弄的

    function go(id){
        var $tpl = $($('#tpl_' + id).html()).addClass('slideIn').addClass(id);
        $container.append($tpl);
        stack.push($tpl);
        // why not use `history.pushState`, https://github.com/weui/weui/issues/26
        //history.pushState({id: id}, '', '#' + id);
        location.hash = '#' + id;
    
        $($tpl).on('webkitAnimationEnd', function (){
            $(this).removeClass('slideIn');
        }).on('animationend', function (){
            $(this).removeClass('slideIn');
        });
        // tooltips
        if (id == 'cell') {
            $('.js_tooltips').show();
            setTimeout(function (){
                $('.js_tooltips').hide();
            }, 3000);
        }
    }

    看一下源码

    • $container.append($tpl);是dom元素插入
    • stack.push($tpl); 视图栈压入最新的
    • location.hash = '#' + id;是pushstate更改url地址
    • 其他就是动画或者根据id干点坏事了

    稍微注意一下:我们push的页面从哪里来的?

     var $tpl = $($('#tpl_' + id).html()).addClass('slideIn').addClass(id);
     $container.append($tpl);

    我们知道id是data-id="button"里的button,也就是说我们要根据id=“tpl_button”来找模板里的html。

    想想我们之前是不是拷贝了一个这样的模板?

    ok,只要是class=js_cell,并且有data-id属性的就会触发点击时间,根据tpl_button里的内容显示(push)。

    这是push,那么返回pop呢?

    // location.hash = '#hash1' 和点击后退都会触发`hashchange`,这个demo页面只关心后退
    $(window).on('hashchange', function (e) {
        if (/#.+/gi.test(e.newURL)) {
            return;
        }
        var $top = stack.pop();
        if (!$top) {
            return;
        }
        $top.addClass('slideOut').on('animationend', function () {
            $top.remove();
        }).on('webkitAnimationEnd', function () {
            $top.remove();
        });
    });

    ocation.hash变了

    • var $top = stack.pop();很明显出栈了
    • if (!$top) {return;} 是如果栈顶,不做操作
    • 然后处理$top,然后出栈的视图移除掉

    最外面的视图移除了,很明显就是上一个视图显示了。

    so,原理就是这么简单.

    下面是全部的代码:

    <!DOCTYPE html>
    <html>
        <head>
            <meta charset="UTF-8">
            <meta name="viewport" content="width=device-width,initial-scale=1,user-scalable=0" />
            <title>患者我的</title>
             <link rel="stylesheet" href="https://cdn.bootcss.com/weui/1.1.0/style/weui.min.css" />
             <link rel="stylesheet" href="https://cdn.bootcss.com/jquery-weui/0.8.0/css/jquery-weui.min.css">
            <link rel="stylesheet" href="../css/example.css"/>
            <link rel="stylesheet" type="text/css" href="../css/jiaj.css" />
            <script src="../js/libs/storage.js"></script>
            <script src="../js/config.js"></script>
            <script src="../js/interface.js"></script>
        </head>
        <body ontouchstart>
            <div class="container js_container">
                <div class="page">
                    <!--头像-->
                    <div class="weui-jiaj-panel">
                        <div class="weui-jia-cell-column-center">
                            <img src="../img/doctor/55.jpg" alt="代表头像" class="weui-jiaj-img" />
                            <h4 class="weui-media-box__title">礼拜五</h4>
                        </div>
                    </div>
                    <!--帮助多少人-->
                    <div class="weui-jiaj-panel">
                        <div class="weui-jia-cell-row">
                            <h4 class="weui-jiaj-media-doctor-title-gray">共问诊</h4>
                            <h2 class="weui-media-box__title weui-jiaj-media-doctor-title">1</h2>
                            <h4 class="weui-media-jiaj-title-gray"></h4>
                        </div>
                    </div>
                    
                    <div class="weui-cells">
                        <a href="javascript:;" class="weui-cell weui-cell_access js_cell" data-id="myDoctor">
                            <div class="weui-cell__bd">
                                <p>我的医生</p>
                            </div>
                            <div class="weui-cell__ft">
                            </div>
                        </a>
                    </div>
                    
                    <div class="weui-cells">
                        <a href="" class="weui-cell weui-cell_access">
                            <div class="weui-cell__bd">
                                <p>我的提问</p>
                            </div>
                            <div class="weui-cell__ft">
                            </div>
                        </a>
                        <a href="" class="weui-cell weui-cell_access">
                            <div class="weui-cell__bd">
                                <p>我看过的答案</p>
                            </div>
                            <div class="weui-cell__ft">
                            </div>
                        </a>
                    </div>
                    
                    <div class="weui-cells">
                        <a href="" class="weui-cell weui-cell_access">
                            <div class="weui-cell__bd">
                                <p>我的信息</p>
                            </div>
                            <div class="weui-cell__ft">
                            </div>
                        </a>
                        <a href="" class="weui-cell weui-cell_access">
                            <div class="weui-cell__bd">
                                <p>修改手机号</p>
                            </div>
                            <div class="weui-cell__ft">
                                13918185896
                            </div>
                        </a>
                        <a href="" class="weui-cell weui-cell_access">
                            <div class="weui-cell__bd">
                                <p>扫一扫</p>
                            </div>
                            <div class="weui-cell__ft">
                            </div>
                        </a>
                    </div>
                    
                    <div class="weui-cells">
                        <a href="" class="weui-cell weui-cell_access">
                            <div class="weui-cell__bd">
                                <p>我的钱包</p>
                            </div>
                            <div class="weui-cell__ft">
                            </div>
                        </a>
                    </div>
                    <!--底部菜单-->
                    <div class="weui-tabbar" style="height: 45px;position: fixed;">
                        <li class="weui-navbar__item weui-bar__item_on">发现</li>
                        <li class="weui-navbar__item">问医生</li>
                        <li class="weui-navbar__item">我的</li>
                    </div>
                </div>
            </div>
            <!--医生列表模板-->
            <script type="text/html" id="tpl_myDoctor">
               <div class="page">
                    <!--医生列表-->
                    <div class="weui-cells">
                        <div class="weui-panel__bd">
                            <div class="weui-media-box weui-media-box_appmsg">
                                <div class="weui-media-box__hd">
                                    <img class="weui-media-box__thumb" src="../img/doctor/55.jpg" alt="">
                                </div>
                                <div class="weui-media-box__bd">
                                    <h4 class="weui-media-box__title">潘仁和</h4>
                                    <p class="weui-media-box__desc">骨科</p>
                                    <p class="weui-media-box__desc">上海交通大学医学院附属瑞金医院</p>
                                </div>
                                <div class="weui_jia_cell_ft"></div>
                            </div>
                        </div>
                    </div>
                    <div class="weui-cells">
                        <div class="weui-panel__bd">
                            <div class="weui-media-box weui-media-box_appmsg">
                                <div class="weui-media-box__hd">
                                    <img class="weui-media-box__thumb" src="../img/doctor/55.jpg" alt="">
                                </div>
                                <div class="weui-media-box__bd">
                                    <h4 class="weui-media-box__title">潘仁和</h4>
                                    <p class="weui-media-box__desc">骨科</p>
                                    <p class="weui-media-box__desc">上海交通大学医学院附属瑞金医院</p>
                                </div>
                                <div class="weui_jia_cell_ft"></div>
                            </div>
                        </div>
                    </div>
                </div>
            </script>
            <script src="https://res.wx.qq.com/open/libs/zepto/1.1.6/zepto.js"></script>
            <script src="../js/libs/example.js"></script>
            <script src="https://res.wx.qq.com/open/libs/weuijs/1.0.0/weui.min.js"></script>
            <!--tabbar-->
            <script type="text/javascript" src="../js/doctor/tab.js"></script>
        </body>
    </html>

    效果国A  <->  B:

    官方切换效果js:

    /**
     * Created by jfengjiang on 2015/9/11.
     */
    
    $(function () {
        // page stack
        var stack = [];
        var $container = $('.js_container');
        //这里的click事件,它的事件是.js_cell[data-id],也就是class=js_cell,并且有data-id属性
        $container.on('click', '.js_cell[data-id]', function () {
            //用button这个例子讲,这个id应该是data-id="button"里的button
            //然后go就跳转了,也就是push的效果应该是它弄的
            var id = $(this).data('id');
            go(id);
        });
    
        //返回页方法
        //location.hash = '#hash1' 和点击后退都会触发`hashchange`,这里操作面的后退操作
        //location.hash变了
        $(window).on('hashchange', function (e) {
            if (/#.+/gi.test(e.newURL)) {
                return;
            }
            //var $top = stack.pop();很明显出栈了
            var $top = stack.pop();
            //if (!$top) {return;} 是如果栈顶,不做操作
            if (!$top) {
                return;
            }
            //给$top添加或删除页面动画的css
            $top.addClass('slideOut').on('animationend', function () {
                $top.remove();
            }).on('webkitAnimationEnd', function () {
                $top.remove();
            });
        });
    
    
        //跳转页 方法
        function go(id){
            //push的页面从哪里来呢?
            //id是data-id="button"里的button,也就是说我们要根据id=“tpl_button”来找模板里的html。
            //只要是class=js_cell,并且有data-id属性的就会触发点击时间,根据tpl_button里的内容显示(push)
            //这就是push,跳转到子页的方法
            var $tpl = $($('#tpl_' + id).html()).addClass('slideIn').addClass(id);
            //$container.append($tpl);是dom元素插入
            $container.append($tpl);
            //stack.push($tpl); 视图栈中push最新的页面
            stack.push($tpl);
            //location.hash = '#' + id;是pushstate更改url地址
            location.hash = '#' + id;
            
            //下面是页面的动画而添加或删除的class
            $($tpl).on('webkitAnimationEnd', function (){
                $(this).removeClass('slideIn');
            }).on('animationend', function (){
                $(this).removeClass('slideIn');
            });
            // 消息提醒
            if (id == 'cell') {
                $('.js_tooltips').show();
                setTimeout(function (){
                    $('.js_tooltips').hide();
                }, 3000);
            }
        }
    
        if (/#.*/gi.test(location.href)) {
            go(location.hash.slice(1));
        }
    
        // toast
        $container.on('click', '#showToast', function () {
            $('#toast').show();
            setTimeout(function () {
                $('#toast').hide();
            }, 5000);
        });
        $container.on('click', '#showLoadingToast', function () {
            $('#loadingToast').show();
            setTimeout(function () {
                $('#loadingToast').hide();
            }, 5000);
        });
    
        $container.on('click', '#showDialog1', function () {
            $('#dialog1').show();
            $('#dialog1').find('.weui_btn_dialog').on('click', function () {
                $('#dialog1').hide();
            });
        });
        $container.on('click', '#showDialog2', function () {
            $('#dialog2').show();
            $('#dialog2').find('.weui_btn_dialog').on('click', function () {
                $('#dialog2').hide();
            });
        })
    });

    参考链接:

    http://i5ting.github.io/weui-practice/#1

  • 相关阅读:
    模拟循环单击事件实现layout中间panel全屏
    easyui tree自定义属性用法
    jquery给动态添加的dom元素绑定事件
    基于easyui fom分组插件
    ubuntu adb 安装
    vim状态保存跟恢复
    ubuntu-删除内核
    u盘安装14.04ubuntu系统
    findFocus-获得拥有焦点的控件
    xml中控件调用构造方法
  • 原文地址:https://www.cnblogs.com/baiyygynui/p/6217080.html
Copyright © 2011-2022 走看看