HBuilderX

HBuilderX

极客开发工具
uni-app

uni-app

开发一次,多端覆盖
uniCloud

uniCloud

云开发平台
HTML5+

HTML5+

增强HTML5的功能体验
MUI

MUI

上万Star的前端框架

uni-pay 配置多个商户动态获取,修改下 /uni-pay-co/service/pay.js 经验

目标 用户点击支付是 动态获取商家的支付配置参数,实现多商户配置,思路:商家支付配置参数储存到数据库然后获取给unipay。
第一步安装导入uniapy2组件 这步骤不说了很简单。。

是这样的 调用支付 ref pay

这里就是调用支付的时候所需的参数我们增加一个商家ID 然后打开\uni_modules\uni-pay\components\uni-pay 这个文件里看一下后面发生的事

这里它调用了创建订单函数就在下面我看了一下 这个才是真正的给unipay云函数传参数的

好这个也看了 我们看下他最后怎么做了

接下来我们去找到这个看一下

\uniCloud\cloudfunctions\uni-pay-co\service\pay,js

这是核心的地方

你因为这就完了,确实完了 但是接受这个参数过程还复杂 我这小白研究半天才实现了
看下面

最后就是按这个格式数据库存储配置信息然后在这个通过商家ID获取对应的配置信息给他就好了

我的思路在这里结束 记录一下吧

继续阅读 »

目标 用户点击支付是 动态获取商家的支付配置参数,实现多商户配置,思路:商家支付配置参数储存到数据库然后获取给unipay。
第一步安装导入uniapy2组件 这步骤不说了很简单。。

是这样的 调用支付 ref pay

这里就是调用支付的时候所需的参数我们增加一个商家ID 然后打开\uni_modules\uni-pay\components\uni-pay 这个文件里看一下后面发生的事

这里它调用了创建订单函数就在下面我看了一下 这个才是真正的给unipay云函数传参数的

好这个也看了 我们看下他最后怎么做了

接下来我们去找到这个看一下

\uniCloud\cloudfunctions\uni-pay-co\service\pay,js

这是核心的地方

你因为这就完了,确实完了 但是接受这个参数过程还复杂 我这小白研究半天才实现了
看下面

最后就是按这个格式数据库存储配置信息然后在这个通过商家ID获取对应的配置信息给他就好了

我的思路在这里结束 记录一下吧

收起阅读 »

国际化vue-i18n报错是版本问题

按照官方文档 推荐使用vue-i18n@9.1.9固定版本安装到项目报一下错误

Uncaught TypeError: Cannot read properties of undefined (reading 'install')
at Vue.use (chunk-vendors.js:20622:23)
at eval (main.js:14:5)
at Object.Vtdi (index.js:3865:1)
at webpack_require (index.js:854:30)
at fn (index.js:151:20)
at 1 (index.js:1244:18)
at
webpack_require
(index.js:854:30)
at checkDeferredModules (index.js:46:23)
at index.js:994:18****

查看本项目vue版本是2.6.14 而vue-i18n@9.1.9是vue3.0版本 经过查阅资料vue2.0版本需要 vue-i18n@5版本 安装5版本即可解决问题

继续阅读 »

按照官方文档 推荐使用vue-i18n@9.1.9固定版本安装到项目报一下错误

Uncaught TypeError: Cannot read properties of undefined (reading 'install')
at Vue.use (chunk-vendors.js:20622:23)
at eval (main.js:14:5)
at Object.Vtdi (index.js:3865:1)
at webpack_require (index.js:854:30)
at fn (index.js:151:20)
at 1 (index.js:1244:18)
at
webpack_require
(index.js:854:30)
at checkDeferredModules (index.js:46:23)
at index.js:994:18****

查看本项目vue版本是2.6.14 而vue-i18n@9.1.9是vue3.0版本 经过查阅资料vue2.0版本需要 vue-i18n@5版本 安装5版本即可解决问题

收起阅读 »

荣耀200真机运行到HBuilder检测不到手机

真机运行

手机型号是荣耀200,用数据线进行调试项目,百度了很多方法,各种方法都尝试了,但是始终检测不到手机!这个问题困扰我很久了
1、安装荣耀手机助手 HonorSuite
2、安装Android SDK Platform-Tools

解决方案:

