商家酒店C端预订小程序,每个商家有独立的小程序应用承载。商家可能为单体酒店,也可能是品牌酒店
安装依赖:
npm install
启动:
目前只支持小程序
npm run serve:inquirer
小程序发布上传流程(已接入除景都道的商家):
npm run build:inquirer
> node build/inquire.js
? 是否开始构建? (Use arrow keys)
> 继续
退出
选中要发布的商家小程序即可开始打包对应小程序包
打完包又回到step1
,完成上传(window需要重新进入项目,触发客户端更新小程序appId
)之后可以选择继续
打包
> node build/inquire.js
? 是否开始构建? 继续
? 请选择想要构建的小程序渠道: (Use arrow keys)
> OTM酒店预订小程序
一隅生活微信小程序
余舍微信小程序
邮电大厦微信小程序
OTM联合会员酒店
默认从上到下依次自动切换商家
设置ext.json:
由于uni-app框架不支持设置ext.json,所以需要开发者自行在编译后的小程序代码根目录手动添加ext.json文件,文件模板参考src/ext.json文件(该文件不会被自动编译到小程序根目录,只做参考用)。dist目录不在git跟踪依赖中,开发者可根据需要修改。
目前使用的是华选账号,需要添加为开发者请联系前端负责人。
微信小程序
产品: 阿树
设计师:阿广
前端:laughing、汤姆猫
中间层:陈宇超
底层:
// 本地开发微信
"dev:mp-weixin": "cross-env NODE_ENV=development UNI_PLATFORM=mp-weixin vue-cli-service uni-build --watch",
// 构建微信
"build:mp-weixin": "cross-env NODE_ENV=production UNI_PLATFORM=mp-weixin vue-cli-service uni-build",
src # 目录结构维护原则,就近维护
│ App.vue # 根应用配置文件
│ main.js # Vue初始化入口文件
├─public # 接口目录
│ ├─hotel-share.html # 酒店分享到朋友圈模板html(服务端需要用此html生成转发图片)
├─api # 接口目录
├─components # 公共组件目录
│ ├─global # 公用的注册为全局的组件
│ ├─project # 公用的业务组件
│ └─public # 公用的非业务组件
├─filters # 公共过滤器
├─lib # 公共目录
│ ├─animation # 公用的动画方法
│ ├─style # 全局样式
│ ├─utils # 工具方法库
│ │ ├─sdk # 跨端方法封装(为将来实现多端渠道考虑)
│ │ ├─helper # 公用基础方法
│ │ ├─choose-date-range # 选择日期范围
│ │ ├─choose-phone-prefix # 选择国际电话前缀
│ │ ├─dom # dom操作
│ │ ├─enum # 枚举常量定义
│ └─ └─get-menu-button # 获取小程序胶囊信息
├─pages # 页面
│ ├─common # 公用页面
│ ├─hotel # 酒店模块
│ ├─my # 会员中心
│ ├─order # 订单模块
│ └─order # 支付模块
├─static # 静态资源文件
错误码 | 说明 |
---|---|
100 | 请求成功 |
201 | 请求参数有误 |
202 | 参数不能为空 |
203 | 参数类型有误 |
204 | json参数格式或参数类型有误 |
205 | 参数格式有误 |
301 | 当前日期没有房型 |
303 | 金额校验不对 |
304 | 商品库存不足 |
305 | 当前订单不可退款 |
602 | 验证码错误 |
605 | 小程序登录失败 |
606 | 小程序未绑定手机号码(未注册) |
20001 | 手机号码已绑定 |
440 | 请先登录 |
429 | 请求过于频繁 |
500 | 系统错误 |
501 | 远程调用失败 |
41002 | 酒店不存在 |
41003 | 房型不存在 |
41004 | 领取上限 |
41005 | 优惠券已过期 |
41006 | 库存不足 |
品牌版 首页小程序码:员工id(channel_staff_id)、品牌id(channel_hotel_id) 扫码预订页小程序码(不存在) 会员卡售卖:员工id(channel_staff_id)、品牌id(channel_hotel_id) 门店版 首页小程序码:员工id(channel_staff_id)、门店id(channel_hotel_id) 扫码预订页小程序码:员工id(channel_staff_id)、门店id(channel_hotel_id) 会员卡售卖:员工id(channel_staff_id)、门店id(channel_hotel_id)
以下参考资料: 小程序模板消息能力调整通知(官方) 微信小程序订阅消息汇总,持续跟进中 「笔记」订阅消息体验踩坑 「笔记」小程序模版消息升级为订阅消息
以下文件无需额外引入,已通过插件注入所有页面。
src/lib/style/color.less src/lib/style/mixins.less
为了节省空间,请定义mixins时定义为函数形式,否则即使不使用也会被注入样式文件中浪费空间。
函数形式定义的缺点就是,不能直接在template模板中直接绑定class。
建议:
/* 文本溢出隐藏 */
.line-ellipsis() {
overflow: hidden;
white-space: nowrap;
text-overflow: ellipsis;
}
不建议:
/* 文本溢出隐藏 */
.line-ellipsis {
overflow: hidden;
white-space: nowrap;
text-overflow: ellipsis;
}
其它样式如果需要,就要单独引入使用。
<we-button @click.native="cancel">取消</we-button>
自定义组件绑定class和style样式不会透传到组件内部根元素上
不能直接在自定义组件上使用v-slot作为插槽,需要包裹一层template
自定义组件注册为全局组件时,本地开发需要重启。否则引用时属性传进去全是undefined
自定义组件模式下,子组件修改父组件传入的对象的属性不会更新到视图。
uni-app目前作用域插槽仅支持解构插槽,且作用域插槽不能使用父组件的属性
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。