【小程序】开发需要注意的地方(二)

16. 小程序this.setData is not a function

现象:如果出现this.setData is not a function 这个错误,这个就是微信小程序中的this的指向问题,比如在发送请求成功之后的this指向。

解决方法:

  1. const that = this;然后使用that.setData
  2. 使用ES6的箭头函数

17.使用data-xx传值

小程序会使用data-xx自定义属性,读取的时候event.currentTarget.dataset就可以获取设置的属性值,常用于循环渲染

<view data-alpha-beta="1" data-alphaBeta="2" bindtap="viewTap"> Click me</view>
  viewTap: function(event) {
    console.log(event.currentTarget.dataset.alphaBeta) // 转化为驼峰写法
    console.log(event.currentTarget.dataset.alphabeta) // 所有的大写转化成小写
  }

注意写法

18. 小程序拨打电话报错

img

解决方法:小程序调用拨打电话参数 phoneNumber必须是字符串格式

calling: function (event) {
  wx.makePhoneCall({
     phoneNumber: event.currentTarget.dataset.tel + ''
  })
}

19. block 标签

<block wx:if="{{true}}">
  <view>view1</view>
  <view>view2</view>
</block>

<block/> 并不是一个组件,它仅仅是一个包装元素,不会在页面中做任何渲染,只接受控制属性(如wx:for 或 wx:if)。

20. 关键字

关键字绑定常用于组件的一些关键字,像复选框组件一样,checked关键字如果等于true,则代表选中复选框,false则代表不选中复选框,示例代码如下:

<checkbox checked="{{false}}"> </checkbox>

不要直接写checked = "false",其计算结果是一个字符串,转成boolean类型后代表真值。

21. 网络请求

小程序通过wx.request方法进行https网络请求,网络请求是获取网络数据的基本方法。

wx.request({
  url: 'test.php', // 仅为示例,并非真实的接口地址
  data: {
    x: '',
    y: ''
  },
  header: {
    'content-type': 'application/json' // 默认值
  },
  success(res) {
    console.log(res.data)
  }
})

注意点:

  1. wx.request方法只支持https请求。
  2. 访问URL域名已经在微信小程序后台配置为合法域名,并且不能有端口。
  3. method的value必须为大写(如GET)。
  4. request请求的默认超时时间和最大超时时间都是60s。
  5. request的最大并发数是5。
  6. 网络请求的referer是不可以设置的,固定格式为https://servicewechat.com/{appid}/{version}/page-frame.html。关于referer的详细解释

22. getCurrentPages()函数

框架以栈的形式维护了当前的所有页面。 当发生路由切换的时候,页面栈的表现如下:

路由方式 页面栈表现
初始化 新页面入栈
打开新页面 新页面入栈
页面重定向 当前页面出栈,新页面入栈
页面返回 页面不断出栈,直到目标返回页
Tab 切换 页面全部出栈,只留下新的 Tab 页面
重加载 页面全部出栈,只留下新的页面

getCurrentPages()函数用于获取当前页面栈的实例,以数组形式按栈的顺序给出,第一个元素为首页,最后一个元素为当前页面。

注意:

  1. 不要尝试修改页面栈,会导致路由以及页面状态错误。
  2. 不要在 App.onLaunch 的时候调用 getCurrentPages(),此时 page 还没有生成。
  3. getCurrentPages() 跳转现在小程序支持十层。超过十层之后小程序可能会造成崩溃。

23. getApp()

微信小程序在App()函数里定义的是全局函数和全局数据,因此在页面文件夹的js文件也可以直接使用。比如存在“pages/home/home”这样的页面路径,在App()函数中也定义了全局函数getUserInfo()。则在home.js文件中就可以直接使用App()函数提供的全局函数或数据,代码如下:

//home.js
//获取应用实例
const app = getApp()

Page({
  onLoad: function () {
    const that = this
    // 调用应用实例的方法获取全局数据
    app.getUserInfo({
      success: res => {
        that.setData({
          userInfo: res.userInfo,
          hasUserInfo: true
        })
      }
    })
  }
})

注意点:

  1. App()函数必须在app.js中注册,且不能注册多个。
  2. 不能在App()内的函数调用getApp(),使用this就可以拿到App实例。
  3. 通过getApp()获取实例之后,不要私自调用生命周期函数。

