zoukankan      html  css  js  c++  java
  • 小程序学习笔记

     微信公众号和微信小程序中一些概念

    1、微信开发者账号 —— 用来登录微信开发者平台的账号

    2、微信应用 —— 同一账号可以在微信开发者平台申请多个应用,假设我们在开发知乎,我们会在微信开发者后台申请两个应用,分别是『知乎网站』和『知乎App』

    3、微信用户 —— 一般理解下的微信用户,假设我们有微信用户 summer 作为测试。

    OpenID 是最对『微信应用』的用户唯一值,同一个『微信开发者账号』下的不同应用中,使用同一个『微信用户』登录,此值会不一样。

    UnionID 是针对『微信开发者账号』的用户唯一值,同一个『微信开发者账号』下的不同应用中,使用同一个『微信用户』登录,此值是一致的。

    1、在app.json中直接配置页面,如下,保存会生成4个相同的文件名的四个文件,值得注意的是最后一个命名是文件名,前面的是文件夹名,如果要在company下面再建一个子文件,需要如下表示!!

    "pages":[
        "pages/company/company" ,
       "pages/company/companylist/companylist"
    ]
    2、在小程序中图片的应用,只能使用测试机或者正式机的路径进行引用,不能用相对路径!
    3、在页面中用于公共js的方法,在page.js中,先const app = getApp(),然后通过var qUrl = app.URL 的方式引用app.js里面的URL  !!!!!
    4.小程序中获取ajax数据的时候,跟vue一样需要res.data的形式不是res!!!
    5、在实际开发过程中遇到 warning: Now you can provide attr "wx:key" for a "wx:for" to improve performance。发现是使用wx:for的时候,没有使用wx:key !!wx.key可以通过

    wx:key 的值以两种形式提供

    1、wx:key="property" 其中property是代表在 for 循环的 array 中 item 的某个 property,该 property 的值需要是列表中唯一的字符串或数字,且不能动态改变。类似于字典的key值

    2、wx:key="*this", 保留关键字 *this 代表在 for 循环中的 item 本身,这种表示需要 item 本身是一个唯一的字符串或者数字。

    6、页面跳转使用wx.navigateTo({}),其中路径是使用前端的相对路径

    wx.navigateTo({
    url: '../search/search'
    })
     
    带参数的跳链接
     如果带的参数是input里面的内容那么使用如下
    resultPage: function () {
    var key = this.data.inputValue;
    // console.log(key);
    wx.navigateTo({
    url: './searchList/searchList?keyword=' + key
    })
    }
    如果带的参数是一个div里面的内容那么使用如下(e.currentTarget.dataset.text
    resultPage2: function (e) {
    console.log(e.currentTarget.dataset.text);
    var key = e.currentTarget.dataset.text;
    wx.navigateTo({
    url: './searchList/searchList?keyword=' + key
    })
    }
     
    接收页面,接收代码
    onLoad: function (option) {
          console.log(option.keyword)
    }

    7、在小程序中没有数据双向绑定,这时候改变完数据需要使用this.setData({)}这个方法来使数据重新渲染,this.setDate这个指向的就是data了,所以里面的值,直接赋值就可以,不用只用this来指示!!

    this.setData({
           hisList: this.data.hisList
    });
     
    需要使用this.setdata对value进行重新赋值渲染,不然.xml层视图层接收不了
    if (this.data.inputValue==""){
    this.setData({
    isValue: false
    });
    }else {
    this.setData({
    isValue:true
    });
    }

    8.在小程序中在使用wx:for 循环出来的列表中,在点击某个item的时候如何传相应的index标识给函数 ??

    在小程序中,需要自定义属性,然后通过函数那边的时间接收来获取相应的自定义属性

    例如在item中自定义属性,<view data-index=“{{index}}” bindtap="delItem"></view>

    然后在函数使用获取 e.target.dataset获取自定义属性,例如使用e.target.dataset.index来获取view中自定义的index属性!!

    获取input中的value中的 val值是使用e.detail.value!!

     在小程序中要获取元素的文本内容,使用,这时候没有dom操作,可使用data-text 自定义属性来实现,给view自定义data-text属性,然后点击的是,使用e.target.dataset.text来获取!!!

    9、函数里面,如果需要引用到data里面定义的数据,使用this.data来引用,不然会undefined

  • 相关阅读:
    获取地址栏数据
    tag标签添加删除并把值存入到一个input的value内
    美化 input type=file控件
    高效的数组去重(js)
    原生js动态改变dom高度
    html5 postMessage解决跨域、跨窗口消息传递
    移动前端制作篇之javascript篇
    js中的事件委托
    图片轮播(定时播放)
    潭州课堂25班:Ph201805201 django 项目 第四十一课 后台 轮播图管理功能讲解,文档管理功能 实现 (课堂笔记)
  • 原文地址:https://www.cnblogs.com/qdlhj/p/8780084.html
Copyright © 2011-2022 走看看