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


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父窗口控制只弹出一个子窗口
Apr 10 Javascript
锋利的jQuery 第三章章节总结的例子
Mar 23 Javascript
javascript获取函数名称、函数参数、对象属性名称的代码实例
Apr 12 Javascript
jQuery中index()的用法分析
Sep 05 Javascript
JavaScript操作XML/HTML比较常用的对象属性集锦
Oct 30 Javascript
JavaScript严格模式详解
Nov 18 Javascript
jQuery使用JSONP实现跨域获取数据的三种方法详解
May 04 jQuery
js实现鼠标单击Tab表单切换效果
May 16 Javascript
ng-events类似ionic中Events的angular全局事件
Sep 05 Javascript
Node.js模拟发起http请求从异步转同步的5种用法
Sep 26 Javascript
解决Vue-Router升级导致的Uncaught (in promise)问题
Aug 07 Javascript
VsCode里的Vue模板的实现
Aug 12 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 rsa加密解密使用方法
2015/04/27 PHP
详解WordPress中分类函数wp_list_categories的使用
2016/01/04 PHP
PHPExcel实现表格导出功能示例【带有多个工作sheet】
2018/06/13 PHP
jquery 使用点滴函数代码
2011/05/20 Javascript
基于jquery的固定表头和列头的代码
2012/05/03 Javascript
最流行的Node.js精简型和全栈型开发框架介绍
2015/02/26 Javascript
基于jQuery实现的双11天猫拆红包抽奖效果
2015/12/01 Javascript
理解js对象继承的N种模式
2016/01/25 Javascript
基于JavaScript实现自动更新倒计时效果
2016/12/19 Javascript
利用iscroll4实现轮播图效果实例代码
2017/01/11 Javascript
jQuery实现弹幕效果
2017/02/17 Javascript
微信小程序的生命周期的详解
2017/10/19 Javascript
AjaxUpLoad.js实现文件上传
2018/03/05 Javascript
vue使用自定义指令实现拖拽
2021/01/29 Javascript
在类Unix系统上开始Python3编程入门
2015/08/20 Python
解决python删除文件的权限错误问题
2018/04/24 Python
Pandas 按索引合并数据集的方法
2018/11/15 Python
python爬虫获取新浪新闻教学
2018/12/23 Python
python3.6环境安装+pip环境配置教程图文详解
2019/06/20 Python
python爬虫 线程池创建并获取文件代码实例
2019/09/28 Python
python实现超级玛丽游戏
2020/03/18 Python
Python使用pdb调试代码的技巧
2020/05/03 Python
python实现mean-shift聚类算法
2020/06/10 Python
LookFantastic丹麦:英国美容护肤精品在线商城
2016/08/18 全球购物
为您的家、后院、车库等在线购物:Spreetail
2019/06/17 全球购物
农业大学毕业生的个人自我评价
2013/10/11 职场文书
班委竞选演讲稿
2014/04/28 职场文书
销售提升方案
2014/06/07 职场文书
民主评议党员自我评议范文2014
2014/09/26 职场文书
二婚主持词
2015/06/30 职场文书
小学开学典礼新闻稿
2015/07/17 职场文书
银行求职信范文
2019/05/13 职场文书
解析原生JS getComputedStyle
2021/05/25 Javascript
深入理解Pytorch微调torchvision模型
2021/11/11 Python
Python中的tkinter库简单案例详解
2022/01/22 Python
win10输入法不见了只能打出字母怎么解决?
2022/08/05 数码科技