十、徒手撸一个vue下拉左侧二级导航

  1. 先附上最终效果图:

  2. 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>
  3. 事件:

    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;
    }
  4. 数据

    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

  1. 基于mavon-editor的丝滑和简洁,我选择引入它作为我项目的一部分,先附上官网地址:https://www.zhystar.com/

  2. 接下来一步步将其引入我的项目中:

    1. 首先通过npm安装:

      npm install mavon-editor --save
    2. 全局注册:

十二、错误总结(二)

  1. 当我将mavon-editor引入组件中后,出现了一个莫名其妙的错误:

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

十三、与后端的第一次数据交互测试

  1. 登录页面基本完成后,开始进行前后端数据交互测试,项目中使用了axios,后端用了PHP,前端发出请求后,后端返回数据,一度报错,原因是内有解析json数据,解析了json数据后,成功解决问题。

  2. 当我在测试时,我有这样一个需求,即通过element的el-input当Enter键按下时,可以触发事件,但是没有任何效果,原因是el-input是封装好的组件,在它外层还有一层div包裹着,所以必须使用.native修饰符,来监听根元素的原生事件,即做出以下修改:

    改为:

从无到有构建vue实战项目(六)的更多相关文章

  1. 从无到有构建vue实战项目(四)

    六.webpack的安装和配置 为了快速构建vue项目,webpack是一个必不可少的工具,我们先来安装它,附上官网地址:https://www.webpackjs.com/ 要安装最新版本或特定版本 ...

  2. 从无到有构建vue实战项目(一)

    vue的安装 首先下载nodehttp://nodejs.cn/download/ 有两种安装方式安装包安装和二进制文件安装 输入以下命令,出现版本提示表示安装成功: node -v 10.15.3 ...

  3. 从无到有构建vue实战项目(二)

    二.vue项目的初步搭建 该项目我采用了当下最流行的vue ui框架---element-ui,首先用vue-cli构建一个vue项目: vue create education 然后会出现一系列配置 ...

  4. 从无到有构建vue实战项目(八)

    十六.vue-lazyload的使用 首先,我们需要下载vue-lazyload包: npm i vue-lazyload -S 下载好之后,我们将它引入到自己的项目: //main.js //引入图 ...

  5. 从无到有构建vue实战项目(三)

    四.响应式布局的实现 elemnt-ui参考bootatrap提供了响应式布局,附上地址:https://element.eleme.cn/#/zh-CN/component/layout 以下是我的 ...

  6. 从无到有构建vue实战项目(五)

    八.错误总结(一) webpack打包项目识别子组件路径问题 之所以出现了这样的问题是因为在webpack打包项目时,未将此处的子组件路径正确识别: 将此处的carousel改为carousel.vu ...

  7. 从无到有构建vue实战项目(七)

    十四.Vuex的使用 Vuex是什么? Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式.它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发生变化.Vu ...

  8. Vue 实战项目: 硅谷外卖(1)

    第 1 章: 准备 1.1. 项目描述 1) 此项目为外卖 WebApp(SPA) 2) 包括商家, 商品, 购物车, 用户等多个子模块 3) 使用 Vue 全家桶+ES6+Webpack 等前端最新 ...

  9. Vue 实战项目开发流程

    一 基础配备 ## 一.环境搭建 #### 1.安装node - 去[官网](https://nodejs.org/zh-cn/)下载node安装包 - 傻瓜式安装 - 万一安装后终端没有node环境 ...

随机推荐

  1. MyCat的初步了解

    MyCat 1 开源数据库中间件 MyCat   如今随着互联网的发展,数据的量级也是撑指数的增长,从GB到TB到PB.对数据的各种操作也是愈加的困难,传统的关系性数据库已经无法满足快速查询与插入数据 ...

  2. 完全卸载mysql免安装版

    使用以下命令 reg delete "HKEY_LOCAL_MACHINE\SYSTEM\ControlSet001\services\eventlog\Application\MySQL& ...

  3. QT---Native Wifi functions 应用(WiFi有密码连接)

    实现功能     无线网卡列表     无线热点扫面     无线连接(有密码,配置文件连接方式)     无线断开     重命名本地无线名(两种方式)     删除无线配置文件     开启和关闭 ...

  4. vs2008在win7系统中安装不问题

    据说是office软件冲突问题. 解决方案是卸载了office软件,不管是2007还是其它版本,先安装vs2008,再安装其它的.

  5. 为什么有如此多的C++测试框架 - from Google Testing Blog

    Why Are There So Many C++ Testing Frameworks? by Zhanyong Wan (Software Engineer) 最近貌似有很多人正在开发他们自己的C ...

  6. 创业游戏模拟器 Startup 游戏试玩

    买的正版游戏,还在beta阶段.因为对这种经营类的游戏挺感兴趣,结合自己也是做这个行当的.算是一次性通关了吧.我来评价一下这个游戏.足足玩了有5个多小时.从1级玩到15级.解锁了所有的内容.员工从1个 ...

  7. python读取json文件并解析

    # -*- coding: utf-8 -*- import os import json import sys reload(sys) sys.setdefaultencoding('utf-8') ...

  8. 用nodejs调用webservice

    用nodejs调用webservice,是用soap包实现的. 步骤如下: 第一步:安装soap包 npm  install soap 第二部:调用webservice var soap = requ ...

  9. 视频私有云实战:基于Docker构建点播私有云平台

    私有云是为一个客户单独使用而构建的,因而提供对数据.安全性和服务质量的最有效控制.前置条件是客户拥有基础设施,并可以使用基础设施在其上部署应用程序.其核心属性是专有的资源.本篇文章将会结合网易云信的实 ...

  10. Scala 学习之路(七)—— 常用集合类型之 Map & Tuple

    一.映射(Map) 1.1 构造Map // 初始化一个空map val scores01 = new HashMap[String, Int] // 从指定的值初始化Map(方式一) val sco ...