参考文章:
关于荣耀Magic UI系列HBuilder真机调试检测不到解决办法

继续阅读 »

手机型号是荣耀200,用数据线进行调试项目,百度了很多方法,各种方法都尝试了,但是始终检测不到手机!这个问题困扰我很久了
1、安装荣耀手机助手 HonorSuite
2、安装Android SDK Platform-Tools

解决方案:

参考文章:
关于荣耀Magic UI系列HBuilder真机调试检测不到解决办法

收起阅读 »

【经验分享】uniappX中实现类似pinia-plugin-persist-uni的本地数据缓存

uniapp x

主要的实现方法

export function defineStore<T>(name : string, obj : T) : T {  
    let storage = uni.getStorageSync(name);  
    if (storage instanceof UTSJSONObject) {  
        let data = JSON.parse<T>(JSON.stringify(storage));  
        if (data != null) {  
            let newVal = data as T;  
            obj = reactive(newVal);  
        }  
    }  
    watch(obj as any, () => {  
        uni.setStorage({  
            key: name,  
            data: obj as any  
        });  
    }, {  
        deep: true  
    })  
    return obj;  
}

调用示例:

type UserStore = {  
    initReady : boolean;  
    userInfo: UTSJSONObject;  
}  
export const app = defineStore("app", reactive<UserStore>({  
    initReady: false,  
    userInfo:{}  
}))

页面中app.xxx就是响应式,参考官方文档:https://doc.dcloud.net.cn/uni-app-x/tutorial/store.html#%E5%85%A8%E5%B1%80%E5%8F%98%E9%87%8F%E4%B8%8E%E7%8A%B6%E6%80%81%E7%AE%A1%E7%90%86
如果没有这种处理,app每次启动的时候,状态都会重置。加了后数据就能本地持久化了。

继续阅读 »

主要的实现方法

export function defineStore<T>(name : string, obj : T) : T {  
    let storage = uni.getStorageSync(name);  
    if (storage instanceof UTSJSONObject) {  
        let data = JSON.parse<T>(JSON.stringify(storage));  
        if (data != null) {  
            let newVal = data as T;  
            obj = reactive(newVal);  
        }  
    }  
    watch(obj as any, () => {  
        uni.setStorage({  
            key: name,  
            data: obj as any  
        });  
    }, {  
        deep: true  
    })  
    return obj;  
}

调用示例:

type UserStore = {  
    initReady : boolean;  
    userInfo: UTSJSONObject;  
}  
export const app = defineStore("app", reactive<UserStore>({  
    initReady: false,  
    userInfo:{}  
}))

页面中app.xxx就是响应式,参考官方文档:https://doc.dcloud.net.cn/uni-app-x/tutorial/store.html#%E5%85%A8%E5%B1%80%E5%8F%98%E9%87%8F%E4%B8%8E%E7%8A%B6%E6%80%81%E7%AE%A1%E7%90%86
如果没有这种处理,app每次启动的时候,状态都会重置。加了后数据就能本地持久化了。

收起阅读 »

HBuilderX linux 平台安装包更新,解决一些低版本模块和vue2的编译问题

Linux HBuilderX CLI HBuilderX linux

Linux 环境:

推荐node 版本为 v18.20.7
uapp 版本 >= 2.3.5,uapp -v 可以查看当前使用版本

Ubuntu 22.04 不要使用 apt install nodejs, 这个版本目前发现问题。建议使用 nvm 安装

安装后,必须确认modules 版本为108,如果109或其他的,sass 插件会有问题。查看版本方法:
node -p "process.versions.modules"
输出 108 就对了,否则都有问题。

下载:

https://artisansoft.feishu.cn/docx/NZRHdetSzoi8VEx7KcYcuivpnqd

继续阅读 »

Linux 环境:

推荐node 版本为 v18.20.7
uapp 版本 >= 2.3.5,uapp -v 可以查看当前使用版本

Ubuntu 22.04 不要使用 apt install nodejs, 这个版本目前发现问题。建议使用 nvm 安装

安装后,必须确认modules 版本为108,如果109或其他的,sass 插件会有问题。查看版本方法:
node -p "process.versions.modules"
输出 108 就对了,否则都有问题。

下载:

https://artisansoft.feishu.cn/docx/NZRHdetSzoi8VEx7KcYcuivpnqd

收起阅读 »

Some App Tech Support

