HBuilderX

HBuilderX

极客开发工具
uni-app

uni-app

开发一次,多端覆盖
uniCloud

uniCloud

云开发平台
HTML5+

HTML5+

增强HTML5的功能体验
MUI

MUI

上万Star的前端框架

个推推送标识有时候获取不到解决办法,plus.push.getClientInfo().clientid

    mui.plusReady(function() {  
            localStorage.tuisong0843 = plus.push.getClientInfo().clientid;  
            console.log(localStorage.tuisong0843);  
            if (!localStorage.tuisong0843) {  
                function uuidxunhuan1304() {  
                    console.log('开始循环获取');  
                    localStorage.tuisong0843 = plus.push.getClientInfo().clientid;  
                    if (localStorage.tuisong0843) {  
                        console.log('获取成功');  
                        return;  
                    } else {  
                        console.log('没有获取成功');  
                        window.setTimeout(function() {  
                            uuidxunhuan1304();  
                        }, 1000);  
                    }  
                }  
                uuidxunhuan1304();  
            }  
        })
继续阅读 »
    mui.plusReady(function() {  
            localStorage.tuisong0843 = plus.push.getClientInfo().clientid;  
            console.log(localStorage.tuisong0843);  
            if (!localStorage.tuisong0843) {  
                function uuidxunhuan1304() {  
                    console.log('开始循环获取');  
                    localStorage.tuisong0843 = plus.push.getClientInfo().clientid;  
                    if (localStorage.tuisong0843) {  
                        console.log('获取成功');  
                        return;  
                    } else {  
                        console.log('没有获取成功');  
                        window.setTimeout(function() {  
                            uuidxunhuan1304();  
                        }, 1000);  
                    }  
                }  
                uuidxunhuan1304();  
            }  
        })
收起阅读 »

uniapp代码块

将以下代码放到自定义vue代码块中,在其他页面输入uniapp回车即可显示出模板,名字可以改。

将以下代码放到自定义vue代码块中,在其他页面输入uniapp回车即可显示出模板,名字可以改。

vue h5转换uni-app指南(vue转uni、h5转uni)

转换 vue转 h5转

如果你已经有了一个基于vue开发的H5站点,想转换为uni-app。

首先注意2个前提:1、你的web站是适合手机屏幕的;2、你的H5代码是全后端分离的,uni-app只处理前端代码。

一切从新建一个uni-app项目开始。然后依次进行

文件处理

  1. 把之前的vue web项目的前端代码copy到新项目下
  2. 如果之前的文件后缀名是.html,需要改为.vue,并注意遵循vue单文件组件SFC规范,比如必须一级根节点为template、script、style,template节点下必须且只能有一个根view节点,所有内容写在这个根view节点下。
  3. 处理页面路由
    uni-app默认是小程序的路由方式,在pages.json里管理页面。如果你使用vue router的话,一种是改造为pages.json方式,另一种是使用三方插件,比如vue router for uni-app
  4. 静态文件(如图片)挪到static目录
    uni-app工程目录下有个static目录,用于存放静态文件,这个目录不编译,直接整体copy到发行代码里的。
    如果你希望自定义静态资源目录,可以在vue.config.js中自定义。

标签代码处理

  1. 相同功能的组件自动转换
    uni-app的标签组件与小程序相同,比如<div>变成了<view><span>变成了<text>
    uni-app的编译器已经自动处理了这部分转换,如果源码中写了可自动转换的组件,在编译到非H5端时会被自动转换(再编译回到H5端时div还是div)。
  2. 区域滚动使用scroll-view,不再使用div的区域滚动处理方式
  3. 左右、上下滑动切换,有专门的swiper组件,不要使用div模拟
  4. input的search,原来的type没用了,改成confirmtype,详见
  5. audio组件不再推荐使用,改成api方式,背景音频api文档
  6. 之前的v-html,可以在H5端和App端(需v3编译器)使用,不能在小程序中使用。如需要在小程序使用,请使用rich-text组件或uparse扩展插件,详见

js代码处理

