多应用+插件架构,代码干净,二开方便,首家独创一键云编译技术,文档视频完善,免费商用码云13.8K 广告
现在我们已经做出了分类的增删改查功能,并且将设计与开发作为一级分类,下面我们要为一级分类添加二级分类。如平面设计、3D设计为二级分类关联到设计分类中,将网站开发、小程序开发归属到开发分类中。 1.更改新建分类页面 CategorySet.vue设置上级分类parent,位于分类名之上: ``` <el-form-item label="上级分类"> <el-select v-model="model.parent"> <!-- 使用select获取分类名name和该分类的id,后期如果修改分类名自动更新子分类的上级分类 --> <!-- 其中label获取分类名,发送到数据库的值为该分类的id————以id为分类寻找依据 --> <el-option v-for="item in parentOptions" :key="item._id" :label="item.name" :value="item._id"></el-option> </el-select> </el-form-item> ``` 2.使用查询接口 下方js使用categories查询分类接口获取分类信息,将获取到的数据传入分类数据parentOptions中: ``` async fetchParentOptions(){ const res = await this.$http.get('categories') this.parentOptions = res.data } ``` 此时页面已接收到分类信息,并可以显示分类名了。 ![](https://img.kancloud.cn/69/3b/693bd6638960942e7f6e42c777c3e425_1268x353.png) 3.改动分类模型 接口使用模型上传,所以接收到的数据不变,无需改动。但要想接收到上级分类的数据,我们需要在模型中添加字段和类型。 在server/model/Category.js中找到分类模型,对分类模型进行改动: ![](https://img.kancloud.cn/17/4c/174c732a41d4e3ef7d35e0304f12a148_946x340.png) ``` parent: { type: mongoose.SchemaTypes.ObjectId, ref: 'Category' }, ``` 这样就可以了,测试一下: ![](https://img.kancloud.cn/35/95/359599ddd8081378d5b6b8cce1bca9be_1268x353.png) ![](https://img.kancloud.cn/32/0e/320e47b379d3fe4dde6d16baacacf979_1268x353.png) 成功,下一步在分类列表中把上级分类展示出来。 4.更改分类列表页面 ![](https://img.kancloud.cn/a8/b8/a8b88eb59fd73d1d3aae17e4242efe95_1352x865.png) ![](https://img.kancloud.cn/33/ed/33edaf93ede1d552c23b7c9471453281_1268x353.png) 由于我们以id为依据传值,所以上级分类显示的就不是上级分类名,而是上级分类id。 此时我们就要改动分类列表的查询数据接口。 5.改动查询接口 在server/route/admin/index.js文件中,找到查询数据接口,添加一个populate()方法: ``` // 查询数据(查) router.get('/categories', async(req, res) => { // populate()方法用于在用到schama架构关联时,取出关联的内容,查询到改内容关联到的对象 const items = await Category.find().populate('parent').limit(10) res.send(items) }) ``` 对比一下populate()方法使用前后的数据。 使用前是查询到的parent值: ![](https://img.kancloud.cn/23/28/232877ba3864a27efc04efd8702b26a6_1268x730.png) 使用后是根据parent查询到的关联对象: ![](https://img.kancloud.cn/81/d2/81d214a7d55237da001ed1552a69a305_1268x730.png) 此时我们把CategoryList.vue页面中上级分类的prop值改一下就可以了: ![](https://img.kancloud.cn/db/4f/db4f5e5ff87d3469c5fe9bcb4b43378e_1239x936.png) ![](https://img.kancloud.cn/23/51/2351b4de21a2f25e7e5a53a9dc9f5cf1_1268x353.png) 5.vue.js devtools插件 具体什么是ObjectId呢,这里我使用vue的vue.js devtools谷歌插件给大家展示一下: ![](https://img.kancloud.cn/59/4e/594edbc579024ca120bb38f8bbbdaba3_1255x727.png) 在vue开发过程中,我们应时刻观察数据的变化,所以就要用到vue的开发者面板插件了,分享给大家: 技能学习:学习使用Node.js + Vue.js,开发前端全栈网站-vue.js devtools谷歌插件下载与安装