微信小程序选择图片和放大预览图片功能


Posted in Javascript onNovember 02, 2017

视频中,老师也是看着官方文档,为学生们讲解,微信提供了系统的方法来选择图片.

wx.chooseImage({})

此方法是用来选择图片的方法,具体使用如下:

data: {
  avatarUrl:null
 },

首先在数据中定义接收数据的变量,然后调用方法选择图片,将图片显示出来。

bindViewTap:function(){
  var that = this;
  wx.chooseImage({
  // 设置最多可以选择的图片张数,默认9,如果我们设置了多张,那么接收时//就不在是单个变量了,
   count: 1, 
   sizeType: ['original', 'compressed'], // original 原图,compressed 压缩图,默认二者都有
   sourceType: ['album', 'camera'], // album 从相册选图,camera 使用相机,默认二者都有
   success: function(res){
    // 获取成功,将获取到的地址赋值给临时变量
    var tempFilePaths = res.tempFilePaths;
    that.setData({
    //将临时变量赋值给已经在data中定义好的变量
     avatarUrl:tempFilePaths
    })
   },
   fail: function(res) {
    // fail
   },
   complete: function(res) {
    // complete
   }
  })
 }

此时我们定义的全局变量,也就是data中的url,已经有值了,现在只需要在页面中显示即可。

//点击此按钮调用选择图片的方法,成功后将图片显示在image标签上
 <button bindtap="bindViewTap" type="submit">绑定事件</button>
<image src="{{avatarUrl}}"></image>

如果是多选的话,在显示的时候,就不应该直接显示数据源了,这样会报错的,因为返回的是数组:

<image wx:for="{{avatarUrl}}" wx:key="unique" src="{{item}}"></image>

图片预览:

下面说一下图片预览:

首先在data中定义好数据源:

data:{
  avatarUrl:null,
  pictures: [ 'https://p0.meituan.net/movie/ea4ac75173a8273f3956e514a4c78018253143.jpeg',
   'https://p0.meituan.net/movie/5d4fa35c6d1215b5689257307c461dd2541448.jpeg',
   'https://p0.meituan.net/movie/0c49f98a93881b65b58c349eed219dba290900.jpg',
   'https://p1.meituan.net/movie/45f98822bd15082ae3932b6108b17a01265779.jpg',
   'https://p1.meituan.net/movie/722de9a7b0c1f9c262162d87eccaec7c451290.jpg',
   'https://p0.meituan.net/movie/cb9be5bbedb78ce2ef8e83c93f83caca474393.jpg',
   'https://p1.meituan.net/movie/a852b992cdec15319c717ba9fa9b7a35406466.jpg',
   'https://p1.meituan.net/movie/dc1f94811793e9c653170cba7b05bf3e484939.jpg'
  ]
 },

然后创建方法previewImage,实现图片预览:

previewImage: function(e){
  var that = this,
  //获取当前图片的下表
    index = e.currentTarget.dataset.index,
    //数据源
    pictures = this.data.pictures;
  wx.previewImage({
  //当前显示下表
   current: pictures[index],
   //数据源
   urls: pictures
  })
 }

然后再页面中边遍历数据,显示:

<view>
 <image wx:for="{{pictures}}" wx:key="unique"src="{{item}}" data-index="{{index}}" bindtap="previewImage"></image>
</view>

先列表显示全部图片,绑定预览方法,点击图片进行左右预览,

下面在给大家补充下微信小程序图片放大预览功能,具体内容介绍如下所示:

需求:当点击图片时,当前图片放大预览,且可以左右滑动

微信小程序选择图片和放大预览图片功能

实现方式:使用微信小程序图片预览接口

微信小程序选择图片和放大预览图片功能

我们可以看到api需要两个参数,分别通过下面的data-list和data-src来传到js中

wxml代码:

<!--图片描述-->
 <view wx:if="{{item.pictures}}" class="list-dImg">
 <image bindtap="imgYu" data-list="{{item.pictures}}" data-src="{{dImg}}" wx:for="{{item.pictures}}" wx:for-item="dImg" src="{{dImg}}"></image>
 </view>

js代码:

//图片点击事件
 imgYu:function(event){
 var src = event.currentTarget.dataset.src;//获取data-src
 var imgList = event.currentTarget.dataset.list;//获取data-list
 //图片预览
 wx.previewImage({
 current: src, // 当前显示图片的http链接
 urls: imgList // 需要预览的图片http链接列表
 })
 }

1.给图片添加一个点击事件(imgYu)

