zoukankan      html  css  js  c++  java
  • HBuilder创建app 基础

    一.了解HBuilder

    HBuilder内封装了大量的书籍,极大方便了使用

    官方文档:

    http://dev.dcloud.net.cn/mui/ui/

    关于布局:

    mhead  表头.mbody 身子,mtap 尾部

    操作:

    1.跳转页面 mui.openWindow

        document.getElementById("setting").addEventListener("tap",function(){ #  tap  监听事件    dga快捷方式
            mui.openWindow({   #mui.openWindow 跳转到新页面
                "url":"new.html",   #跳转的页面文件
                "id":"new.html",    #跳转的id
                styles:{
                    top:"0px",     # styles 样式  固定时必须用top作为参照
                    bottom:"50px"
                },
                extras:{              # extras 传值  需要在new.html上注入plusReady(function{}) ,内部填写  变量= plus.webview.currentWebview()接收.
                    
                    name:"666"
                }
            });
        });

    2.点击显示提示 toast

        document.getElementById('email').addEventListener('tap',function () {
               mui.toast("你点击邮件了"); 
        })

    3.mui.fire 跨表发送数据

      mui.plusReady(function(){
            
            
        })
        document.getElementById('email').addEventListener('tap',function () {
            var new_page = plus.webview.getWebviewById("new.html"); #同过mui.fire传值的参数,指向id为要发送数据的html 的id,使用plus必须有 mui.plusReady(function()
            mui.fire(new_page,'show_alert',{name:"chunsheng"}); #mui.fire三个参数(访问页面id,function回调函数名,字典形式内容),需要在访问html接收这个回调函数
        })

    另一端的接收

        document.addEventListener("show_alert",function(data){ #这里全局监听传递的回调函数
            console.log(JSON.stringify(data.detail.name));  #监听返回的函数必须 .detail 转换为Object字典形式
            alert("欢迎观临");
        })

    4.json post请求

      document.getElementById('login_btn').addEventListener('tap',function () {
             var username = document.getElementById("username").value;   
             var password = document.getElementById("password").value; 
             
             mui.post('http://192.168.13.144:9527/login',{
                     username:username,
                     password:password
                 },function(data){
                     mui.toast(data.msg);
                 },'json'
             );
             
        })
        mui.post('',#'' 存访问的地址
        {
                #传递的参数位置
           },function(data){
                #接收数据位置
            },'json'  #若为jsonity格式,可不告诉客户端请求头为json格式
        );

     

    5.图文列表,自己创建列表格式 通过createElement("")创建标签和appendChild()定义层级关系

      function create_item(content){         
              var li = document.createElement("li");#创建标签li createElement
              li.className ="mui-table-view-cell mui-media"; #配置class信息  className
              var a = document.createElement("a");
              var img = document.createElement("img");
              img.className ="mui-media-object mui-pull-left";
              img.src = "http://192.168.13.144:9527/get_image/"+content.image; #配置src 直接访问地址获取
              var div = document.createElement("div");
              div.className="mui-media-body";
              div.innerText = content.tilte; #创建文本  innerText
              var p = document.createElement("p");
              p.className="mui-ellipsis";
              p.innerText=content.text;
              
              li.appendChild(a); #创建层级关系
              a.appendChild(img);
              a.appendChild(div);
              div.appendChild(p);
              
              document.getElementById("content_list").appendChild(li);
              #注意,这是有名函数,需要调用才可用
        }

    调用函数

        mui.plusReady(function () {
            mui.post('http://192.168.13.144:9527/content_list',{
                    
                },function(data){
                    for (var i = 0; i < data.length; i++) {
    //                    console.log(JSON.stringify(data[i])) 
                        create_item(data[i]);#调用函数
                    }
                },'json' 
            );
        })

    关于后端传递src

    from flask import Flask,request,jsonify,send_file
    from setting import MONGO_DB
    @app.route("/content_list",methods=["POST"])
    def content_list():
        res = list(MONGO_DB.content.find({},{"_id":0}))
        return jsonify(res)
    
    @app.route("/get_image/<filename>")
    def get_image(filename):
        import os
        path = os.path.join("tupian",filename)
        return send_file(path)

    6.将其他页面在首页显示   mui.init( )     subpages

        mui.init({
            subpages:[{ #将main页面显示在首页的方法   subpages
              url:'main.html',
              id:'main.html',
              styles:{
                top:'0px',//mui标题栏默认高度为45px;
                bottom:'50px'//默认为0px,可不定义;
              }
            }]
          });

    7.全局设置 mui.js

    使用时一定要引用

    <script src="js/mui.js" type="text/javascript" charset="utf-8"></script>

    内容

    window.serv = "http://192.168.13.189:9527";
    window.serv_image = window.serv + "/get_image/";
    window.serv_music = window.serv + "/get_music/";

    在以后访问的路由中,都可以使用变量代替

    8.将音频播放 myplayer

    myplayer = plus.audio.createPlayer(window.serv_music + Sdata.audio);  #后面是访问文件的地址
            myplayer.play(); 播放
    myplayer.pause();  #暂停
     myplayer.resume();  #继续
    myplayer.stop();#停止

    9.查看自身ip

    //     var sdata = plus.webview.currentWebview(); # 在plusready ()使用
    //     console.log(JSON.stringify(sdata)) #这里获取的是页面的全部信息
          

    10websocket访问

        var ws = new WebSocket("ws://192.168.13.189:3721/app/app01");#这里同样可以通过websocket进行数据访问
        document.addEventListener("send_music",function(data){
            var send_str = data.detail // {to_user:"toy123",music:Sdata.audio}
            ws.send(JSON.stringify(send_str));
        }) 
        
  • 相关阅读:
    Linux系统中的load average
    通过数据库评估存储设备IO性能-Oracle11gIO校准功能介绍
    ORACLE查询字段中含有空格的数据
    JavaScript&Typescript中的时间
    LeetCode
    LeetCode
    面试问题及知识汇总
    Bootstrap布局容器与栅格系统
    JVM垃圾回收(GC)
    9. 专题
  • 原文地址:https://www.cnblogs.com/zhangqing979797/p/10289790.html
Copyright © 2011-2022 走看看