uni-app的非H5端,不管是App还是各种小程序,都不支持window、navigator、document等web专用对象。
uni-app的API与小程序保持一致,需要处理这些不同的API写法

  1. 处理window api
  2. 处理navigator api
  3. 处理dom api
    • 如果使用标准vue的数据绑定,是不需要操作dom来修改界面内容的。如果没有使用vue数据绑定,仍然混写了jquery等dom操作,需要改为纯数据绑定
    • 有时获取dom并不是为了修改显示内容,而是为了获取元素的长宽尺寸来做布局。此时uni-app提供了同小程序的另一种API,uni.createSelectorQuery
  4. 其他js api
    web中还有canvas、video、audio、websocket、webgl、webbluetooth、webnfc,这些在uni-app中都有专门的API。
  5. 生命周期
    uni-app补充了一批类小程序的声明周期,包括App的启动、页面的加载,详见https://uniapp.dcloud.io/collocation/frame/lifetime
    vue h5一般在created或者mounted中请求数据,而在uni-app的页面中,使用onLoad或者onShow中请求数据。(组件仍然是created或者mounted)
  6. 少量不常用的vue语法在非h5端仍不支持,data必须以return的方式编写,注意事项详见

注意:如果你使用了一些三方ui框架、js库,其中引用了包括一些使用了dom、window、navigator的三方库,除非你只做H5端,否则需要更换。去uni-app的插件市场寻找替代品。如果找不到对应库,必须使用for web的库,在App端可以使用renderjs来引入这些for web的库。

css代码处理

uni-app发布到App(非nvue)、小程序时,显示页面仍然由webview渲染,css大部分是支持的。但需要注意

  • 不支持 *选择器
  • 没有body元素选择器,改用page元素选择器。(编译到非H5时,编译器会自动处理。所以不改也行)
  • div等元素选择器改为view、span和font改为text、a改为navigator、img改为image...(编译到非H5时,编译器会自动处理。所以不改也行)
  • 不同端的浏览器兼容性仍然存在,避免使用太新的css语法,否则发布为App时,Android低端机(Android 4.4、5.x),会有样式错误。当然在App端也可以引用x5浏览器内核来抹平浏览器差异。

本文是思路,不是工具。我们鼓励和欢迎开发者编写垫片API和转换器,方便更多人使用。

继续阅读 »

如果你已经有了一个基于vue开发的H5站点,想转换为uni-app。

首先注意2个前提:1、你的web站是适合手机屏幕的;2、你的H5代码是全后端分离的,uni-app只处理前端代码。

一切从新建一个uni-app项目开始。然后依次进行

文件处理

  1. 把之前的vue web项目的前端代码copy到新项目下
  2. 如果之前的文件后缀名是.html,需要改为.vue,并注意遵循vue单文件组件SFC规范,比如必须一级根节点为template、script、style,template节点下必须且只能有一个根view节点,所有内容写在这个根view节点下。
  3. 处理页面路由
    uni-app默认是小程序的路由方式,在pages.json里管理页面。如果你使用vue router的话,一种是改造为pages.json方式,另一种是使用三方插件,比如vue router for uni-app
  4. 静态文件(如图片)挪到static目录
    uni-app工程目录下有个static目录,用于存放静态文件,这个目录不编译,直接整体copy到发行代码里的。
    如果你希望自定义静态资源目录,可以在vue.config.js中自定义。

标签代码处理

  1. 相同功能的组件自动转换
    uni-app的标签组件与小程序相同,比如<div>变成了<view><span>变成了<text>
    uni-app的编译器已经自动处理了这部分转换,如果源码中写了可自动转换的组件,在编译到非H5端时会被自动转换(再编译回到H5端时div还是div)。
  2. 区域滚动使用scroll-view,不再使用div的区域滚动处理方式
  3. 左右、上下滑动切换,有专门的swiper组件,不要使用div模拟
  4. input的search,原来的type没用了,改成confirmtype,详见
  5. audio组件不再推荐使用,改成api方式,背景音频api文档
  6. 之前的v-html,可以在H5端和App端(需v3编译器)使用,不能在小程序中使用。如需要在小程序使用,请使用rich-text组件或uparse扩展插件,详见

js代码处理

