HBuilderX

HBuilderX

极客开发工具
uni-app

uni-app

开发一次,多端覆盖
uniCloud

uniCloud

云开发平台
HTML5+

HTML5+

增强HTML5的功能体验
MUI

MUI

上万Star的前端框架

zui-svg-icon自动生成icon

做了个监听文件改动的webpack插件,监听 /assets/svg-icons 下的文件改动,自动执行 npm run svgicon

就不用每次新增icon都跑一遍脚本

文件一: 根目录下创建:build/icon-watcher.js

const fs = require('fs');  
const path = require('path');  
const {  
    exec  
} = require('child_process');  

let timer = null;  

const watchDir = path.resolve(__dirname, '../assets/svg-icons');  
const projectRoot = path.resolve(__dirname, '../');  

class IconWatcherPlugin {  
    apply(compiler) {  
        compiler.hooks.afterEmit.tap('IconWatcherPlugin', () => {  
            console.log('zui-svg-icon 开始监听/assets/svg-icons文件改动')  
            fs.watch(watchDir, {  
                recursive: true  
            }, (eventType, filename) => {  
                if (filename) {  

                    if (timer) {  
                        clearTimeout(timer);  
                    }  
                    timer = setTimeout(() => {  
                        console.log(`zui-svg-icon 改动类型: ${eventType}`);  
                        console.log(`zui-svg-icon 文件名: ${filename}`);  
                        exec('npm run svgicon', {  
                            cwd: projectRoot  
                        }, (error, stdout, stderr) => {  
                            if (error) {  
                                console.error(`zui-svg-icon  exec error: ${error}`);  
                                console.error(`zui-svg-icon  stderr: ${stderr}`);  
                                return;  
                            }  
                            console.log(`zui-svg-icon stdout: ${stdout}`);  
                        });  
                    }, 500)  
                }  
            });  

        });  
    }  
}  

module.exports = IconWatcherPlugin;

vue.config.js中引入

javascript  

const IconWatcherPlugin = require('./build/icon-watcher');  

module.exports = {  
        // ....   
    configureWebpack: {  
        plugins: [new IconWatcherPlugin()],  
    }  
}

package.json中配置脚本

json  

{  

    "scripts": {  
        "svgicon": "node ./uni_modules/zui-svg-icon/tools/generate-svg-icon.js"  
    }  
}
继续阅读 »

做了个监听文件改动的webpack插件,监听 /assets/svg-icons 下的文件改动,自动执行 npm run svgicon

就不用每次新增icon都跑一遍脚本

文件一: 根目录下创建:build/icon-watcher.js

const fs = require('fs');  
const path = require('path');  
const {  
    exec  
} = require('child_process');  

let timer = null;  

const watchDir = path.resolve(__dirname, '../assets/svg-icons');  
const projectRoot = path.resolve(__dirname, '../');  

class IconWatcherPlugin {  
    apply(compiler) {  
        compiler.hooks.afterEmit.tap('IconWatcherPlugin', () => {  
            console.log('zui-svg-icon 开始监听/assets/svg-icons文件改动')  
            fs.watch(watchDir, {  
                recursive: true  
            }, (eventType, filename) => {  
                if (filename) {  

                    if (timer) {  
                        clearTimeout(timer);  
                    }  
                    timer = setTimeout(() => {  
                        console.log(`zui-svg-icon 改动类型: ${eventType}`);  
                        console.log(`zui-svg-icon 文件名: ${filename}`);  
                        exec('npm run svgicon', {  
                            cwd: projectRoot  
                        }, (error, stdout, stderr) => {  
                            if (error) {  
                                console.error(`zui-svg-icon  exec error: ${error}`);  
                                console.error(`zui-svg-icon  stderr: ${stderr}`);  
                                return;  
                            }  
                            console.log(`zui-svg-icon stdout: ${stdout}`);  
                        });  
                    }, 500)  
                }  
            });  

        });  
    }  
}  

module.exports = IconWatcherPlugin;

vue.config.js中引入

javascript  

const IconWatcherPlugin = require('./build/icon-watcher');  

