• 因为刚初学Vue.js,暂时遇到以下问题,待之后解决

    • 点击父节点,怎么隐藏显示子节点
    • 点击父节点或子节点,切换li的class="active"
    • iframe怎么自适应高度
  • 思路
    • 这里是通过vue.router进行切换
  • 效果图
  • 代码
    <!DOCTYPE html>
    <html lang="en">
    <head>
    <meta charset="utf-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <!-- The above 3 meta tags *must* come first in the head; any other head content must come *after* these tags -->
    <meta name="description" content="">
    <meta name="author" content="">
    <link rel="icon" href="../../favicon.ico"> <title>Dashboard Template for Bootstrap</title> <!-- Bootstrap core CSS -->
    <link href="css/bootstrap.min.css" rel="stylesheet">
    <link href="css/dashboard.css" rel="stylesheet"> <script src="js/jquery.min.js"></script>
    <script src="bootstrap-4.3.1-dist/js/bootstrap.min.js"></script> <script src="https://cdn.staticfile.org/vue/2.4.2/vue.min.js"></script>
    <script src="https://cdn.staticfile.org/vue-router/2.7.0/vue-router.min.js"></script> <style>
    .smail-ul {
    list-style-type: none;
    } .router-view-style {
    width: 100%;
    height: 100%;
    } .router-view-iframe-style {
    width: 100%;
    height: 1280px;
    }
    </style>
    </head> <body> <nav class="navbar navbar-inverse navbar-fixed-top">
    <div class="container-fluid">
    <div class="navbar-header">
    <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar"
    aria-expanded="false" aria-controls="navbar">
    <span class="sr-only">Toggle navigation</span>
    <span class="icon-bar"></span>
    <span class="icon-bar"></span>
    <span class="icon-bar"></span>
    </button>
    <a class="navbar-brand" href="#">Project name</a>
    </div>
    <div id="navbar" class="navbar-collapse collapse">
    <ul class="nav navbar-nav navbar-right">
    <li><a href="#">Dashboard</a></li>
    <li><a href="#">Settings</a></li>
    <li><a href="#">Profile</a></li>
    <li><a href="#">Help</a></li>
    </ul>
    <form class="navbar-form navbar-right">
    <input type="text" class="form-control" placeholder="Search...">
    </form>
    </div>
    </div>
    </nav> <div class="container-fluid" id="app">
    <div class="row">
    <div class="col-sm-3 col-md-2 sidebar">
    <ul class="nav nav-sidebar">
    <li >
    <a href="#">用户管理 <span class="sr-only">(current)</span></a>
    <ul class="smail-ul">
    <li><a href="#">
    <router-link to="/managementUser">管理用户</router-link>
    </a></li>
    </ul>
    </li>
    <li class="active">
    <a href="#">行程游记管理</a>
    <ul class="smail-ul">
    <li><a href="#">
    <router-link to="/managementTravel">管理游记</router-link>
    </a></li>
    </ul>
    </li>
    <li>
    <a href="#">攻略计划管理</a>
    <ul class="smail-ul">
    <li><a href="#">
    <router-link to="/managementPlan">管理计划</router-link>
    </a></li>
    </ul>
    </li>
    <li>
    <a href="#">攻略问答管理</a>
    <ul class="smail-ul">
    <li><a href="#">
    <router-link to="/managementProblem">管理问题</router-link>
    </a></li>
    <li><a href="#">
    <router-link to="/managementReply">管理回答</router-link>
    </a></li>
    </ul>
    </li>
    <li>
    <a href="#">玩转当地管理</a>
    <ul class="smail-ul">
    <li><a href="#">
    <router-link to="/addAttraction">添加景点</router-link>
    </a></li>
    <li><a href="#">
    <router-link to="/managementAttraction">管理景点</router-link>
    </a></li>
    <li><a href="#">
    <router-link to="/addFood">添加美食</router-link>
    </a></li>
    <li><a href="#">
    <router-link to="/managingFood">管理美食</router-link>
    </a></li>
    <li><a href="#">
    <router-link to="/addAccommodation">添加住宿</router-link>
    </a></li>
    <li><a href="#">
    <router-link to="/managementAccommodation">管理住宿</router-link>
    </a></li>
    </ul>
    </li>
    </ul>
    </div>
    <div class="col-sm-9 col-sm-offset-3 col-md-10 col-md-offset-2 main">
    <!--<h1 class="page-header">Dashboard</h1>--> <div class="row placeholders">
    <!-- 路由出口 -->
    <!-- 路由匹配到的组件将渲染在这里 -->
    <router-view class="router-view-style"> </router-view>
    </div>
    </div>
    </div>
    </div> </body>
    <script> // 0. 如果使用模块化机制编程,導入Vue和VueRouter,要调用 Vue.use(VueRouter)
    //1. 定义(路由)组件
    const ManagementUser = {template: '<iframe frameborder="0" class="router-view-iframe-style" src="login.html"></iframe>'}
    const ManagementTravel = {template: '<div>Management travel</div>'}
    const ManagementPlan = {template: '<div>Management Plan</div>'}
    const ManagementProblem = {template: '<div>Management Problem</div>'}
    const ManagementReply = {template: '<div>Management Reply</div>'}
    const AddAttraction = {template: '<div>Add Attraction</div>'}
    const ManagementAttraction = {template: '<div>Management Attraction</div>'}
    const AddFood = {template: '<div>Add Food</div>'}
    const ManagingFood = {template: '<div>Managing Food</div>'}
    const AddAccommodation = {template: '<div>Add Accommodation</div>'}
    const ManagementAccommodation = {template: '<div>Management Accommodation</div>'} //template: '<div>User{{ $route.params.id}}</div>' // 2. 创建 router 实例,然后传 `routes` 配置
    // 你还可以传别的配置参数, 不过先这么简单着吧。
    const router = new VueRouter({
    //定义路由
    //每个路由应该映射一个组件。 其中"component" 可以是
    //创建路由实例,
    routes: [
    {path: '/managementUser', component: ManagementUser},
    {path: '/managementTravel', component: ManagementTravel},
    {path: '/managementPlan', component: ManagementPlan},
    {path: '/managementProblem', component: ManagementProblem},
    {path: '/managementReply', component: ManagementReply},
    {path: '/addAttraction', component: AddAttraction},
    {path: '/managementAttraction', component: ManagementAttraction},
    {path: '/addFood', component: AddFood},
    {path: '/managingFood', component: ManagingFood},
    {path: '/addAccommodation', component: AddAccommodation},
    {path: '/managementAccommodation', component: ManagementAccommodation}, ] }) // 4. 创建和挂载根实例。
    // 记得要通过 router 配置参数注入路由,
    // 从而让整个应用都有路由功能
    const app = new Vue({
    router
    }).$mount('#app');
    </script>
    </html>

