uni-app微信小程序image引入图片;background-image背景图引入图片;小程序预览本地图片;小程序图片过大引入报错;获取本地图片的网络地址;

uni-app小程序图片使用有image标签和background-image背景图两种方式:
在这里插入图片描述

下有获取本地图片的网络地址方式:见第四步

一、方式一:使用image标签引入: uni-app官方image
1.官方文档说:src 仅支持相对路径、绝对路径,支持 base64 码;但是我使用了网络地址https也可以显示
在这里插入图片描述

目前支持以下四种方式引入:

	  <view>引入image的绝对路径src:</view>
      <image src="~@/static/iconimg/big.png"  mode="scaleToFill" />
      <view>引入image的相对路径src2 </view>
      <image src="../static/iconimg/big.png"  mode="scaleToFill" />
      <view>引入image的变量src3(注意仅支持相对引入路径变量)</view>
      <image :src="imgUrl"  mode="scaleToFill" />

      data下变量引入
	  imgUrl: '../static/iconimg/big.png',//可以
      imgUrl: '~@/static/iconimg/big.png',//不可以
      <view>引入image的网络src4 :https</view>
      <image src="https://su.bcebos.com/shitu-query-nj/2021-07-21/15/ba8d23f1085c34d8?authorization=bce-auth-v1%2F7e22d8caf5af46cc9310f1e3021709f3%2F2021-07-21T08%3A13%3A52Z%2F300%2F%2Fca431ab8970c8573f59a105c98dc4ace6d7b461b234aca196bf35c018a645744"  mode="scaleToFill" />

以下是uni-app文档截图

二、方式二:使用background-image背景图属性引入: uni-app背景图官方介绍

1.官方文档说:支持 base64 格式图片。 支持网络路径图片。40kb以下小图片推荐使用以 ~@ 开头的绝对路径;大图片推荐使用网络地址微信小程序不支持相对路径(真机不支持,开发工具支持)

在这里插入图片描述

目前支持以下三种方式引入:

/* 大图片推荐网络地址引入  注意如果是相对或者绝对引入都会报错  */
background-image: url("https://su.bcebos.com/shitu-query-nj/2021-07-21/15/ba8d23f1085c34d8?authorization=bce-auth-v1%2F7e22d8caf5af46cc9310f1e3021709f3%2F2021-07-21T08%3A13%3A52Z%2F300%2F%2Fca431ab8970c8573f59a105c98dc4ace6d7b461b234aca196bf35c018a645744");
/* 小图片推荐~@绝对路径引入 */
background-image: url("~@/static/iconimg/l1.png");
/* 小图片官方说不支持  但是试了一下可以用 不推荐 */
background-image: url("../static/iconimg/l1.png");

三、预览本地图片

