Unit3 使用 uniCloud 制作书籍管理移动端应用项目

Unit3 使用 uniCloud 制作书籍管理移动端应用项目

    • 1 构建项目并关联云服务空间
    • 2 为项目准备数据库表
    • 3 schema2Code
    • 4 遇到了错误
    • 5 对 "addtime" 字段对应的前端组件进行修改
    • 6 首次运行

1 构建项目并关联云服务空间

  • uniCloud 为开发人员提供了“阿里云”和“腾讯云”两种云服务空间供应商。其中“阿里云”可以创建一个免费的云服务空间,“腾讯云”不提供免费服务。
  • 不管是“阿里云”还是“腾讯云”,如果要使用云服务功能,都必须进行实名制认证。
  • “阿里云”的免费云服务空间有效期是 1 个月,如果需要延长免费使用时间,需要在临到期之前继续以 0 元支付该空间的费用,否则将失去“免费”资格,只能创建付费的云服务空间。

以下是构建一个新的项目,并与uniCloud云服务空间关联的操作步骤。

[1] 新建一个 uni-ui 项目 uniCloudBooks,并启用 uniCloud。

在这里插入图片描述

[2] 项目创建后,在项目管理器中“右键单击” uniCloud 目录,在弹出的快捷菜单中选择 “关联云服务空间或项目”。

在这里插入图片描述

[3] 初次使用 uniCloud 时,由于并没有任何云服务空间,所以在 “关联云服务空间或项目”窗口中看到的列表项应该是空的。需要点击窗口上的“新建”按钮,进入新建云服务空间页面。

在这里插入图片描述

[4] 进入 uniCloud 控制台页面,点击 “新建服务空间” 按钮。

在这里插入图片描述

[5] 免费的阿里云服务空间

在这里插入图片描述

[6] 在 HX 中完成云服务空间与项目之间的关联

在这里插入图片描述

2 为项目准备数据库表

一本书的信息应该包含(但不限于):书名、作者、出版社、封面照片、单价、内容简介等。

为了让小程序更加适用于一个线下书店对所有图书的管理功能,这里可以考虑增加 “剩余数量” 和 “购置日期”两个信息。

uniCloud 的云数据库是一个基于 JSON 格式的文档型数据库。官网的介绍如下:

在这里插入图片描述

以下是在 HX 中创建数据库表文件的操作步骤。

[1] 新建DB Schema

在这里插入图片描述

[2] 选择 default 模板创建 DB Schema 文件

在这里插入图片描述

[3] 一个基本的数据库表文件结构

{"bsonType": "object","required": [],"permission": {"read": true,"create": true,"update": true,"delete": true},"properties": {"_id": {"description": "ID,系统自动生成"}}
}

在 uniCloud 的云数据库中,使用 json 格式的数据来描述一个数据库表的表结构。其中:

  • "bsonType" 表示当前是一个表对象实例。
  • "required"表示在 “properties” 项里定义的哪些字段是必填项。
  • "permission" 表示可以在当前的数据库表实例上进行“增、删、改、查”的权限,默认创建时全是“false”
  • "properties" 表示这里是表字段的描述。默认情况自动创建了“主键”字段 “_id”。该字段不可删除和修改。用户需要添加的其他字段也都写在这里。

[4] 该项目的数据库表文件 mybooks.schema.json