移动APP

一、软件介绍
名称:小秘书
类型:办公类应用

二、功能
小秘书是一款办公助手类app,兼具便签、日记本、待办事项等功能,虽然简单却功能齐全、门类清晰,方便统一处理。
【功能】
1.【idea闪现】:将突然出现的好点子捕捉下来
2.【挑战出现】:记录难题和应对方法
3.【经验总结】:帮助你将工作经验记录下来
4.【日程安排】:有序规划生活,达成你的目标
还有更多隐藏功能供探索。
让你随时随地记录灵感!更便捷地处理工作!!并形成经验总结方便日后翻阅

三、Getting Support:

邮箱: royalulugemma@yeah.net

或者评论留言

继续阅读 »

一、软件介绍
名称:小秘书
类型:办公类应用

二、功能
小秘书是一款办公助手类app,兼具便签、日记本、待办事项等功能,虽然简单却功能齐全、门类清晰,方便统一处理。
【功能】
1.【idea闪现】:将突然出现的好点子捕捉下来
2.【挑战出现】:记录难题和应对方法
3.【经验总结】:帮助你将工作经验记录下来
4.【日程安排】:有序规划生活,达成你的目标
还有更多隐藏功能供探索。
让你随时随地记录灵感!更便捷地处理工作!!并形成经验总结方便日后翻阅

三、Getting Support:

邮箱: royalulugemma@yeah.net

或者评论留言

收起阅读 »

uni.onBLECharacteristicValueChange接收不到消息

uniapp

启用低功耗蓝牙设备特征值变化时的 notify 功能 (人话:把这个打开)

deviceId,serviceId,characteristicId这三个值改为你需要回调监听的值

await uni.notifyBLECharacteristicValueChange({  
        state: true,  //设为true  
        deviceId,  
        serviceId,  
        characteristicId,  
})

打开这个监听

这里放一个,

uni.onBLECharacteristicValueChange(function (res) {  
  console.log(`characteristic ${res.characteristicId} has changed, now is ${res.value}`)  
  console.log(ab2hex(res.value))  
})

接下来就是拿这个写入数据

写入一次没用!写入两次第二次监听uni.onBLECharacteristicValueChange中就有数据了

uni.writeBLECharacteristicValue({  
  deviceId,  
  serviceId,  
  characteristicId,  
  value: buffer,  
  success(res) {  
    console.log('writeBLECharacteristicValue success', res.errMsg)  
  }  
})

总结

开启uni.notifyBLECharacteristicValueChange,后放uni.onBLECharacteristicValueChange,然后写入两次 uni.writeBLECharacteristicValue,往后再进行写操作就不用发两次了,初始化第一次时需要发两次

继续阅读 »

启用低功耗蓝牙设备特征值变化时的 notify 功能 (人话:把这个打开)

deviceId,serviceId,characteristicId这三个值改为你需要回调监听的值

await uni.notifyBLECharacteristicValueChange({  
        state: true,  //设为true  
        deviceId,  
        serviceId,  
        characteristicId,  
})

打开这个监听

这里放一个,

uni.onBLECharacteristicValueChange(function (res) {  
  console.log(`characteristic ${res.characteristicId} has changed, now is ${res.value}`)  
  console.log(ab2hex(res.value))  
})

接下来就是拿这个写入数据

写入一次没用!写入两次第二次监听uni.onBLECharacteristicValueChange中就有数据了

uni.writeBLECharacteristicValue({  
  deviceId,  
  serviceId,  
  characteristicId,  
  value: buffer,  
  success(res) {  
    console.log('writeBLECharacteristicValue success', res.errMsg)  
  }  
})

总结

开启uni.notifyBLECharacteristicValueChange,后放uni.onBLECharacteristicValueChange,然后写入两次 uni.writeBLECharacteristicValue,往后再进行写操作就不用发两次了,初始化第一次时需要发两次

收起阅读 »

[项目外包] 外包一个uniapp+uncloud的网页公众号开发,类AI聊天应用

外包接单 外包