module.exports = {  
        // ....   
    configureWebpack: {  
        plugins: [new IconWatcherPlugin()],  
    }  
}

package.json中配置脚本

json  

{  

    "scripts": {  
        "svgicon": "node ./uni_modules/zui-svg-icon/tools/generate-svg-icon.js"  
    }  
}
收起阅读 »

仿抖音短视频上下滑动视频组件分享

列表流畅滑动 微信小程序 短视频

分享短视频小程序上下滑动组件,支持微信小程序,抖音小程序,h5端,APP端。喜欢的小伙伴们下载使用,仅提供前端组件。

分享短视频小程序上下滑动组件,支持微信小程序,抖音小程序,h5端,APP端。喜欢的小伙伴们下载使用,仅提供前端组件。

现在插件广告收入低的过分了吧

现在插件广告收入低的过分了吧。哪怕是新上线的插件,每条广告的平均收入仅在3分啊

现在插件广告收入低的过分了吧。哪怕是新上线的插件,每条广告的平均收入仅在3分啊

hbuilderx开发的app获取公钥和MD5的方法

app备案

阿里云提示需要安装jadx-gui和使用mac来获取app的公钥和MD5这些信息。

这样就比较麻烦了,使用uniapp开发就是为了跨系统开发,假如还需要mac或jadx-gui,就不灵活了。

所以这里建议使用下面方式来获取公钥和md5值

ios查询方法:

https://www.yunedit.com/iosmd5

android查询方法:

https://www.yunedit.com/androidmd5​​​​​​

继续阅读 »

阿里云提示需要安装jadx-gui和使用mac来获取app的公钥和MD5这些信息。

这样就比较麻烦了,使用uniapp开发就是为了跨系统开发,假如还需要mac或jadx-gui,就不灵活了。

所以这里建议使用下面方式来获取公钥和md5值

ios查询方法:

https://www.yunedit.com/iosmd5

android查询方法:

https://www.yunedit.com/androidmd5​​​​​​

收起阅读 »

在global.scss文件中使用scss变量无效??

scss

在scss文件中使用scss变量无效??
经测试,在App端无效果,但是在Web中可以生效

但是在app.vue文件中使用可以生效

在uni.scss文件导入variables.scss和通过脚手架配置都不生效

继续阅读 »

在scss文件中使用scss变量无效??
经测试,在App端无效果,但是在Web中可以生效

但是在app.vue文件中使用可以生效

在uni.scss文件导入variables.scss和通过脚手架配置都不生效

收起阅读 »

关于map组件绘制markers,polyline可能会出现重绘的问题

地图 map

当前遇到在绘制markers,polyline之后,地图会闪动并且只显示设置的经纬度点,这个有可能是某些代码逻辑涉及到了地图绘制,导致地图多次重绘.所以需要检查这部分的代码,保证地图只需要重绘一次即可.

当前遇到在绘制markers,polyline之后,地图会闪动并且只显示设置的经纬度点,这个有可能是某些代码逻辑涉及到了地图绘制,导致地图多次重绘.所以需要检查这部分的代码,保证地图只需要重绘一次即可.

【已解决】调试链接已关闭。原因websocket已断开 项目真机调试,打开webview调试,显示调试连接已关闭是什么回事?

WebView调试模式常见问题 WebView调试

【已经解决】如果你正在开发app应用,打开webview的时候提示websocket
我本地的是两个wifi,分别的是A和A_5G A_5G工作时候使用,A是2.4H的,给家用电器使用,有一次电脑抓包,不知道为啥,电脑和手机都切换成了A才能成功,出去回来后,手机自动连接的A_5G,电脑自动连接的A,导致不在一个wifi下面,所以不成功,把电脑的wifi设置成A_5G后问题迎刃而解
所以前面几天手机投屏不到电视,也是这个原因,有问题的就试试吧

继续阅读 »