uni-app的非H5端,不管是App还是各种小程序,都不支持window、navigator、document等web专用对象。
uni-app的API与小程序保持一致,需要处理这些不同的API写法

  1. 处理window api
  2. 处理navigator api
  3. 处理dom api
    • 如果使用标准vue的数据绑定,是不需要操作dom来修改界面内容的。如果没有使用vue数据绑定,仍然混写了jquery等dom操作,需要改为纯数据绑定
    • 有时获取dom并不是为了修改显示内容,而是为了获取元素的长宽尺寸来做布局。此时uni-app提供了同小程序的另一种API,uni.createSelectorQuery
  4. 其他js api
    web中还有canvas、video、audio、websocket、webgl、webbluetooth、webnfc,这些在uni-app中都有专门的API。
  5. 生命周期
    uni-app补充了一批类小程序的声明周期,包括App的启动、页面的加载,详见https://uniapp.dcloud.io/collocation/frame/lifetime
    vue h5一般在created或者mounted中请求数据,而在uni-app的页面中,使用onLoad或者onShow中请求数据。(组件仍然是created或者mounted)
  6. 少量不常用的vue语法在非h5端仍不支持,data必须以return的方式编写,注意事项详见

注意:如果你使用了一些三方ui框架、js库,其中引用了包括一些使用了dom、window、navigator的三方库,除非你只做H5端,否则需要更换。去uni-app的插件市场寻找替代品。如果找不到对应库,必须使用for web的库,在App端可以使用renderjs来引入这些for web的库。

css代码处理

uni-app发布到App(非nvue)、小程序时,显示页面仍然由webview渲染,css大部分是支持的。但需要注意

  • 不支持 *选择器
  • 没有body元素选择器,改用page元素选择器。(编译到非H5时,编译器会自动处理。所以不改也行)
  • div等元素选择器改为view、span和font改为text、a改为navigator、img改为image...(编译到非H5时,编译器会自动处理。所以不改也行)
  • 不同端的浏览器兼容性仍然存在,避免使用太新的css语法,否则发布为App时,Android低端机(Android 4.4、5.x),会有样式错误。当然在App端也可以引用x5浏览器内核来抹平浏览器差异。

本文是思路,不是工具。我们鼓励和欢迎开发者编写垫片API和转换器,方便更多人使用。

收起阅读 »

迫于客户说uparse卡顿,分享一个rich-text的简单方案

rich_text

使用场景是商品详情页 多张大图 基本没有复杂样式

uparse碰到的问题是,图片加载卡顿,需要等一段时间才能适应全屏

使用rich-text h5下没有太大问题 其他平台图片可能超出屏幕宽度

使用方法

data() {  
            return {  
                content:`<img style='' src='/static/image/Businessmen.png'></img>`  
            }  
        },  
        onLoad() {  
                this.content=htmlBeautify(this.content,{  
                                                                                                  img: {  
                                                                                           "max-width": "100%"  
                                                                                             }  
                                                                                               })  
        },
/**  
 * 给html添加指定样式 常用于rich text的子节点  
 * @param {*} html 需要处理的html文本  
 * @param {*} rule {  
            img: {  
                "max-width": "100%"  
            }  
        }   增加的样式规则 {元素名称:{css名称:属性}}  
 */  
const htmlBeautify = (html, rule) => {  
    if (!rule) {  
        rule = {  
            img: {  
                "max-width": "100%"  
            }  
        }  
    }  

    for (const key in rule) {  
        if (rule.hasOwnProperty(key)) {  
            const element = rule[key];  
            let style = ';'  
            for (const k in element) {  
                if (element.hasOwnProperty(k)) {  
                    const v = element[k];  
                    style += `${k}:${v};`  
                }  
            }  

            // let reg = new RegExp(`<${key}>`, 'g')  
            var reg = new RegExp(`(i?)(\<${key})(?!(.*?style=[\'\"](.*)[\'\"])[^\>]+\>)`, "gmi");  
            let reg1 = new RegExp(`<${key}(.*?)style=[\'\"](.*?)[\'\"]`, 'gmi')  

            html = html.replace(reg, `$2 style="" $3`).replace(reg1, `<${key} $1 style="$2${style}"`)  
        }  
    }  
    // html = html.replace(/<p>/, '<p style="">').replace(/<p(.*?)style=[\'\"](.*?)[\'\"]/g, `<p $1 style="$2;max-width:100%;background:#333;"`)  

    console.log(html)  
    return html  
}
继续阅读 »

使用场景是商品详情页 多张大图 基本没有复杂样式

uparse碰到的问题是,图片加载卡顿,需要等一段时间才能适应全屏

使用rich-text h5下没有太大问题 其他平台图片可能超出屏幕宽度

使用方法