开发要求:
1、请使用uni-app和uni-cloud进行开发,要求使用js开发,不要ts
2、功能界面需要精美,大气(有UI),动画效果需要有质感。
3、界面与交互要求
UI设计需提供完整设计稿(Figma/Sketch/PSD),开发者需按设计还原。
动画效果需流畅且有质感,需增加对动画在低端设备上流畅性的考量。
兼容性:Chrome、Safari、微信内置浏览器。
4、技术方案要求:
前端框架:uni-app(要求使用JavaScript进行开发)可使用其他UI框架
后端服务:uni-cloud阿里云版
支付解决方案:uni-pay
AI聊天:参考uni-ai-chat的流式响应实现(可选),建议结合uni-push2提高用户体验
UI设计:需精美大气,并具有良好的动画质感
兼容性:确保在主流浏览器上的良好表现
5、性能要求:
页面响应延迟需低于1秒。

开发者要求:
1、 至少两年以上uni-app手机端开发经验
2、 使用过uni-cloud,有作品可看
3、 接过2个或以上单子并成功交付

验收标准:
1、所有功能需求实现且无重大BUG。
2、UI设计稿与实现效果一致,动画流畅。
3、通过微信公众号、消息推送等官方审核流程。

交付要求:
1、需交付整套源代码
2、源代码注释详细

报价方式:
总包制(需分阶段付款:30%预付款+40%中期验收+30%交付尾款)。
30%预付款:合同签订后立即支付
40%中期验收:完成核心功能开发并通过内部测试,80%功能
30%交付尾款:所有功能开发完毕并通过最终验收后。
具体交付成果:完整的应用程序源码及其相关资源文件、用户手册和技术文档,涵盖部署指南、API文档等。确保应用程序在主流浏览器上的兼容性,并通过微信公众号平台的所有审核流程
验收标准:
应用程序完全按照需求文档的要求实现了所有功能,不存在重大BUG。
UI设计与最初的设计稿高度一致,动画效果流畅自然。
应用程序已成功上线或准备好上线,所有必要的官方审核均已通过

v:Peter-A-Gao
私信不一定看到,有意向+
UI设计稿签订合同后单独提供。

继续阅读 »

开发要求:
1、请使用uni-app和uni-cloud进行开发,要求使用js开发,不要ts
2、功能界面需要精美,大气(有UI),动画效果需要有质感。
3、界面与交互要求
UI设计需提供完整设计稿(Figma/Sketch/PSD),开发者需按设计还原。
动画效果需流畅且有质感,需增加对动画在低端设备上流畅性的考量。
兼容性:Chrome、Safari、微信内置浏览器。
4、技术方案要求:
前端框架:uni-app(要求使用JavaScript进行开发)可使用其他UI框架
后端服务:uni-cloud阿里云版
支付解决方案:uni-pay
AI聊天:参考uni-ai-chat的流式响应实现(可选),建议结合uni-push2提高用户体验
UI设计:需精美大气,并具有良好的动画质感
兼容性:确保在主流浏览器上的良好表现
5、性能要求:
页面响应延迟需低于1秒。

开发者要求:
1、 至少两年以上uni-app手机端开发经验
2、 使用过uni-cloud,有作品可看
3、 接过2个或以上单子并成功交付

验收标准:
1、所有功能需求实现且无重大BUG。
2、UI设计稿与实现效果一致,动画流畅。
3、通过微信公众号、消息推送等官方审核流程。

交付要求:
1、需交付整套源代码
2、源代码注释详细

报价方式:
总包制(需分阶段付款:30%预付款+40%中期验收+30%交付尾款)。
30%预付款:合同签订后立即支付
40%中期验收:完成核心功能开发并通过内部测试,80%功能
30%交付尾款:所有功能开发完毕并通过最终验收后。
具体交付成果:完整的应用程序源码及其相关资源文件、用户手册和技术文档,涵盖部署指南、API文档等。确保应用程序在主流浏览器上的兼容性,并通过微信公众号平台的所有审核流程
验收标准:
应用程序完全按照需求文档的要求实现了所有功能,不存在重大BUG。
UI设计与最初的设计稿高度一致,动画效果流畅自然。
应用程序已成功上线或准备好上线,所有必要的官方审核均已通过

v:Peter-A-Gao
私信不一定看到,有意向+
UI设计稿签订合同后单独提供。

收起阅读 »

关于unicloud-db模糊搜索_id字段无效的解决方案

clientDB

使用正则判定一下输入的值是否为objectId

如果是就使用查询command.eq( )方式查询

否则就使用test正则校验查询