{"bsonType": "object","required": ["book_name","authors","publisher","classify","count","price"],"permission": {"read": true,"create": true,"update": true,"delete": true},"properties": {"_id": {"description": "ID,系统自动生成"},"book_name": {"bsonType": "string","minLength": 1,"maxLength": 50,"title": "书籍名称"},"authors": {"bsonType": "string","minLength": 1,"maxLength": 50,"title": "作者"},"publisher": {"bsonType": "string","minLength": 1,"maxLength": 50,"title": "出版社"},"classify": {"bsonType": "string","enum": [{"text": "小说", "value": "novel"},{"text": "科技", "value": "technology"},{"text": "生活", "value": "life"},{"text": "社科", "value": "society"},{"text": "经济", "value": "economic"},{"text": "传记", "value": "biography"},{"text": "历史", "value": "history"},{"text": "儿童", "value": "children"}],"componentForEdit": {"name": "uni-data-select","props": {"placeholder": "请选择分类"}},"title": "分类"},"book_cover": {"bsonType": "file","fileMediaType": "image","fileExtName": "jpg,png","title": "封面"},"count": {"bsonType": "int","minimum": 0,"title": "余量"},"price": {"bsonType": "int","minimum": 0,"title": "单价(分)"},"brief": {"bsonType": "string","minLength": 3,"maxLength": 200,"componentForEdit": {"name": "uni-easyinput","props": {"type": "textarea"}},"title": "简介"},"addtime": {"bsonType": "timestamp","forceDefaultValue": {"$env": "now"},"componentForShow": {"name": "uni-dateformat"},"title": "购置时间"}}
}

【说明】:

  • "properties" 项中定义了数据表所需要的9个字段。
  • "book_name" 字段存放的是书籍名称,字符串型,长度在 1 ~ 50 个字符之间。
  • "authors" 字段存放的是书籍作者,字符串型,长度在 1 ~ 50 个字符之间。
  • "publisher" 字段存放的是出版社名称,字符串型,长度在 1 ~ 50 个字符之间。
  • "classify" 字段存放的是书籍的种类,字符串型。
    • 这里用到了 "enum" 属性,表示这个字段的数据值是在 "enum" 中所列内容中的其中一个。
    • 搭配的 "componentForEdit" 属性,表示在对该数据进行编辑使,使用什么样的前端组件进行展示。这里使用的是数据下拉选择器组件 "uni-data-select"
  • "book_cover" 字段用于存放书籍封面图片的信息,这里用的是 file 类型,有关使用 file 类型设置图片信息的示例可以参考官网的说明。

在这里插入图片描述

  • "count" 字段用于存储书籍的数量,int 类型,最小值为 0。
  • "price" 字段用于存储书籍的单价,int 类型,最小值为 0。因为在 JavaScript 中 double 数据类型在计算时容易出现误差,因此建议使用“分”为单位进行价格数据的存储。这个可以看下图中官网的解释。

在这里插入图片描述

  • "brief" 字段用于存储书籍的简介,字符串类型,长度在 3 ~ 200 之间。因为简介内容比较多,用单行文本输入框不合适,因此使用 "componentForEdit" 属性指定了前端组件 "uni-easyinput" 为多行文本框。
  • "addtime" 字段用于存储当前这条记录添加到数据库表的时刻,用的是 timestamp 类型(时间戳)。针对这种数据官方的解释说明见下图:

在这里插入图片描述

[5] 上传 DB Schema

在这里插入图片描述

上传成功后,在 HX 的控制台调试窗口中会显示:“上传数据集合Schema(mybooks.schema.json)成功” 的字样。

在 uniCloud 的 Web 控制台中,看到云数据库中已经有了一个与本地的 mybooks 一模一样的表文件。

在这里插入图片描述

3 schema2Code

关于 schema2code 官网的介绍如下:

在这里插入图片描述

以下是对创建好的表文件 mybooks.schema.json 执行 schema2code 的操作步骤。

[1] 对表文件执行 schema2code

在这里插入图片描述

[2] 在数据表文件上右键后,选择“schema2code”,注意在下图中一定要全选所有字段后,点击“确定”按钮。

在这里插入图片描述

如果弹出来提示说未安装XX插件的话,那就直接点击安装即可。

[3] schema2code 的过程会稍微长一些,等待一下,会询问是否需要把页面合并注册的提示。一定要选择“注册”

在这里插入图片描述

[4] 之后会询问是否将文件进行合并,下图一定要选“合并”。

在这里插入图片描述

[5] 一切结束后,在 HX 的项目管理器窗口中会看到 schema2code 自动生成的四个页面。