data() {  
            return {  
                content:`<img style='' src='/static/image/Businessmen.png'></img>`  
            }  
        },  
        onLoad() {  
                this.content=htmlBeautify(this.content,{  
                                                                                                  img: {  
                                                                                           "max-width": "100%"  
                                                                                             }  
                                                                                               })  
        },
/**  
 * 给html添加指定样式 常用于rich text的子节点  
 * @param {*} html 需要处理的html文本  
 * @param {*} rule {  
            img: {  
                "max-width": "100%"  
            }  
        }   增加的样式规则 {元素名称:{css名称:属性}}  
 */  
const htmlBeautify = (html, rule) => {  
    if (!rule) {  
        rule = {  
            img: {  
                "max-width": "100%"  
            }  
        }  
    }  

    for (const key in rule) {  
        if (rule.hasOwnProperty(key)) {  
            const element = rule[key];  
            let style = ';'  
            for (const k in element) {  
                if (element.hasOwnProperty(k)) {  
                    const v = element[k];  
                    style += `${k}:${v};`  
                }  
            }  

            // let reg = new RegExp(`<${key}>`, 'g')  
            var reg = new RegExp(`(i?)(\<${key})(?!(.*?style=[\'\"](.*)[\'\"])[^\>]+\>)`, "gmi");  
            let reg1 = new RegExp(`<${key}(.*?)style=[\'\"](.*?)[\'\"]`, 'gmi')  

            html = html.replace(reg, `$2 style="" $3`).replace(reg1, `<${key} $1 style="$2${style}"`)  
        }  
    }  
    // html = html.replace(/<p>/, '<p style="">').replace(/<p(.*?)style=[\'\"](.*?)[\'\"]/g, `<p $1 style="$2;max-width:100%;background:#333;"`)  

    console.log(html)  
    return html  
}
收起阅读 »

MUI 日期选择器踩过的坑

mui

我在做关于日期选择的时候 抱着学习心态,引用了 mui.picker.js 文件 和 mui.picker.css 文件.然后我新创建的日期组件 报错
mui.DtPicker is not a constructor

最后发现 mui.picker.js 文件 和 mui.picker.css 文件 和 mui.picker.min.js 文件 和 mui.picker.min.css 文件 是不一样的 少了DtPicker 构造器.

继续阅读 »

我在做关于日期选择的时候 抱着学习心态,引用了 mui.picker.js 文件 和 mui.picker.css 文件.然后我新创建的日期组件 报错
mui.DtPicker is not a constructor

最后发现 mui.picker.js 文件 和 mui.picker.css 文件 和 mui.picker.min.js 文件 和 mui.picker.min.css 文件 是不一样的 少了DtPicker 构造器.

收起阅读 »

【分享】uniapp支持使用vue/test-utils进行单元测试

uniapp

看uniapp github使用了vue/test-utils进行单元测试,点赞~

看uniapp github使用了vue/test-utils进行单元测试,点赞~

为什么选择Hbuilder而放弃了HbuilderX

  1. 我非前端人员,我在Hbuilder里面建了很多项目,为了用到的时候,直接打开看看。但是他不能在HbuilderX里面
  2. 我安装过HbuilderX,文件是小了,打开速度是快了。但是没有Hbuilder的充实感了,安装嗖嗖的,就完成了。桌面连个图标都没有,原来跑右键里去了。整的和notpad++似的。然后想卸载了。。。我竟然照不到卸载的地方,连卸载的exe都没有,更不爽了,百度了好长时间,删文件,删注册表,搞定。
  3. 继续回到Hbuilder里面了,打开,等一会。打开xx.html,ctrl+r运行,真香!!!!!!
继续阅读 »
  1. 我非前端人员,我在Hbuilder里面建了很多项目,为了用到的时候,直接打开看看。但是他不能在HbuilderX里面
  2. 我安装过HbuilderX,文件是小了,打开速度是快了。但是没有Hbuilder的充实感了,安装嗖嗖的,就完成了。桌面连个图标都没有,原来跑右键里去了。整的和notpad++似的。然后想卸载了。。。我竟然照不到卸载的地方,连卸载的exe都没有,更不爽了,百度了好长时间,删文件,删注册表,搞定。
  3. 继续回到Hbuilder里面了,打开,等一会。打开xx.html,ctrl+r运行,真香!!!!!!
收起阅读 »

2.1.1: Mac电脑,右键菜单,svn或git缺少部分菜单项的暂时解决方案