2.使用event.currentTarget.dataset.自定义属性名称   来获取data-的值 如event.currentTarget.dataset.src  (获取data-src的值)

3.之后将获取的两个值 放到wx.previewImage接口 里面即可

效果图片如下:可以左右滑动上一张下一张

微信小程序选择图片和放大预览图片功能

总结

以上所述是小编给大家介绍的微信小程序选择图片和放大预览图片功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
JavaScript 节点操作 以及DOMDocument属性和方法
Dec 06 Javascript
Javascript Function对象扩展之延时执行函数
Jul 06 Javascript
js下用eval生成JSON对象
Sep 17 Javascript
提取jquery的ready()方法单独使用示例
Mar 25 Javascript
玩转方法:call和apply
May 08 Javascript
jQuery常用数据处理方法小结
Feb 20 Javascript
angularjs表格分页功能详解
Jan 21 Javascript
基于BootstrapValidator的Form表单验证(24)
Dec 12 Javascript
解析JS在获取当前月的最后一天遇到的坑
Aug 30 Javascript
JavaScript canvas绘制渐变颜色的矩形
Feb 18 Javascript
使用element-ui +Vue 解决 table 里包含表单验证的问题
Jul 17 Javascript
uni-app 自定义底部导航栏的实现
Dec 11 Javascript
微信小程序实现图片放大预览功能
Oct 22 #Javascript
极简主义法编写JavaScript类
Nov 02 #Javascript
利用nvm管理多个版本的node.js与npm详解
Nov 02 #Javascript
JavaScript屏蔽Backspace键的实现代码
Nov 02 #Javascript
Vue源码学习之初始化模块init.js解析
Nov 02 #Javascript
为输入框加入数字js校验代码分享
Nov 02 #Javascript
详谈js中标准for循环与foreach(for in)的区别
Nov 02 #Javascript
You might like
用php获取远程图片并把它保存到本地的代码
2008/04/07 PHP
PHP检测移动设备类mobile detection使用实例
2014/04/14 PHP
Thinkphp将二维数组变为标签适用的一维数组方法总结
2014/10/30 PHP
php实现refresh刷新页面批量导入数据的方法
2014/12/23 PHP
PHP实现电商订单自动确认收货redis队列
2017/05/17 PHP
JS高级拖动技术 setCapture,releaseCapture
2011/07/31 Javascript
js中运算符&amp;&amp; 和 || 的使用记录
2014/08/21 Javascript
jquery中ajax处理跨域的三大方式
2016/01/05 Javascript
JS锚点的设置与使用方法
2016/09/05 Javascript
如何清除IE10+ input X 文本框的叉叉和密码输入框的眼睛图标
2016/12/21 Javascript
详解vue与后端数据交互(ajax):vue-resource
2017/03/16 Javascript
vue axios用法教程详解
2017/07/23 Javascript
JavaScript 下载svg图片为png格式
2018/06/21 Javascript
详解微信小程序实现WebSocket心跳重连
2018/07/31 Javascript
vue实现淘宝购物车功能
2020/04/20 Javascript
解决vue+webpack项目接口跨域出现的问题
2020/08/10 Javascript
[38:23]2014 DOTA2国际邀请赛中国区预选赛 5 23 CIS VS LGD第一场
2014/05/24 DOTA
在Python中使用NLTK库实现对词干的提取的教程
2015/04/08 Python
探究Python的Tornado框架对子域名和泛域名的支持
2015/05/02 Python
python处理二进制数据的方法
2015/06/03 Python
详解Python 装饰器执行顺序迷思
2018/08/08 Python
Python pymongo模块常用操作分析
2018/09/01 Python
Python Web框架之Django框架cookie和session用法分析
2019/08/16 Python
python 实现屏幕录制示例
2019/12/23 Python
Python爬虫之Selenium警告框(弹窗)处理
2020/12/04 Python
亚马逊加拿大网站:Amazon.ca
2020/01/06 全球购物
基层工作经历证明
2014/01/13 职场文书
黄河的主人教学反思
2014/02/07 职场文书
高中语文课后反思
2014/04/27 职场文书
学习考察心得体会
2014/09/04 职场文书
房屋转让协议书
2014/10/18 职场文书
班主任经验交流材料
2014/12/16 职场文书
公司承诺函范文
2015/01/21 职场文书
销售内勤岗位职责
2015/02/10 职场文书
小学生班干部竞选稿
2015/11/20 职场文书
导游词之广州陈家祠
2019/10/21 职场文书