从无到有构建vue实战项目(六)
十、徒手撸一个vue下拉左侧二级导航
先附上最终效果图:

vue代码:
<div
class="dropdown-menu-explore"
v-on:mouseover="addDropdownContent(this)"
v-on:mouseout="removeDropdownContent(this)"
>
<span class="dropdown-menu">探索</span>
<span class="dropdown-menu-arrow"></span>
<div class="dropdown-content" v-bind:style="{display:activeDisplay}">
<div class="dropdown-menu-content" id="dropdown-menu-content">
<ul>
<li
v-for="(list,index) in lists"
v-bind:key="index"
v-on:mouseover="addListContent(index)"
v-on:mouseout="removeListContent(this)"
>
<router-link to>{{list.message}}</router-link>
<ul class="dropdown-menu-content-list" v-show="index===isShow">
<li v-for="(item,index) in list.childs" v-bind:key="index">
<router-link to>{{item.subTitle}}</router-link>
</li>
</ul>
</li>
</ul>
</div>
</div>
</div>
事件:
methods: {
handleSelect: function() {},
//鼠标覆盖显示下拉内容
addDropdownContent: function() {
this.activeDisplay = "block";
return this.activeDisplay;
},
//鼠标移出隐藏内容
removeDropdownContent: function() {
this.activeDisplay = "none";
return this.activeDisplay;
},
addListContent: function(index) {
this.isShow = index;
},
removeListContent: function() {
this.isShow = !this.isShow;
}
},
mounted: function() {
this.isShow = -1;
}
数据
activeDisplay: "none",
isShow: 0,
lists: [
{
id: 1,
message: "理学",
childs: [{ subTitle: "1", subMessage: "这是子菜单信息" }]
},
{
id: 2,
message: "工学",
childs: [{ subTitle: "2", subMessage: "这是子菜单信息" }]
},
{ id: 3, message: "计算机" },
{ id: 4, message: "管理" },
{ id: 5, message: "经济学" },
{ id: 6, message: "外语" },
{ id: 7, message: "四六级" },
{ id: 8, message: "期末冲刺" },
{ id: 9, message: "考研" },
{ id: 10, message: "更多" }
]
十一、引入基于vue的支持markdown语法的编辑器---mavon-editor
基于mavon-editor的丝滑和简洁,我选择引入它作为我项目的一部分,先附上官网地址:https://www.zhystar.com/
接下来一步步将其引入我的项目中:
首先通过npm安装:
npm install mavon-editor --save
全局注册:
十二、错误总结(二)
当我将mavon-editor引入组件中后,出现了一个莫名其妙的错误:

经过排查,是因为我将组件name值与import引入的组件重名了,只需要对name值做出修改即可:


十三、与后端的第一次数据交互测试
登录页面基本完成后,开始进行前后端数据交互测试,项目中使用了axios,后端用了PHP,前端发出请求后,后端返回数据,一度报错,原因是内有解析json数据,解析了json数据后,成功解决问题。
当我在测试时,我有这样一个需求,即通过element的el-input当Enter键按下时,可以触发事件,但是没有任何效果,原因是el-input是封装好的组件,在它外层还有一层div包裹着,所以必须使用.native修饰符,来监听根元素的原生事件,即做出以下修改:

改为:

