关于将手机里的图片放在上传到小程序,在小程序里这种方法并不陌生,甚至大多数小程序都附带有这种功能,那么这种功能是怎么实现的呢,一起来看看吧!!!
1.微信小程序加载图片的几种方法
1.本地图片的加载
例如:本地路径:/pages/images/1.png
<image class="widget" src="/pages/images/1.png"></image>
//此处可以通过mode来设置图片的放置方式
然后在wxss中设置自己需要的样式即可
关于mode的其他详情可以前往官方文档进行查看:image | 微信开放文档 (qq.com)
2.加载网络图片
例如:网络图片地址为:(此图片已无效)
<image class="widget" src="" mode="aspectFill"></image>
然后在wxss中设置自己需要的样式即可
mode的使用方法如上
3.使用本地svg图片(svg是可缩放矢量图形)
详情可以进行以下链接查看:小程序支持 SVG | 微信开放社区 (qq.com)
<image class="number-icon" src="/static/svg/shandian.svg"></image>
本地svg与本地图片的调用使用方法相同(svg相比较于图片更加清晰)
此处还可使用base64的方法将svg转化为base64的代码在wxss中使用
<view class="skin-icon1"></view>
.skin-icon1 {
width: 40rpx;
height: 40rpx;
background-image: url("");
background-size: cover;
}
此处一样可以展示出图片效果,而且不会占据小程序内部的空间,是很不错的降低空间储存的方法
2.如何获取手机内部的图片
以下部分为js代码,获取到你所上传图片的链接(此处链接的产生是微信自带的api返回的)
//从相册获取照片
wx.chooseMedia({
count: 1,
mediaType: ['image'],
sourceType: ['album'],
sizeType: ['original'],
success(res) {
var tempFilePath = res.tempFiles[0].tempFilePath;
try {
const FileSystemManager = wx.getFileSystemManager();
var url = FileSystemManager.saveFileSync(tempFilePath, wx.env.USER_DATA_PATH + '/' + tempFilePath.replace("wxfile://", ""));
this.setData({
picture: url
});
} catch {
wx.showToast({
title: '设置失败',
icon: 'error',
duration: 2000
});
}
},
fail() {
wx.showToast({
title: '上传失败',
icon: 'error',
duration: 2000
});
}
});
在此处拿到链接之后就可以将其渲染到主页面上了
<!-- 自定义图片 -->
<image class="ima" src="{{picture}}" mode="aspectFill"></image>
这里此处由于自定义图片位于个性换肤界面与需要渲染的页面距离较远,故采用存缓存的方式,将图片链接先储存在缓存之中,在返回主页面的时候小程序在监听到返回主页面时会触发onshow函数,故将读取缓存的位置放在onshow函数中即可拿到对应的图片链接,然后将其设置给picture这个变量即可,在wxml页面通过{{picture}}来引用picture里面的链接地址,即可完成图片背景的自定义设置啦!同样可以通过class选择器来实现对图片样式的设置
关于更多的详情可查看微信小程序官方文档:wx.chooseMedia(Object object) | 微信开放文档 (qq.com)
3.总结
此处知识点的总结希望可以帮到各位刚入门的开发者们,总体来说此处的知识点并不复杂,加以练习便可熟练的掌握啦,那各位咱们下次再见了,期待和各位一起变强!!!