Git SVN

关于HBuilderX 2.1.1版本 【Mac】右键菜单,没有svn更新或git拉取菜单项目的说明

进入菜单【工具】【插件配置】,找到svn或git,卸载重装

关于HBuilderX 2.1.1版本 【Mac】右键菜单,没有svn更新或git拉取菜单项目的说明

进入菜单【工具】【插件配置】,找到svn或git,卸载重装

PC端web-view样式调节、全屏、刷新、内存释放(删除多余iframeDom)

1.样式调节
当你使用web-view标签后会在页面生成一个iframe,我们主要是针对这个生成的iframe做样式调节,要注意的是你在引入web-view组件的vue文件中定义iframe是不会生效的,需要再项目根目录的app.vue 下定义才能生效。(如果项目中有多个模块需要引入样式不一致的iframe那就当我没写过这条~。~)

2.iframe全屏操作
全屏参考https://blog.csdn.net/IT_COOKIE_SAM/article/details/76944134,实现后全屏效果和你在浏览器按F11是一样的。这边注意全屏后要改变iframe中的
allowFullscreen = true才能生效

                        // 全屏  
            intoFull(el){  
                var rfs = el.requestFullScreen || el.webkitRequestFullScreen || el.mozRequestFullScreen || el.msRequestFullScreen,wscript;  
                if(typeof rfs != "undefined" && rfs) {    
                    rfs.call(el);    
                    return;    
                }  
                if(typeof window.ActiveXObject != "undefined") {    
                    wscript = new ActiveXObject("WScript.Shell");    
                    if(wscript) {    
                        wscript.SendKeys("{F11}");    
                    }    
                }  
            },  
            // 退出全屏  
            exitFullScreen(el) {    
                var el= document,cfs = el.cancelFullScreen || el.webkitCancelFullScreen || el.mozCancelFullScreen || el.exitFullScreen,wscript;    
                if (typeof cfs != "undefined" && cfs) {    
                    cfs.call(el);    
                    return;    
                }    
                if (typeof window.ActiveXObject != "undefined") {    
                    wscript = new ActiveXObject("WScript.Shell");    
                    if (wscript != null) {    
                        wscript.SendKeys("{F11}");      
                    }    
                }    
            },  
            // 触发全屏按钮事件  
            fullScreen(){  
                let iframeDom = document.getElementsByTagName("iframe")[0];  
                this.intoFull(iframeDom);  
                iframeDom.allowFullscreen = true  
            },

3.刷新iframe
刷新效果比较简单,直接获取页面上iframe DOM信息然后替换他的src属性(替换contentWindow.location.href也是可以的哦~)

let iframeDom = document.getElementsByTagName("iframe")[0];  
iframeDom.src="xxxxxxxxxxxx";

4.内存释放(删除多余iframeDom)
正如1中所提到的当你使用web-view标签后会在页面生成一个iframe,而你路由发生改变后(跳转页面等操作),生成的iframe是不会自动删除的,也就是说你在引入了web-view的页面不断进入退出会在你页面中生成无数个iframe,带来一系列问题(不知道是不是因为我用了自定义模板的原因,据观察页面跳转时uni-App只会刷新uni-app标签内的内容,可以它理解成route标签,而iframe是生成在body下的并不会被页面渲染到),下图是我进出4次页面后的效果:


解决方案是在在当前页面加载完成后通过this.$watch函数监听路由变化,当路由跳转时触发里面的函数遍历删除页面上的iframe节点,最后在注销路由监听(不注销监听的话watch会在全局监听你的路由触发事件)

// vue生命周期函数  
        mounted(){  
            this.unwatch = this.$watch('$route.path',()=>{  
                let iframeDom = document.getElementsByTagName("iframe");  
                if(iframeDom.length==0){  
                    return false;  
                }else{  
                    for(var i=0;i<iframeDom.length;i++){  
                        //释放iframe内存  
                        iframeDom[i].src = 'about:blank';   
                        try{   
                            iframeDom[i].contentWindow.document.write('');   
                            iframeDom[i].contentWindow.document.clear();   
                        }catch(e){}   
                        //把iframe从页面移除   
                        iframeDom[i].parentNode.removeChild(iframeDom[i]);   
                    }  
                }  
                // 注销路由监听  
                this.unwatch();  
            });  
        },

才疏学浅,希望对需要的人有所帮助。

