(编辑:jimmy 日期: 2025/1/18 浏览:2)
本文实例讲述了微信小程序使用wx.request请求服务器json数据并渲染到页面操作。分享给大家供大家参考,具体如下:
微信小程序的数据总不能写死吧,肯定是要结合数据库来做数据更新,而小程序数据主要是json数据格式,所以我们可以利用php操作数据库,把数据以json格式数据输出即可。现在给大家讲一下,微信小程序的wx.request
进行服务器数据请求的用法:
官方文档给出了示例代码,但是我这边自己进行了简单的处理:
index.js
Page({ data: { }, onLoad: function () { var that = this wx.request({ url: 'http://www.likeyunba.com/test/test.json', headers: { 'Content-Type': 'application/json' }, success: function (res) { //将获取到的json数据,存在名字叫list的这个数组中 that.setData({ list: res.data, //res代表success函数的事件对,data是固定的,list是数组 }) } }) } })
上面的url是json数据
test.json
[ { "id":"1", "title":"测试数据1" }, { "id":"2", "title":"测试数据2" }, { "id":"3", "title":"测试数据3" }, { "id":"4", "title":"测试数据4" }, { "id":"5", "title":"测试数据5" }, { "id":"6", "title":"测试数据6" }, { "id":"7", "title":"测试数据7" }, { "id":"8", "title":"测试数据8" }, { "id":"9", "title":"测试数据9" } ]
index.wxml
<view wx:for="{{list}}" wx:key="list"> <view>{{item.id}}</view> <view>{{item.title}}</view> </view>
然后wxml是首页,渲染json数据的,这是一个for循环(wx.for
),wx:key="list"
干嘛用的?
如果我们没有wx:key="list"
,那么在控制台会报错,但是这个报错并不影响页面的渲染,基本可以忽略掉!
Now you can provide attr "wx:key" for a "wx:for" to improve performance.这是报错信息
wx:key
用来对列表渲染的数据指定一个"主键”,以加快列表渲染的速度。以下是官方文档原话:如不提供 wx:key
,会报一个 warning, 如果明确知道该列表是静态,或者不必关注其顺序,可以选择忽略。如果你一定想去掉这个警告,可以在wx:for
的组件属性里增加一个 wx:key="unique"
,unique请替换成数据绑定列表里的任意一个字段的字段名,比如文章列表数据中的字段“postId”,即wx:key="postId"
。不建议使用wx:key="*this"
。
希望本文所述对大家微信小程序开发有所帮助。