Vue.js实现后台菜单切换的更多相关文章

  1. vue、element-ui 后台菜单切换重新请求数据

    我们在做后台管理系统时,通常将数据请求挂载到created或mounted钩子中,但这样引发的问题是它只会被出发一次,如果不同菜单中数据关联性较大,切换过程中未及时更新数据,容易引发一些问题,这种情况 ...

  2. Vue.js连接后台数据jsp页面  ̄▽ ̄

    <%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding= ...

  3. vue.js与后台模板引擎“双花括号”冲突时的解决办法

    后台渲染模板如swig,也使用“{{ }}“作为渲染,与前端vue的产生冲突,此时只要在新建Vue对象时,添加delimiters: ['${', '}'],就搞定了,代码如下 <!DOCTYP ...

  4. vue js 实现 树形菜单

    添加一个模板.<template id="menu-template"> <li v-if="model.nodes!=undefined"& ...

  5. Vue.js学习 — 微信公众号菜单编辑器(一)

    学习里一段时间Vue.js,于是想尝试着做一个像微信平台里那样的菜单编辑器,在这里分享下 具体样式代码查看项目github 创建一个vue实例 <!DOCTYPE html> <ht ...

  6. 用Vue.js开发微信小程序:开源框架mpvue解析

    前言 mpvue 是一款使用 Vue.js 开发微信小程序的前端框架.使用此框架,开发者将得到完整的 Vue.js 开发体验,同时为 H5 和小程序提供了代码复用的能力.如果想将 H5 项目改造为小程 ...

  7. 前端之Vue.js库的使用

    vue.js简介 Vue.js读音 /vjuː/, 类似于 view Vue.js是前端三大新框架:Angular.js.React.js.Vue.js之一,Vue.js目前的使用和关注程度在三大框架 ...

  8. Vue.js库的第一天的学习

    一,vue.js简介 Vue.js可以作为一个js库来使用,也可以用它全套的工具来构建系统界面,这些可以根据项目的需要灵活选择 所以说, vue.js是一套构建用户界面的渐进式框架 Vue.js的核心 ...

  9. Vue.js的简介

    vue.js简介 Vue.js读音 /vjuː/, 类似于 view   Vue.js是前端三大新框架:Angular.js.React.js.Vue.js之一,Vue.js目前的使用和关注程度在三大 ...