在这里插入图片描述

4 遇到了错误

以下的问题主要是由 HX 的版本问题引起的,如果开发过程中没有遇到,可以忽略这里。

[错误1] 提示 “未安装公共模块”

在 HX 的编辑器打开 list.vue 页面后,点击“预览”按钮,在 HX 的内置浏览器中“第一次”运行时,会报“未找到公共模块[uni-id-common]”的错误,见下图:

在这里插入图片描述

参考下图的指引,下载所有云函数、公共模块及actions

在这里插入图片描述

[错误2] Invaild uni-id config file

当执行完“下载所有云函数、公共模块及 action”后,再次运行 list.vue 页面,报错:“Invalid uni-id config file”。

在这里插入图片描述

这种情况就需要手动创建 uni-id 目录及 config.json 文件,在 uniCloud/cloudfunctions/common/uni-config-center/ 目录下新建 uni-id 目录,并继续创建 config.json 文件。

在这里插入图片描述

上述代码从https://uniapp.dcloud.net.cn/uniCloud/uni-id-summary.html#config 页面上找到文件源码,直接按照官网提示复制文件内容。

【重要提示】:

  • json 文件不支持注释语句,一定要把所有的注释代码删掉。
  • "tokenSecret" 项必须填写,自己拟定一个比较长的字符串即可。

故障排除,预览正常

在这里插入图片描述

5 对 “addtime” 字段对应的前端组件进行修改

schema2code 自动生成的前端页面有些组件的选配不是很智能,需要手动进行一下调整。这里仅仅以 “addtime” 字段对应生成的组件进行调整。其他页面中前端组件的显示效果,可以根据实际需要进行美化或重新布局。

“addtime” 字段在定义时选择的类型是 timestamp 时间戳,且设置了强制默认值为当前的系统时间,而这种数据本身以长整型的形式存储,在查看该数据时需要对其使用专门的组件 uni-dateformat 来实施。

以下就是对涉及到的三个页面的修改步骤。

[1] 在 HX 中打开 pages/mybooks/add.vue 页面,在页面源码中找到以下代码,将其删除。

<uni-forms-item name="addtime" label="购置时间"><uni-datetime-picker return-type="timestamp" v-model="formData.addtime"></uni-datetime-picker>
</uni-forms-item>

mybooks.schema.json 文件中,为存放“购置时间”的字段 "addtime" 设置了强制默认值,因此不需要在前端页面中执行时间选择。

[2] pages/mybooks/edit.vue 页面中也包含了添加时间的前端组件,同样需要删除。在页面源码中找到以下代码,将其删除即可。

<uni-forms-item name="addtime" label="购置时间"><uni-datetime-picker return-type="timestamp" v-model="formData.addtime"></uni-datetime-picker>
</uni-forms-item>

[3] 打开 pages/mybooks/detail.vue 页面,在页面源码中找到以下代码,

<uni-dateformat :value="data.addtime"></uni-dateformat>

将其修改为:

<uni-dateformat :date="data.addtime"  threshold="[0,0]"></uni-dateformat>

虽然在 "addtime" 字段定义时指定了使用 uni-dateformat 组件显示时间,但是自动生成的代码中属性配置有误,需要进行手动调整。

6 首次运行

以下视频演示了通过在 HX 的内置浏览器中运行 schema2code 的4个页面的执行效果,本地运行与云服务空间中的云数据库以及云存储的对应效果。

Unit3 6-1 schema2code页面的运行效果

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/151975.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

边坡安全监测系统:守护边坡稳定的重要工具

在工程建设中&#xff0c;边坡安全监测系统一直被认为是掌握边坡安全及其支护结构维护决策系统的关键支撑条件。这一系统的主要目的在于确定边坡结构的稳定性&#xff0c;监控支护结构的承载能力、运营状态和耐久性能&#xff0c;并对边坡稳定性进行实时监控。 一、边坡安全监测…