从无到有构建vue实战项目(六)的更多相关文章
- 从无到有构建vue实战项目(四)
六.webpack的安装和配置 为了快速构建vue项目,webpack是一个必不可少的工具,我们先来安装它,附上官网地址:https://www.webpackjs.com/ 要安装最新版本或特定版本 ...
- 从无到有构建vue实战项目(一)
vue的安装 首先下载nodehttp://nodejs.cn/download/ 有两种安装方式安装包安装和二进制文件安装 输入以下命令,出现版本提示表示安装成功: node -v 10.15.3 ...
- 从无到有构建vue实战项目(二)
二.vue项目的初步搭建 该项目我采用了当下最流行的vue ui框架---element-ui,首先用vue-cli构建一个vue项目: vue create education 然后会出现一系列配置 ...
- 从无到有构建vue实战项目(八)
十六.vue-lazyload的使用 首先,我们需要下载vue-lazyload包: npm i vue-lazyload -S 下载好之后,我们将它引入到自己的项目: //main.js //引入图 ...
- 从无到有构建vue实战项目(三)
四.响应式布局的实现 elemnt-ui参考bootatrap提供了响应式布局,附上地址:https://element.eleme.cn/#/zh-CN/component/layout 以下是我的 ...
- 从无到有构建vue实战项目(五)
八.错误总结(一) webpack打包项目识别子组件路径问题 之所以出现了这样的问题是因为在webpack打包项目时,未将此处的子组件路径正确识别: 将此处的carousel改为carousel.vu ...
- 从无到有构建vue实战项目(七)
十四.Vuex的使用 Vuex是什么? Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式.它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发生变化.Vu ...
- Vue 实战项目: 硅谷外卖(1)
第 1 章: 准备 1.1. 项目描述 1) 此项目为外卖 WebApp(SPA) 2) 包括商家, 商品, 购物车, 用户等多个子模块 3) 使用 Vue 全家桶+ES6+Webpack 等前端最新 ...
- Vue 实战项目开发流程
一 基础配备 ## 一.环境搭建 #### 1.安装node - 去[官网](https://nodejs.org/zh-cn/)下载node安装包 - 傻瓜式安装 - 万一安装后终端没有node环境 ...
随机推荐
- C#数据导出Excel详细介绍
概要: excel导出在C#代码中应用己经很广泛了,我这里就做些总结,供自己和读者学习用. Excel知识点.一.添加引用和命名空间 添加Microsoft.Office.Interop.Excel引 ...
- 解决WPF中TextBox文件拖放问题
在WPF中,当我们尝试向TextBox中拖放文件,从而获取其路径时,往往无法成功(拖放文字可以成功).造成这种原因关键是WPF的TextBox对拖放事件处理机制的不同,具体可参考这篇文章Textbox ...
- MinGW和MSYS区别和关系以及MinGW&MSYS在Win7中安装并编译x264
http://blog.csdn.net/freeape/article/details/50555003
- “多团队大规模”开发模式 - 基于SAP HANA平台的多团队产品研发
应用SAP HANA “官方”开发模式的伙伴们在转到“多团队大规模”开发模式时会遇到各式各样的心理不适应的状况,各种纠结.比如GIT Repository和HANA Repository冲突什么的. ...
- 【工具】Axure 8.0 序列号
之前用的 Axure 8.0 到期最近了,重找了一个序列号,发现可用,记录一下,分享如下: 授权人:University of Science and Technology of China (CLA ...
- spring通过注解方式依赖注入原理 (私有成员属性如何注入)
一.spring如何创建依赖的对象 用过spring的都知道我们在dao.service层加上@repository.@Service就能将这两个对象交给spring管理,在下次使用的时候使用@res ...
- java关键字-interface
1:是用关键字interface定义的. 2:接口中包含的成员,最常见的有全局常量.抽象方法. 注意:接口中的成员都有固定的修饰符. 成员变量:public static final 成员方法:pub ...
- ZooKeeper学习第六期---ZooKeeper机制架构(转)
转载来源:https://www.cnblogs.com/sunddenly/p/4133784.html 一.ZooKeeper权限管理机制 1.1 权限管理ACL(Access Control L ...
- Hexo+NexT(零):最全Hexo+Next搭建博客教程
快速.简洁且高效的博客框架 有位大神说,喜欢写博客的人的人,折腾博客会经历三个阶段.找到一个免费空间,搭建一个博客,很欣喜,很有成就感,此为一阶段:受限免费空间各种限制,自己买空间和域名,实现对博客的 ...
- HBase —— 单机环境搭建
一.安装前置条件说明 1.1 JDK版本说明 HBase 需要依赖JDK环境,同时HBase 2.0+ 以上版本不再支持JDK 1.7 ,需要安装JDK 1.8+ .JDK 安装方式见本仓库: Lin ...