24. 小程序生命周期

小程序生命周期分为两类:应用生命周期和页面生命周期。

应用生命周期包括onLaunch、onShow、onHide、onError、onUnload。

页面生命周期包括onLoad、onShow、onReady、onHide、onUnload。

详细解释

25. 小程序判断用户是否是通过点击别人分享的小卡片进入页面

用户进入小程序的方法有很多种,可以通过好友分享、群聊分享、微信聊天主页面下拉或者发现栏小程序等等多种途径。但如果通过好友分享或者群聊分享打开的可能是某一个小程序页面,不能返回主页面,这时就需要在分享的页面中加入一个返回主页面的按钮,所以需要判断用户进入的渠道。

其解决方法有多种,详细解释

26.小程序与内嵌网页之间的跳转

小程序跳转到内嵌H5页面,需要使用web-view组件,定义该组件的src属性即可。

内嵌H5页面跳转到小程序页面引入微信的jssdk文件,使用wx.miniProgram.redirectTo({url: '/path/to/page'})

详细解释

27. 判断网页是否在小程序环境

在网页内可通过window.__wxjs_environment变量判断是否在小程序环境,建议在WeixinJSBridgeReady回调中使用,也可以使用JSSDK 1.3.2提供的getEnv接口。
代码如下:

// web-view下的页面内
wx.ready(function() {
  console.log(window.__wxjs_environment === 'miniprogram') // true
})

// 或

wx.miniProgram.getEnv(function(res) {
  console.log(res.miniprogram) // true 
})

28. 小程序与内嵌网页的通信

  1. 在web-view中添加bindmessage属性,并绑定一个函数,用于监听网页发来的消息。
  2. 在内嵌网页中引入jssdk,然后调用wx.miniProgram.postMessage()来向小程序发送数据。

小程序代码:

<!--webview.wxml-->
<web-view src="{{url}}" bindmessage="postMessage"></web-view>
// webview.js
Page({

  /**
   * 生命周期函数--监听页面加载
   */
  onLoad: function (options) {
    this.setData({
      url: options.url
    })
  },
  postMessage(e) {
    // e.detail = { data },data是多次 postMessage 的参数组成的数组
    this.setData({
      score: e.detail.data[0].score
    })
  }

})

内嵌网页代码:

<!-- html -->
<script type="text/javascript" src="https://res.wx.qq.com/open/js/jweixin-1.3.2.js"></script>

// javascript 
wx.miniProgram.postMessage({ data: 'foo' }) 
wx.miniProgram.postMessage({ data: {foo: 'bar'} }) 

注意:网页向小程序 postMessage时,不是实时的,只有在特定时机(小程序后退、组件销毁、分享)触发并收到消息。

29. 小程序内嵌网页的转发分享

小程序内嵌网页本质是在web-view组件的容器中,当对小程序内嵌网页的转发分享,也是对webview页面的转发分享,所以只需在webview.js中的page()定义onShareAppMessage即可。
代码如下:

Page({
  onShareAppMessage(options) {
    console.log(options.webViewUrl) // 获取当前<web-view>的URL
    return {
      title: "转发文本标题",
      imageUrl: "转发缩略图途径",
      path: options.webViewUrl
    }
  }
})

30. webview组件中bindload问题

最近开发小程序的时候,遇到了一个奇怪的问题。当我对内嵌网页设置背景音频的时候,当网页加载成功的时候,定义音频。但在真机上测试的时候背景音频定义两次,所以出现了重音的现象。

打印了一下日志,发现bindload定义的方法执行了两次。其原因我也不知。

代码如下:
webview.wxml

<!-- 指向微信公众平台首页的web-view -->
<web-view src="{{url}}" bindload="loadHtml"></web-view>

webview.js

Page({

  /**
   * 生命周期函数--监听页面加载
   */
  onLoad: function (options) {
    this.setData({
      url: options.url
    })
  },

  loadHtml() {
    console.log('页面加载完成') // 该方法执行两次
  }
})
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,794评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,050评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,587评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,861评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,901评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,898评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,832评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,617评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,077评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,349评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,483评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,199评论 5 341
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,824评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,442评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,632评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,474评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,393评论 2 352

推荐阅读更多精彩内容