isValidObjectId(id) {  
        return /^[0-9a-fA-F]{24}$/.test(id);  
      },  

 getWhere() {  
      const query = this.query.trim();  
      if (!query) return '';  

      // 优先处理 _id 精确查询  
      if (this.isValidObjectId(query)) {  
        return { _id: uniCloud.database().command.eq(query) };  
      }  

      // 处理普通字段正则搜索  
      const escapedQuery = query.replace(/[.*+?^${}()|[\]\\]/g, '\\$&');  
      const regex = new RegExp(escapedQuery, 'i');  

      return {  
        $or: dbSearchFields.map(field => ({  
          [field]: regex  
        }))  
      };  
    },
继续阅读 »

使用正则判定一下输入的值是否为objectId

如果是就使用查询command.eq( )方式查询

否则就使用test正则校验查询

isValidObjectId(id) {  
        return /^[0-9a-fA-F]{24}$/.test(id);  
      },  

 getWhere() {  
      const query = this.query.trim();  
      if (!query) return '';  

      // 优先处理 _id 精确查询  
      if (this.isValidObjectId(query)) {  
        return { _id: uniCloud.database().command.eq(query) };  
      }  

      // 处理普通字段正则搜索  
      const escapedQuery = query.replace(/[.*+?^${}()|[\]\\]/g, '\\$&');  
      const regex = new RegExp(escapedQuery, 'i');  

      return {  
        $or: dbSearchFields.map(field => ({  
          [field]: regex  
        }))  
      };  
    },
收起阅读 »

Shiply Android应用内升级:灵活高效的版本发布解决方案

Shiply Android应用内升级功能为开发者提供了一套完整的版本发布管理工具,支持灰度放量和立即全量等发布模式,帮助开发者在确保应用稳定性的同时,高效完成新版本推送。

核心功能亮点

灰度发布能力

  • 精准控制:逐步向部分用户推送新版本,降低发布风险
  • 智能匹配:基于用户画像、设备特征等维度进行精准下发
  • 实时监控:关键指标动态追踪,确保发布过程可控

全量升级支持

  • 一键推送:快速完成全量用户版本覆盖
  • 强制更新:确保关键版本及时渗透
  • 版本追溯:完整记录发布历史,支持快速排查定位问题

插件地址:https://ext.dcloud.net.cn/plugin?id=21913

继续阅读 »

Shiply Android应用内升级功能为开发者提供了一套完整的版本发布管理工具,支持灰度放量和立即全量等发布模式,帮助开发者在确保应用稳定性的同时,高效完成新版本推送。

核心功能亮点

灰度发布能力

  • 精准控制:逐步向部分用户推送新版本,降低发布风险
  • 智能匹配:基于用户画像、设备特征等维度进行精准下发
  • 实时监控:关键指标动态追踪,确保发布过程可控

全量升级支持

  • 一键推送:快速完成全量用户版本覆盖
  • 强制更新:确保关键版本及时渗透
  • 版本追溯:完整记录发布历史,支持快速排查定位问题

插件地址:https://ext.dcloud.net.cn/plugin?id=21913

收起阅读 »

HBuilderX在ai编程时代,已经掉队了!

现在国内比较先进的ai编程大模型,例如通义灵码和Deepseek,vscode,webstorm这些编辑器都很快接入了,但hbuilderx至今还没有接入,比其他同类编辑器慢太多。而且官方貌似也不重视这个,在ai编程时代,hbuilderx已经快掉队了

现在国内比较先进的ai编程大模型,例如通义灵码和Deepseek,vscode,webstorm这些编辑器都很快接入了,但hbuilderx至今还没有接入,比其他同类编辑器慢太多。而且官方貌似也不重视这个,在ai编程时代,hbuilderx已经快掉队了

可以把uniapp 的一些公共页面抽离出来 提供给其它项目对接?

插件

可以把uniapp 的一些公共页面抽离出来 提供给其它项目对接?

比如当前项目的 几个公共页面 a,b,c 包括里面的跳转逻辑 和 业务逻辑 然后提供给其它项目 比如 app 小程序使用

可以把uniapp 的一些公共页面抽离出来 提供给其它项目对接?

比如当前项目的 几个公共页面 a,b,c 包括里面的跳转逻辑 和 业务逻辑 然后提供给其它项目 比如 app 小程序使用