随机推荐

  1. 二维码神器QRCoder

    好久没有写Blog,都是因为不小心坠入了爱河,时间都给我家那位了,都没时间加班了(嗨呀,不小心撒了一下狗粮),不过,还是希望单身的赶紧找到心仪的另一半,实在找不到,那就加班啊(开个玩笑,别认真). 二 ...

  2. 分析Class类和ClassLoader类下的同名方法getResourceAsStream

    在读取本地资源的时候我们经常需要用到输入流,典型的场景就是使用Druid连接池时读取连接池的配置文件.Java为我们提供了读取资源的方法getResourceAsStream(),该方法有三种: Cl ...

  3. linux安装nvm node版本管理器 nvm常用命令 部署node服务器环境

    1,nvm git地址点击打开链接,安装命令 curl -o- https://raw.githubusercontent.com/creationix/nvm/v0.33.11/install.sh ...

  4. 一个C#程序员学习微信小程序的笔记

    客户端打开小程序的时候,就将代码包下载到本地进行解析,首先找到了根目录的 app.json ,知道了小程序的所有页面. 在这个Index页面就是我们的首页,客户端在启动的时候,将首页的代码装载进来,通 ...

  5. 十问 JVM

    今天我们来讨论下 Java 虚拟机,通过一系列常见的问题来逐渐深入了解 JVM 创建对象过程,内存布局,类加载以及 GC 回收算法等机制. 十问 JVM 问题整理: Java虚拟机创建对象的过程 (使 ...

  6. 30分钟玩转Net MVC 基于WebUploader的大文件分片上传、断网续传、秒传(文末附带demo下载)

    现在的项目开发基本上都用到了上传文件功能,或图片,或文档,或视频.我们常用的常规上传已经能够满足当前要求了, 然而有时会出现如下问题: 文件过大(比如1G以上),超出服务端的请求大小限制: 请求时间过 ...

  7. aps .net MVC单用户登录

    当不允许多用户同时登录一个帐号时,就需要一种机制,当再登录一个相同的帐号时,前面登录的人被挤下线. 原文地址:http://www.cnblogs.com/f23wangj/p/4984302.htm ...

  8. 配置rsync+inotify实时同步

    与上一篇同步做 配置rsync+inotify实时同步 1:调整inotify内核参数 在linux内核中,默认的inotify机制提供三个调控参数:max_queue_events.max_user ...

  9. Vue基本使用

    Vue.js是一款流行的开源JavaScript前端框架,旨在更好地组织与简化Web开发.Vue所关注的核心是MVC模式中的视图层,同时,它也能方便地获取数据更新,并通过组件内部特定的方法实现视图与模 ...

  10. GridView 的简单应用

    gridView 是android一个控件主要是显示列似与九宫格这样的效果.废话不多说直接上代码. 首先是需要一个适配器来确定每一个里面的布局,在里面我自定义了一个点击事件,当点击图片布局的时候触发, ...