先看下「名片盒」详情页的效果图:

微信小程序开发教程第五章:名片夹详情页开发

微信小程序开发教程第五章:名片夹详情页开发

备注下大致需求:顶部背后是轮播图,二维码按钮弹出模态框信息、点击微信栏、点击存入手机,地址栏需要地图展示,名片分享也是模态框指引。

首先是轮播图,autoplay 自动播放,interval 轮播的时间,duration 切换速度,可以根据自己需求去添加。

Delete:是删除按钮,加载进来是隐藏的,需用户点轮播图进去后,轮播图全屏显示才出来。noClickImg 与 ClickImg:切换全屏与非全屏轮播图,绑定了点击事件 changeClick 来切换,只是改变样式即可。Block:图片列表。Number_img:当前轮播 index(currentNumber),与图片 length 集合(cardnum)。其中 currentNumber:

//轮播图发生改变时改变数字

//初始化数据

Data:{

currentNumber:1

}

slidechange:function(e){

var number = e.detail.current;

this.setData({

currentNumber:number+1

})

},

微信小程序开发教程第五章:名片夹详情页开发

这里可以看到全屏状态下当关闭按钮被点击后 getBackStyle,把 changeClick 切换到 imgFullScrenn 待命。

微信小程序开发教程第五章:名片夹详情页开发

再次点击返回原样式,

微信小程序开发教程第五章:名片夹详情页开发

切换后事件又走回到 getBackStyle 了,灵活运用。

微信小程序开发教程第五章:名片夹详情页开发

刷新下开发者工具可以看到具体效果如下:

微信小程序开发教程第五章:名片夹详情页开发

详情页可以看到信息基本都是样式一样,可以使用微信提供的循环 block。

下面是详情页里面的个人信息数据,

如果有信息就显示出来,没有数据的不显示,这里使用

微信小程序开发教程第五章:名片夹详情页开发

//中文信息

var chinaMessage = res.card.groups[0].fields;

var personMessage= []

for(var i = 0;i<chinamessage.length;i++){

</chinamessage.length;i++){

personMessage.push(chinaMessage[i])

}

//为空或者null是不显示判断

for(var k in personMessage){

if(personMessage[k].value==null || personMessage[k].value==""){

personMessage[k]["display"] = "none";

}else{

personMessage[k]["display"] = "block";

}

}

具体以 json 数据格式来处理,我们需要做的就是给它绑定 display 的值,然后我们调用即可。

微信小程序开发教程第五章:名片夹详情页开发

微信此版本的 setData 不支持异步更新数据,故而我们在发生真实网络数据请求时一定要在后面加上 forceUpdata(),强制触发视图渲染,否则会出现很多莫名其妙的 bug。

微信小程序开发教程第五章:名片夹详情页开发

这里说明下:如是服务器真实数据。

微信小程序开发教程第五章:名片夹详情页开发

可以看到会报错,可能是 js 的执行顺序,依次往下走,此时网络数据还在请求中。

微信小程序开发教程第五章:名片夹详情页开发

定义一个变量即可。

微信小程序开发教程第五章:名片夹详情页开发

当然这里的数据都是 push 上来的。

微信小程序开发教程第五章:名片夹详情页开发

以下是二维码弹出信息。

微信小程序开发教程第五章:名片夹详情页开发

这是弹出模态框二维码信息,布好局初始化是none状态。那里需要它直接绑定数据即可:

This.setData({

//模态框名字:”显示?隐藏”

})

方法是让它显示。

微信小程序开发教程第五章:名片夹详情页开发

需要用他的地方调用方法即可。(支持重复调用)

详情页公司位置地图直接调用微信提供的接口实现(群里的 demo 有实现方式)。

可以看下实现的效果:

微信小程序开发教程第五章:名片夹详情页开发

微信小程序开发教程第五章:名片夹详情页开发

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。