竞赛选题 深度学习 python opencv 火焰检测识别 火灾检测

文章目录 0 前言1 基于YOLO的火焰检测与识别2 课题背景3 卷积神经网络3.1 卷积层3.2 池化层3.3 激活函数&#xff1a;3.4 全连接层3.5 使用tensorflow中keras模块实现卷积神经网络 4 YOLOV54.1 网络架构图4.2 输入端4.3 基准网络4.4 Neck网络4.5 Head输出层 5 数据集准备5.1 数…

react-antd 文件导入按钮增加一个加载状态

1、效果图实例: 2、部分代码 2.1 props : 2.2 handleChange、上传的文件检验 : construction中定义 construction(props) { super(props); this.state { loadingStaus: flase, loadingDisabled: flase, // 作用:按钮如果在加 载状态中&#xff0c;没…

Node.js代码漏洞扫描工具介绍——npm audit

npm audit 运行安全检查 主要作用&#xff1a;检查命令将项目中配置的依赖项的描述提交到默认注册中心&#xff0c;并要求报告已知漏洞。如果发现任何漏洞&#xff0c;则将计算影响和适当的补救措施。如果 fix 提供了参数&#xff0c;则将对包树应用补救措施。 具体参考&#x…

【面向校招】Golang 常考面试题汇总 持续更新中...

前言: 为了方便自己复习和巩固,基础知识,整理了这个面试题汇总 文章目录 Go基础1. 讲一讲go中slice底层2. 讲一讲go中Map底层3. 讲一讲go中channel底层4. go中的并发编程MutexMysql1)数据库的三大范式2)关系型数据库和非关系型数据库的优缺点对比,应用场景3)MySQL和Mong…

机器视觉工程师,我们上班的意义在哪里?

很多朋友&#xff0c;现在不是自己想做的工作&#xff0c;那你做这份工作干什么&#xff1f;担心自己没有竞争力&#xff0c;担心自己被替代。上班的意义是完成自己头脑和资源的原始积累&#xff0c;迈向下一级人生游戏;我最终要靠自己本事吃饭&#xff0c;而不是一直待在这个只…

Tensorflow入门之 Hello World

Tensorflow入门之 Hello World 简介 Tensorflow 是 Google 开源的深度学习框架&#xff0c;来自于 Google Brain 研究项目&#xff0c;在 Google 第一代分布式机器学习框架 DistBelief 的基础上发展起来。 Tensorflow 的官方网址 http://www.tensorflow.org Tensorflow 的 G…

Stm32_标准库_8_ADC_光敏传感器_测量具体光照强度

ADC简介 测量方式 采用二分法比较数据 IO通道 ADC基本结构及配置路线 获取数字变量需要用到用到光敏电阻的AO口&#xff0c;AO端口接在PA0引脚即可 测得的模拟数据与实际光照强度之间的关系为 光照强度 100 - 模拟量 / 40;代码&#xff1a; 完整朴素代码&#xff1a; #in…

微信小程序template界面模板导入

我们有些时候 会有一些比较大但并不复杂的界面结构 这个时候 你可以试试这种导入模板的形式 我们在根目录创建一个 template 目录 然后下面创建一个 text文件夹下面创建一个 test.wxml 参考代码如下 <template name"textIndex"><text class "testw&…

Django使用SMTP发送邮件教程

CONTENTS 1. SMTP介绍2. 申请邮箱授权码3. Django发送邮件 1. SMTP介绍 SMTP&#xff08;Simple Mail Transfer Protocol&#xff09;即简单邮件传输协议&#xff0c;它是一组用于由源地址到目的地址传送邮件的规则&#xff0c;由它来控制信件的中转方式。SMTP 协议属于 TCP/I…

Arm64体系架构-MPIDR_EL1寄存器

背景 在Arm64多核处理器中, 各核间的关系可能不同. 比如1个16 core的cpu, 每4个core划分为1个cluster,共享L2 cache. 当我们需要从core 0将任务调度出来时,如果优先选择core 1~3, 那么性能明显时优于其他core的. 那么操作系统怎么知道core之间这样的拓扑信息呢? Arm提供了MPID…

