image-path.uvue 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195
  1. <template>
  2. <!-- #ifdef APP -->
  3. <scroll-view style="flex: 1;">
  4. <!-- #endif -->
  5. <view>
  6. <page-head :title="title"></page-head>
  7. <view class="uni-padding-wrap uni-common-mt">
  8. <view class="uni-title">
  9. <text class="uni-title-text">图片路径示例</text>
  10. </view>
  11. <view v-for="(item,index) in data" :key="index">
  12. <text class="uni-subtitle-text">{{item.description}}</text>
  13. <view class="uni-center" style="background:#FFFFFF;">
  14. <image class="image" mode="widthFix" :src="item.errorImage == null ? item.src : item.errorImage"
  15. @error="imageErrorEvent(index, $event as ImageErrorEvent)"></image>
  16. </view>
  17. </view>
  18. <test-image-path />
  19. <view>
  20. <text class="uni-subtitle-text">非static目录的src静态路径:./logo.png</text>
  21. <view class="uni-center" style="background:#FFFFFF;">
  22. <image class="image" mode="widthFix" src="./logo.png"></image>
  23. </view>
  24. </view>
  25. </view>
  26. </view>
  27. <!-- #ifdef APP -->
  28. </scroll-view>
  29. <!-- #endif -->
  30. </template>
  31. <script>
  32. import logo from './logo.png';
  33. const appid = uni.getAppBaseInfo().appId;
  34. export default {
  35. data() {
  36. return {
  37. title: 'image-path',
  38. outsideStaticPath: './logo.png' as string.ImageURIString,
  39. outsideStaticErrorPath: null as string | null,
  40. data: [
  41. {
  42. src: '/static/test-image/logo.png',
  43. description: '本地路径:/static方式'
  44. },
  45. {
  46. src: '../../../static/test-image/logo.png',
  47. description: '本地路径:../static/'
  48. },
  49. {
  50. src: '../../../static/Test-Image/Logo.png',
  51. description: '本地相对路径忽略大小写(需注意iOS平台不支持,Android平台云端打包后无效)'
  52. },
  53. {
  54. src: logo,
  55. description: 'import方式'
  56. },
  57. {
  58. src: `file:///android_asset/apps/${appid}/www/static/test-image/logo.png`,
  59. description: '本地绝对路径file://方式(仅限Android平台,云端打包后生效)'
  60. },
  61. {
  62. src: 'testerror.jpg',
  63. description: '错误的本地路径'
  64. },
  65. {
  66. src: '',
  67. description: 'Base64'
  68. },
  69. {
  70. src: 'https://request.dcloud.net.cn/api/http/contentType/image/png',
  71. description: '正确网络路径'
  72. },
  73. {
  74. src: 'https://request.dcloud.net.cn/api/http/contentType/wrongImage/gif',
  75. description: '错误网络格式,假gif实为jpeg'
  76. },
  77. {
  78. src: 'https://request.dcloud.net.cn/api/http/contentType/wrongImage/jpeg',
  79. description: '错误网络格式,假jpg实为png'
  80. },
  81. {
  82. src: 'https://request.dcloud.net.cn/api/http/contentType/wrongImage/png',
  83. description: '错误网络格式,假png实为gif'
  84. },
  85. {
  86. src: 'https://request.dcloud.net.cn/api/http/contentType/404',
  87. description: '错误网络地址404接口'
  88. },
  89. {
  90. src: 'https://request.dcloud.net.cn/api/http/contentType/404.png',
  91. description: '错误网络地址,不存在的图片'
  92. },
  93. {
  94. src: './logo.png',
  95. description: '非static目录的动态路径(不显示是对的)'
  96. },
  97. // #ifdef APP-ANDROID || APP-IOS || APP-HARMONY || MP-WEIXIN
  98. {
  99. src: uni.env.USER_DATA_PATH+'/uni.png',
  100. description: 'uni.env.USER_DATA_PATH 路径'
  101. },
  102. // #endif
  103. // #ifdef APP-ANDROID || APP-IOS || APP-HARMONY
  104. {
  105. src: uni.env.CACHE_PATH+'/uni.png',
  106. description: 'uni.env.CACHE_PATH 路径'
  107. },
  108. {
  109. src: uni.env.SANDBOX_PATH+'/uni.png',
  110. description: 'uni.env.SANDBOX_PATH 路径'
  111. },
  112. // #endif
  113. // #ifdef APP-HARMONY
  114. {
  115. src: `$uni.env.TEMP_PATH/uni.png`,
  116. description: 'uni.env.TEMP_PATH 路径'
  117. },
  118. // #endif
  119. // #ifdef APP-ANDROID
  120. {
  121. src: uni.env.ANDROID_INTERNAL_SANDBOX_PATH+'/uni.png',
  122. description: 'uni.env.ANDROID_INTERNAL_SANDBOX_PATH 路径'
  123. },
  124. // #endif
  125. ] as Array<ImagePath>
  126. }
  127. },
  128. onLoad() {
  129. let fileManager = uni.getFileSystemManager()
  130. // #ifdef APP-ANDROID || APP-HARMONY || MP-WEIXIN
  131. try{
  132. fileManager.accessSync(`${uni.env.USER_DATA_PATH}/uni.png`)
  133. } catch (e) {
  134. fileManager.copyFileSync("/static/uni.png", `${uni.env.USER_DATA_PATH}/uni.png`)
  135. }
  136. // #endif
  137. // #ifdef APP-IOS
  138. fileManager.copyFileSync("/static/uni.png", `${uni.env.USER_DATA_PATH}/uni.png`)
  139. // #endif
  140. // #ifdef APP-ANDROID || APP-HARMONY
  141. try{
  142. fileManager.accessSync(`${uni.env.CACHE_PATH}/uni.png`)
  143. fileManager.accessSync(`${uni.env.SANDBOX_PATH}/uni.png`)
  144. } catch (e) {
  145. console.log("CACHE_PATH error")
  146. fileManager.copyFileSync("/static/uni.png", `${uni.env.CACHE_PATH}/uni.png`)
  147. fileManager.copyFileSync("/static/uni.png", `${uni.env.SANDBOX_PATH}/uni.png`)
  148. }
  149. // #endif
  150. // #ifdef APP-IOS
  151. fileManager.copyFileSync("/static/uni.png", `${uni.env.CACHE_PATH}/uni.png`)
  152. fileManager.copyFileSync("/static/uni.png", `${uni.env.SANDBOX_PATH}/uni.png`)
  153. // #endif
  154. // #ifdef APP-HARMONY
  155. try{
  156. fileManager.accessSync(`${uni.env.TEMP_PATH}/uni.png`)
  157. } catch (e) {
  158. fileManager.copyFileSync("/static/uni.png", `${uni.env.TEMP_PATH}/uni.png`)
  159. }
  160. // #endif
  161. // #ifdef APP-ANDROID
  162. try{
  163. fileManager.accessSync(`${uni.env.ANDROID_INTERNAL_SANDBOX_PATH}/uni.png`)
  164. } catch (e) {
  165. fileManager.copyFileSync("/static/uni.png", `${uni.env.ANDROID_INTERNAL_SANDBOX_PATH}/uni.png`)
  166. }
  167. // #endif
  168. },
  169. methods: {
  170. imageErrorEvent(index : number, e : ImageErrorEvent) {
  171. console.log("图片加载错误", e.detail.errMsg);
  172. // 图片加载失败,加载本地占位图
  173. this.data[index].errorImage = '/static/template/drop-card/dislike.png'
  174. }
  175. },
  176. }
  177. type ImagePath = {
  178. src : string.ImageURIString
  179. errorImage ?: string.ImageURIString | null
  180. description : string
  181. }
  182. </script>
  183. <style>
  184. .image {
  185. margin: 20px auto;
  186. width: 100px;
  187. }
  188. </style>