【已经解决】如果你正在开发app应用,打开webview的时候提示websocket
我本地的是两个wifi,分别的是A和A_5G A_5G工作时候使用,A是2.4H的,给家用电器使用,有一次电脑抓包,不知道为啥,电脑和手机都切换成了A才能成功,出去回来后,手机自动连接的A_5G,电脑自动连接的A,导致不在一个wifi下面,所以不成功,把电脑的wifi设置成A_5G后问题迎刃而解
所以前面几天手机投屏不到电视,也是这个原因,有问题的就试试吧

收起阅读 »

打包ios,传ipa文件到app store最简教程

应用上架

ios的证书创建、安装或上架,并没有安卓这么简单直接。它的打包需要通过苹果开发者中心生成证书,安装的话,也是根据证书的类型决定,假如是普通的证书或普通company证书只能上架才能安装(测试的话有其他安装方法,那是另外的话题),假如是企业类型的in house证书,则可以通过在线安装的方式,比如通过上传到一些分发平台,比如香蕉云编或蒲公英生成安装码扫码安装。

因为生成证书需要苹果开发者账号,开发者根据是否需要上架选择不同的类型注册。

下面是申请公司或企业类型的苹果开发者账号的方法:

https://blog.csdn.net/hepingdev/article/details/125489193

有了证书后,就可以创建证书进行打包了,假如是生成上架或测试打包的证书,可以参考这篇文章:

https://blog.csdn.net/handsome0916/article/details/140115616

假如是想生成企业in house类型的证书,可参考这篇文章

https://blog.csdn.net/handsome0916/article/details/140435304

通过上述教程生成证书后,就可以安装或者上架。

假如是上架,可以参考这篇文章:

https://zhuanlan.zhihu.com/p/352455941

继续阅读 »

ios的证书创建、安装或上架,并没有安卓这么简单直接。它的打包需要通过苹果开发者中心生成证书,安装的话,也是根据证书的类型决定,假如是普通的证书或普通company证书只能上架才能安装(测试的话有其他安装方法,那是另外的话题),假如是企业类型的in house证书,则可以通过在线安装的方式,比如通过上传到一些分发平台,比如香蕉云编或蒲公英生成安装码扫码安装。

因为生成证书需要苹果开发者账号,开发者根据是否需要上架选择不同的类型注册。

下面是申请公司或企业类型的苹果开发者账号的方法:

https://blog.csdn.net/hepingdev/article/details/125489193

有了证书后,就可以创建证书进行打包了,假如是生成上架或测试打包的证书,可以参考这篇文章:

https://blog.csdn.net/handsome0916/article/details/140115616

假如是想生成企业in house类型的证书,可参考这篇文章

https://blog.csdn.net/handsome0916/article/details/140435304

通过上述教程生成证书后,就可以安装或者上架。

假如是上架,可以参考这篇文章:

https://zhuanlan.zhihu.com/p/352455941

收起阅读 »

社区插件用的真烦 想用插件根本就联系不到人

uniapp插件

写了插件 然后也不留联系方式, 弄个交流群 说话也没人回 写插件的时候能不能留一下联系人

如果你免费不留也就算了 买了插件 使用各种问题 联系不到人 白白浪费了 例子也不全 也不留截图

写了插件 然后也不留联系方式, 弄个交流群 说话也没人回 写插件的时候能不能留一下联系人

如果你免费不留也就算了 买了插件 使用各种问题 联系不到人 白白浪费了 例子也不全 也不留截图

关于map组件markers的自定义icon不显示

map

目前我遇到的是因为markers的id相同所以不显示,需要设置不同的id

注:
如果icon不显示,可以设置以下几种方式,有时候加载会慢一点
1.使用静态资源
2.使用网络资源

  1. 把图片转成base64

目前我遇到的是因为markers的id相同所以不显示,需要设置不同的id

注:
如果icon不显示,可以设置以下几种方式,有时候加载会慢一点
1.使用静态资源
2.使用网络资源

  1. 把图片转成base64

[项目外包]外包一个UNIAPP项目

外包

需开发一个安卓APP项目,TV端,APP需打包为启动器,能自动热更,能自动下载APP并安装等一些功能,有兴趣的联系我啦~~

需开发一个安卓APP项目,TV端,APP需打包为启动器,能自动热更,能自动下载APP并安装等一些功能,有兴趣的联系我啦~~