注意:需要有预览方法,同时图标列表数组预览
除了是https网络地址可以预览外
本地引入直接写根路径引入(既[‘/static/iconimg/big.png’] 才可行(同时注意:本地引入的 小程序编辑器预览会一直刷新不可行 真机可行

    previewImage () {
      var index = 0
      uni.previewImage({
        // 图标列表数组预览 除了是https网络地址外 本地引入直接写根路径引入才可行(同时注意:本地引入的 小程序编辑器预览会一直刷新 真机可行)
        urls: ['/static/iconimg/big.png'],
        // urls: ['https://su.bcebos.com/shitu-query-nj/2021-07-21/15/ba8d23f1085c34d8?authorization=bce-auth-v1%2F7e22d8caf5af46cc9310f1e3021709f3%2F2021-07-21T08%3A13%3A52Z%2F300%2F%2Fca431ab8970c8573f59a105c98dc4ace6d7b461b234aca196bf35c018a645744'],

        // 以下两种方法路径引入不可以
        // urls: ['~@/static/iconimg/big.png'],
        // urls: ['../static/iconimg/big.png'],
        current: index,
        longPressActions: {
          itemList: ['发送给朋友', '保存图片', '收藏'],
          success: function (data) {
            console.log('选中了第' + (data.tapIndex + 1) + '个按钮,第' + (data.index + 1) + '张图片')
          },
          fail: function (err) {
            console.log(err.errMsg)
          }
        }
      })

    },

四、如何获取本地图片的网络地址:

需要注意:这个百度识图获取到的图片地址,不是永久有效的!!!!!最好让后端返回网络地址

百度–更多–百度识图–上传图片–右键检查–找到图片的src就是网络图片地址。

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

五、代码

<template>
  <view>
    <view id="top" class="uni-padding-wrap uni-common-mt">
      image 组件默认宽度 300px、高度 225px;<br>
      src 仅支持相对路径、绝对路径,支持 base64 码;

      <view>引入image的绝对路径src:(推荐)</view>
      <view>~@/static/iconimg/big.png </view>
      <image src="~@/static/iconimg/big.png" @click="previewImage()" mode="scaleToFill" />

      <view>引入image的相对路径src2 </view>
      <view>../static/iconimg/big.png </view>
      <image src="../static/iconimg/big.png" @click="previewImage()" mode="scaleToFill" />

      <view>引入image的变量src3(注意仅支持相对引入路径变量)</view>
      <view>imgUrl: '../static/iconimg/big.png',//相对路径可以</view>
      <view>imgUrl: '/static/iconimg/big.png',//根目录路径可以</view>
      <view>// imgUrl: '~@/static/iconimg/big.png',//不可以</view>
      <image :src="imgUrl" @click="previewImage()" mode="scaleToFill" />

      <view>引入image的网络src4 :https(官方未说可用不)</view>
      <image src="https://su.bcebos.com/shitu-query-nj/2021-07-21/15/ba8d23f1085c34d8?authorization=bce-auth-v1%2F7e22d8caf5af46cc9310f1e3021709f3%2F2021-07-21T08%3A13%3A52Z%2F300%2F%2Fca431ab8970c8573f59a105c98dc4ace6d7b461b234aca196bf35c018a645744" @click="previewImage()" mode="scaleToFill" />

      <view>以下四个是背景图background-image:大图是指大小超过40kb</view>
      <view class="bgi1">图片背景图:大图用网络地址https</view>
      <view class="bgi2">图片背景图:大图相对、绝对都不可用 只能用https地址</view>
      <view class="bgi3">图片背景图:小图可用绝对地址(推荐)</view>
      <view class="bgi4">图片背景图:小图可用相对地址(官方说不支持)</view>
    </view>
  </view>
</template>
<script>
export default {
  data () {
    return {
      imgUrl: '../static/iconimg/big.png',//相对路径可以
      // imgUrl: '/static/iconimg/big.png',//根目录路径可以
      // imgUrl: '~@/static/iconimg/big.png',//绝对路径不可以
    }
  },
  onLoad () {
  },
  methods: {
    previewImage () {
      var index = 0
      uni.previewImage({
        // 图标列表数组预览 除了是https网络地址外 本地引入直接写根路径引入才可行(同时注意:本地引入的 小程序编辑器预览会一直刷新 真机可行)
        urls: ['/static/iconimg/big.png'],
        // urls: ['https://su.bcebos.com/shitu-query-nj/2021-07-21/15/ba8d23f1085c34d8?authorization=bce-auth-v1%2F7e22d8caf5af46cc9310f1e3021709f3%2F2021-07-21T08%3A13%3A52Z%2F300%2F%2Fca431ab8970c8573f59a105c98dc4ace6d7b461b234aca196bf35c018a645744'],

        // 以下两种方法路径引入不可以
        // urls: ['~@/static/iconimg/big.png'],
        // urls: ['../static/iconimg/big.png'],
        current: index,
        longPressActions: {
          itemList: ['发送给朋友', '保存图片', '收藏'],
          success: function (data) {
            console.log('选中了第' + (data.tapIndex + 1) + '个按钮,第' + (data.index + 1) + '张图片')
          },
          fail: function (err) {
            console.log(err.errMsg)
          }
        }
      })

    },
  }
}
</script>

<style>
.text {
  margin: 16rpx 0;
  width: 100%;
  background-color: #fff;
  height: 120rpx;
  line-height: 120rpx;
  text-align: center;
  color: #555;
  border-radius: 8rpx;
}

.bgi1 {
  width: 500rpx;
  height: 200rpx;
  border: 1px solid #1fff;
  margin-bottom: 20rpx;
  /* 大图片 */
  background-image: url("https://su.bcebos.com/shitu-query-nj/2021-07-21/15/ba8d23f1085c34d8?authorization=bce-auth-v1%2F7e22d8caf5af46cc9310f1e3021709f3%2F2021-07-21T08%3A13%3A52Z%2F300%2F%2Fca431ab8970c8573f59a105c98dc4ace6d7b461b234aca196bf35c018a645744");
  background-repeat: no-repeat;
  background-size: contain;
}
.bgi2 {
  width: 500rpx;
  height: 200rpx;
  border: 1px solid #1fff;
  margin-bottom: 20rpx;
  /* background-image: url("https://su.bcebos.com/shitu-query-nj/2021-07-21/15/ba8d23f1085c34d8?authorization=bce-auth-v1%2F7e22d8caf5af46cc9310f1e3021709f3%2F2021-07-21T08%3A13%3A52Z%2F300%2F%2Fca431ab8970c8573f59a105c98dc4ace6d7b461b234aca196bf35c018a645744"); */
  /* background-image: url("~@/static/iconimg/l1.png"); */
  /* background-image: url("../static/iconimg/l1.png"); */
  /* background-image: url("~@/static/iconimg/big.png"); */
  background-repeat: no-repeat;
  background-size: contain;
}
.bgi3 {
  width: 500rpx;
  height: 200rpx;
  border: 1px solid #1fff;
  margin-bottom: 20rpx;
  background-image: url("~@/static/iconimg/l1.png");
  background-repeat: no-repeat;
  background-size: contain;
}
.bgi4 {
  width: 500rpx;
  height: 200rpx;
  border: 1px solid #1fff;
  margin-bottom: 20rpx;
  background-image: url("../static/iconimg/l1.png");
  background-repeat: no-repeat;
  background-size: contain;
}

image {
  margin-bottom: 50rpx;
}
</style>

  • 10
    点赞
  • 34
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
uni-app中,要实现微信小程序图片放大预览并带有图片描述并可左右切换,可以使用uni-app提供的组件和方法来实现。 首先,我们可以使用uni-appimage组件来展示图片,并通过设置mode属性为aspectFit,使图片按照原图的长宽比等比缩放并保持完整显示。 然后,为了实现图片放大预览并可左右切换,在点击图片时,我们可以使用uni-app的previewImage方法来打开一个全屏的图片预览,并传入一个包含图片链接数组的current参数,以及一个包含图片描述的urls参数。这样就可以在预览界面中显示图片描述,并且可通过左右滑动切换图片。 具体实现步骤如下: 1.在模板中,使用image组件展示图片,设置mode为aspectFit,并绑定点击事件。 2.在点击事件处理函数中,调用uni-app的previewImage方法,传入图片链接数组和图片描述数组。 3.在预览界面中,通过swiper组件实现图片的左右滑动切换,并显示图片描述。 示例代码如下: ``` <template> <view> <image mode="aspectFit" :src="imageUrl" @click="previewImage"></image> </view> </template> <script> export default { data() { return { imageUrl: '图片链接', imageDesc: '图片描述' } }, methods: { previewImage() { uni.previewImage({ current: this.imageUrl, urls: [this.imageUrl], longPressActions: { itemList: ['保存图片'], success: function(data) { if (data.tapIndex === 0) { uni.saveImageToPhotosAlbum({ filePath: this.imageUrl, success: function() { uni.showToast({ title: '保存图片成功' }) }, fail: function() { uni.showToast({ title: '保存图片失败', icon: 'none' }) } }) } } } }) } } } </script> ``` 使用以上方法,我们可以在uni-app微信小程序中实现图片放大预览并带有图片描述可左右切换的功能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值