继续阅读 »

1.样式调节
当你使用web-view标签后会在页面生成一个iframe,我们主要是针对这个生成的iframe做样式调节,要注意的是你在引入web-view组件的vue文件中定义iframe是不会生效的,需要再项目根目录的app.vue 下定义才能生效。(如果项目中有多个模块需要引入样式不一致的iframe那就当我没写过这条~。~)

2.iframe全屏操作
全屏参考https://blog.csdn.net/IT_COOKIE_SAM/article/details/76944134,实现后全屏效果和你在浏览器按F11是一样的。这边注意全屏后要改变iframe中的
allowFullscreen = true才能生效

                        // 全屏  
            intoFull(el){  
                var rfs = el.requestFullScreen || el.webkitRequestFullScreen || el.mozRequestFullScreen || el.msRequestFullScreen,wscript;  
                if(typeof rfs != "undefined" && rfs) {    
                    rfs.call(el);    
                    return;    
                }  
                if(typeof window.ActiveXObject != "undefined") {    
                    wscript = new ActiveXObject("WScript.Shell");    
                    if(wscript) {    
                        wscript.SendKeys("{F11}");    
                    }    
                }  
            },  
            // 退出全屏  
            exitFullScreen(el) {    
                var el= document,cfs = el.cancelFullScreen || el.webkitCancelFullScreen || el.mozCancelFullScreen || el.exitFullScreen,wscript;    
                if (typeof cfs != "undefined" && cfs) {    
                    cfs.call(el);    
                    return;    
                }    
                if (typeof window.ActiveXObject != "undefined") {    
                    wscript = new ActiveXObject("WScript.Shell");    
                    if (wscript != null) {    
                        wscript.SendKeys("{F11}");      
                    }    
                }    
            },  
            // 触发全屏按钮事件  
            fullScreen(){  
                let iframeDom = document.getElementsByTagName("iframe")[0];  
                this.intoFull(iframeDom);  
                iframeDom.allowFullscreen = true  
            },

3.刷新iframe
刷新效果比较简单,直接获取页面上iframe DOM信息然后替换他的src属性(替换contentWindow.location.href也是可以的哦~)

let iframeDom = document.getElementsByTagName("iframe")[0];  
iframeDom.src="xxxxxxxxxxxx";

4.内存释放(删除多余iframeDom)
正如1中所提到的当你使用web-view标签后会在页面生成一个iframe,而你路由发生改变后(跳转页面等操作),生成的iframe是不会自动删除的,也就是说你在引入了web-view的页面不断进入退出会在你页面中生成无数个iframe,带来一系列问题(不知道是不是因为我用了自定义模板的原因,据观察页面跳转时uni-App只会刷新uni-app标签内的内容,可以它理解成route标签,而iframe是生成在body下的并不会被页面渲染到),下图是我进出4次页面后的效果:


解决方案是在在当前页面加载完成后通过this.$watch函数监听路由变化,当路由跳转时触发里面的函数遍历删除页面上的iframe节点,最后在注销路由监听(不注销监听的话watch会在全局监听你的路由触发事件)

// vue生命周期函数  
        mounted(){  
            this.unwatch = this.$watch('$route.path',()=>{  
                let iframeDom = document.getElementsByTagName("iframe");  
                if(iframeDom.length==0){  
                    return false;  
                }else{  
                    for(var i=0;i<iframeDom.length;i++){  
                        //释放iframe内存  
                        iframeDom[i].src = 'about:blank';   
                        try{   
                            iframeDom[i].contentWindow.document.write('');   
                            iframeDom[i].contentWindow.document.clear();   
                        }catch(e){}   
                        //把iframe从页面移除   
                        iframeDom[i].parentNode.removeChild(iframeDom[i]);   
                    }  
                }  
                // 注销路由监听  
                this.unwatch();  
            });  
        },

才疏学浅,希望对需要的人有所帮助。

收起阅读 »

关于plus.gallery.save与uni.saveImageToPhotosAlbum保存临时路径图片,返回成功相册中却找不到的问题的一种可能解

有一种可能是:

图片临时路径中的文件名未包括正确的图片扩展名类型

解决方案是:

在图片临时路径中添加上正确的扩展名即可

有一种可能是:

图片临时路径中的文件名未包括正确的图片扩展名类型

解决方案是:

在图片临时路径中添加上正确的扩展名即可