香港Web3.0生态现状

目前香港Web3.0生态正在快速发展。香港政府和金融机构正在积极推动Web3.0生态的建设&#xff0c;以推动数字经济和智慧城市的发展。香港政府已经发布了有关虚拟资产发展的政策宣言&#xff0c;鼓励和监管并重&#xff0c;加大力度推动虚拟资产产业向前发展。同时&#xff0c;香…

E. Monsters

Problem - 1810E - Codeforces 思路&#xff1a;我们总结一下题意&#xff0c;能够得到这个题其实就是让我们从某个0开始搜索&#xff0c;然后看看是否可以遍历所有得节点&#xff0c;那么如果采用暴力得话那就是n^2logn&#xff0c;因为我们遍历一次使用优先队列得话是nlogn的…

ubuntu2204配置仓库为阿里源

官网上支持到2004&#xff0c;2204需要手动更改一下 deb https://mirrors.aliyun.com/ubuntu/ jammy main restricted universe multiverse deb-src https://mirrors.aliyun.com/ubuntu/ jammy main restricted universe multiversedeb https://mirrors.aliyun.com/ubuntu/ jam…

如何使用 Dijkstra 算法找到从源到所有顶点的最短路径--附C++/Java源码

给定一个图和图中的源顶点,找到从源到给定图中所有顶点的最短路径。 例子: 输入: src = 0,图形如下图所示。 输出: 0 4 12 19 21 11 9 8 14解释:从 0 到 1 的距离 = 4。 从 0 到 2 的最小距离 = 12。0->1->2 从 0 到 3 的最小距离 = 19。0 ->1-

Spring Cloud Gateway2之断言Predicate详解

文章目录 1. 前言2. Spring Cloud Gateway断言的种类及各自功能2.1. Path断言 PathRoutePredicateFactory2.2.Method断言 MethodRoutePredicateFactory2.3.Header断言 HeaderRoutePredicateFactory2.4.Host断言 HostRoutePredicateFactory2.5.Query断言 QueryRoutePredicateFac…

2023年中国石化行业节能减排发展措施分析:用精细化生产提高生产效率,降低能耗[图]

2022年&#xff0c;我国石油和化工行业克服诸多挑战取得了极其不易的经营业绩&#xff0c;行业生产基本稳定&#xff0c;营业收入和进出口总额增长较快&#xff0c;效益比上年略有下降但总额仍处高位。2022年&#xff0c;我国石油化工行业市场规模为191761.2亿元&#xff0c;同…

数字IC前端学习笔记:数字乘法器的优化设计(Dadda Tree乘法器)

相关阅读 数字IC前端https://blog.csdn.net/weixin_45791458/category_12173698.html?spm1001.2014.3001.5482 华莱士树仍然是一种比较规则的结构&#xff08;这使得可以方便地生成树的结构&#xff09;&#xff0c;这导致了它所使用的全加器和半加器个数不是最少的&#xff…

现代化战机之路:美国空军U-2侦察机基于Jenkins和k8s的CI/CD架构演进

▲ 点击上方"DevOps和k8s全栈技术"关注公众 华为北京研究所Q27大楼 随着技术的不断进步&#xff0c;军事领域也在积极采纳现代化工具来提高战备水平和效率。美国空军的U-2侦察机项目是一个鲜明的例子&#xff0c;它成功地借助Jenkins和Kubernetes&#xff08;k8s&…

【算法分析与设计】回溯法(下)

目录 一、符号三角形问题二、N皇后问题三、0-1背包问题四、最大团问题4.1 进一步改进 五、图的m着色问题5.1 算法设计六、旅行售货员问题七、连续邮资问题八、回溯法效率分析九、重排原理十、回溯法的效率分析十一、Monte Carlo方法附一、四后问题的搜索树附二、随机选择路径附…