国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

【Vue.js】使用Element中的Mock.js搭建首頁導(dǎo)航&左側(cè)菜單---【超高級教學(xué)】

這篇具有很好參考價(jià)值的文章主要介紹了【Vue.js】使用Element中的Mock.js搭建首頁導(dǎo)航&左側(cè)菜單---【超高級教學(xué)】。希望對大家有所幫助。如果存在錯(cuò)誤或未考慮完全的地方,請大家不吝賜教,您也可以點(diǎn)擊"舉報(bào)違法"按鈕提交疑問。

一,Mock.js

1.1 認(rèn)識Mock.js

? ? ?Mock.js是一個(gè)用于前端開發(fā)中生成隨機(jī)數(shù)據(jù)、模擬接口響應(yīng)的 JavaScript 庫。模擬數(shù)據(jù)的生成器,用來幫助前端調(diào)試開發(fā)、進(jìn)行前后端的原型分離以及用來提高自動(dòng)化測試效率

總結(jié)來說,Element中的Mock.js是一個(gè)用于前端開發(fā)中生成隨機(jī)數(shù)據(jù)、模擬接口響應(yīng)的庫。它可以幫助你快速開發(fā)和調(diào)試前端項(xiàng)目,而無需依賴后端接口

1.2 安裝mockjs

npm i mockjs -D

注意:SPA項(xiàng)目工作區(qū)間使用cmd執(zhí)行該命令

-D表示只在開發(fā)環(huán)境中使用

執(zhí)行完畢之后,在devDependencies下會(huì)發(fā)現(xiàn)已下載好mockjs插件,證明已經(jīng)安裝好了

【Vue.js】使用Element中的Mock.js搭建首頁導(dǎo)航&左側(cè)菜單---【超高級教學(xué)】,vue.js,前端,javascript

1.3 引入mockjs

為了只在開發(fā)環(huán)境使用mock,而打包到生產(chǎn)環(huán)境時(shí)自動(dòng)不使用mock,我們可以在config目錄中的dev.env.jsprod.env.js做一個(gè)配置,如下:

dev.env.js(開發(fā)壞境):

加入Mock:'true'? 如下

module.exports = merge(prodEnv, {
  NODE_ENV: '"development"',
	MOCK: 'true'
})

prod.env.js(生產(chǎn)壞境):

加入Mock:'flase'? 如下

module.exports = {
  NODE_ENV: '"production"',
	MOCK: 'false'
}

mian.js導(dǎo)入Mock動(dòng)態(tài)依賴:

//開發(fā)環(huán)境下才會(huì)引入mockjs
process.env.MOCK && require('@/mock') 

二 mockjs使用

導(dǎo)入兩個(gè)js:

【Vue.js】使用Element中的Mock.js搭建首頁導(dǎo)航&左側(cè)菜單---【超高級教學(xué)】,vue.js,前端,javascript

login-mock:

// const loginInfo = {
// 	code: -1,
// 	message: '密碼錯(cuò)誤'
// }

//使用mockjs的模板生成隨機(jī)數(shù)據(jù)
const loginInfo = {
	'code|-1-0': 0,
	'message|3-10': 'msg'
}
export default loginInfo;

index.js:

import Mock from 'mockjs' //引入mockjs,npm已安裝
import action from '@/api/action' //引入請求地址

//全局設(shè)置:設(shè)置所有ajax請求的超時(shí)時(shí)間,模擬網(wǎng)絡(luò)傳輸耗時(shí)
Mock.setup({
	// timeout: 400  //延時(shí)400s請求到數(shù)據(jù)
	timeout: 200 - 400 //延時(shí)200-400s請求到數(shù)據(jù)
})

//引登陸的測試數(shù)據(jù),并添加至mockjs
import loginInfo from '@/mock/json/login-mock.js'
let s1 = action.getFullPath('SYSTEM_USER_DOLOGIN')
Mock.mock(s1, "post", loginInfo)
// Mock.mock(s1, /post|get/i, loginInfo)

登入Login.vue:

<template>
	<div class="login-wrap">
		<el-form class="login-container">
			<h1 class="title">用戶登錄</h1>
			<el-form-item label="">
				<el-input type="text" v-model="username" placeholder="登錄賬號" autocomplete="off"></el-input>
			</el-form-item>
			<el-form-item label="">
				<el-input type="password" v-model="password" placeholder="登錄密碼" autocomplete="off"></el-input>
			</el-form-item>
			<el-form-item>
				<el-button type="primary" style="width:100%;" @click="doSubmit()">提交</el-button>
			</el-form-item>
			<el-row style="text-align: center;margin-top:-10px">
				<el-link type="primary">忘記密碼</el-link>
				<el-link type="primary" @click="gotoRegister()">用戶注冊</el-link>
			</el-row>
		</el-form>
	</div>
</template>

<script>
import axios from 'axios'
import qs from 'qs' //用于post請求
export default {
    name: 'Login',
    data() {
      return {
        username: "",
        password: "",
        msg: '啊'
      }
    },
    methods: {
      Register() {
        this.$router.push('/Register');
      },
      doSubmit() {
        let params = {
          username: this.username,
          password: this.password
        };
        console.log(params);
        //定義后端都請求地址
        var url = this.axios.urls.SYSTEM_USER_DOLOGIN;
 
        //以下是post請求及整合資源
        //通過qs中的stringify方法進(jìn)行格式轉(zhuǎn)換
        //注意數(shù)據(jù)是保存到j(luò)son對象的params屬性
        this.axios.post(url,params).then(r => {
          console.log(r);
		  this.$message({
			  message:r.data.message,
			  type:r.data.code==0?'success':'error'
		  });
		  
        }).catch(e => {
          console.log(e);
        });
 
 
      }
    }
  }

</script>
<style scoped>
	.login-wrap {
		box-sizing: border-box;
		width: 100%;
		height: 100%;
		padding-top: 10%;
		background-image: url();
		/* background-color: #112346; */
		background-repeat: no-repeat;
		background-position: center right;
		background-size: 100%;
	}
	 .login-container {
	border-radius: 10px;
	margin: 0px auto;
	width: 350px;
	padding: 30px 35px 15px 35px;
	background: #fff;
	border: 1px solid #eaeaea;
	text-align: left;
	box-shadow: 0 0 20px 2px rgba(0, 0, 0, 0.1);
}

.title {
	margin: 0px auto 40px auto;
	text-align: center;
	color: #505458;
}
</style>

效果:

【Vue.js】使用Element中的Mock.js搭建首頁導(dǎo)航&左側(cè)菜單---【超高級教學(xué)】,vue.js,前端,javascript

三,Bus事物總線

3.1.首頁導(dǎo)航欄與左側(cè)菜單搭建

①組件(3個(gè))

  • AppMain.vue:布局容器組件

  • LeftAside.vue:左側(cè)菜單組件

  • TopNav.vue:首頁導(dǎo)航組件

APPMian.vue:

<template>
	<el-container class="main-container">
		<el-aside v-bind:class="asideClass">
			<LeftNav></LeftNav>
		</el-aside>
		<el-container>
			<el-header class="main-header">
				<TopNav></TopNav>
			</el-header>
			<el-main class="main-center">Main</el-main>
		</el-container>
	</el-container>
</template>

<script>
	// 導(dǎo)入組件
	import TopNav from '@/components/TopNav.vue'
	import LeftNav from '@/components/LeftNav.vue'

	// 導(dǎo)出模塊
	export default {
		
	};
</script>
<style scoped>
	.main-container {
		height: 100%;
		width: 100%;
		box-sizing: border-box;
	}

	.main-aside-collapsed {
		/* 在CSS中,通過對某一樣式聲明! important ,可以更改默認(rèn)的CSS樣式優(yōu)先級規(guī)則,使該條樣式屬性聲明具有最高優(yōu)先級 */
		width: 64px !important;
		height: 100%;
		background-color: #334157;
		margin: 0px;
	}

	.main-aside {
		width: 240px !important;
		height: 100%;
		background-color: #334157;
		margin: 0px;
	}

	.main-header,
	.main-center {
		padding: 0px;
		border-left: 2px solid #333;
	}
</style>

LeftNav.vue:

<template>
	<el-menu default-active="2" class="el-menu-vertical-demo" @open="handleOpen" @close="handleClose" background-color="#334157"
	 text-color="#fff" active-text-color="#ffd04b" :collapse="collapsed" :collapse-transition="bb">
		<!-- <el-menu default-active="2" :collapse="collapsed" collapse-transition router :default-active="$route.path" unique-opened class="el-menu-vertical-demo" background-color="#334157" text-color="#fff" active-text-color="#ffd04b"> -->
		<div class="logobox">
			<img class="logoimg" src="../assets/img/logo.png" alt="">
		</div>
		<el-submenu index="1">
			<template slot="title">
				<i class="el-icon-location"></i>
				<span>導(dǎo)航一</span>
			</template>
			<el-menu-item-group>
				<template slot="title">分組一</template>
				<el-menu-item index="1-1">選項(xiàng)1</el-menu-item>
				<el-menu-item index="1-2">選項(xiàng)2</el-menu-item>
			</el-menu-item-group>
			<el-menu-item-group title="分組2">
				<el-menu-item index="1-3">選項(xiàng)3</el-menu-item>
			</el-menu-item-group>
			<el-submenu index="1-4">
				<template slot="title">選項(xiàng)4</template>
				<el-menu-item index="1-4-1">選項(xiàng)1</el-menu-item>
			</el-submenu>
		</el-submenu>
		<el-menu-item index="2">
			<i class="el-icon-menu"></i>
			<span slot="title">導(dǎo)航二</span>
		</el-menu-item>
		<el-menu-item index="3" disabled>
			<i class="el-icon-document"></i>
			<span slot="title">導(dǎo)航三</span>
		</el-menu-item>
		<el-menu-item index="4">
			<i class="el-icon-setting"></i>
			<span slot="title">導(dǎo)航四</span>
		</el-menu-item>
	</el-menu>
</template>
<script>
	export default {
		
	}
</script>
<style>
	.el-menu-vertical-demo:not(.el-menu--collapse) {
		width: 240px;
		min-height: 400px;
	}

	.el-menu-vertical-demo:not(.el-menu--collapse) {
		border: none;
		text-align: left;
	}

	.el-menu-item-group__title {
		padding: 0px;
	}

	.el-menu-bg {
		background-color: #1f2d3d !important;
	}

	.el-menu {
		border: none;
	}

	.logobox {
		height: 40px;
		line-height: 40px;
		color: #9d9d9d;
		font-size: 20px;
		text-align: center;
		padding: 20px 0px;
	}

	.logoimg {
		height: 40px;
	}
</style>

TopNav.vue

<template>
	<!-- <el-menu :default-active="activeIndex2" class="el-menu-demo" mode="horizontal" @select="handleSelect" background-color="#545c64"
	 text-color="#fff" active-text-color="#ffd04b">
		<el-menu-item index="1">處理中心</el-menu-item>
		<el-submenu index="2">
			<template slot="title">我的工作臺(tái)</template>
			<el-menu-item index="2-1">選項(xiàng)1</el-menu-item>
			<el-menu-item index="2-2">選項(xiàng)2</el-menu-item>
			<el-menu-item index="2-3">選項(xiàng)3</el-menu-item>
			<el-submenu index="2-4">
				<template slot="title">選項(xiàng)4</template>
				<el-menu-item index="2-4-1">選項(xiàng)1</el-menu-item>
				<el-menu-item index="2-4-2">選項(xiàng)2</el-menu-item>
				<el-menu-item index="2-4-3">選項(xiàng)3</el-menu-item>
			</el-submenu>
		</el-submenu>

		<el-menu-item index="3" disabled>消息中心</el-menu-item>
		<el-menu-item index="4"><a  target="_blank">訂單管理</a></el-menu-item>
	</el-menu> -->
	<el-menu class="el-menu-demo" mode="horizontal" background-color="#334157" text-color="#fff" active-text-color="#fff">
		<el-button class="buttonimg">
			<img class="showimg" :src="collapsed?imgshow:imgsq" @click="doToggle()">
		</el-button>
		<el-submenu index="2" class="submenu">
			<template slot="title">超級管理員</template>
			<el-menu-item index="2-1">設(shè)置</el-menu-item>
			<el-menu-item index="2-2">個(gè)人中心</el-menu-item>
			<el-menu-item @click="exit()" index="2-3">退出</el-menu-item>
		</el-submenu>
	</el-menu>
</template>

<script>
	export default {
		
	}
</script>

<style scoped>
	.el-menu-vertical-demo:not(.el-menu--collapse) {
		border: none;
	}

	.submenu {
		float: right;
	}

	.buttonimg {
		height: 60px;
		background-color: transparent;
		border: none;
	}

	.showimg {
		width: 26px;
		height: 26px;
		position: absolute;
		top: 17px;
		left: 17px;
	}

	.showimg:active {
		border: none;
	}
</style>

② 給組件配置路由關(guān)系

index.js:

import Vue from 'vue'
import Router from 'vue-router'
import HelloWorld from '@/components/HelloWorld'
import AppMain from '@/components/AppMain'
import LeftNav from '@/components/LeftNav'
import TopNav from '@/components/TopNav'
import Login from '@/views/Login'
import Register from '@/views/Register'


Vue.use(Router)

export default new Router({
	routes: [{
		path: '/',
		name: 'Login',
		component: Login
	
	},{path: '/Register',
		name: 'Register',
		component: Register,
		
	},{path: '/AppMain',
		name: 'AppMain',
		component: AppMain,
		children:[
			{path: '/LeftNav',
				name: 'LeftNav',
				component: LeftNav,
				
			},{path: '/TopNav',
				name: 'TopNav',
				component: TopNav
			}
		]
	}
	]
})

Login.vue跳轉(zhuǎn)到AppMain(登入跳到主界面)

this.$router.push('/AppMian');

【Vue.js】使用Element中的Mock.js搭建首頁導(dǎo)航&左側(cè)菜單---【超高級教學(xué)】,vue.js,前端,javascript

【Vue.js】使用Element中的Mock.js搭建首頁導(dǎo)航&左側(cè)菜單---【超高級教學(xué)】,vue.js,前端,javascript

3.2 結(jié)合總線完成組件通訊

?Bus事件適用于父子組件、非父子組件等之間的通信

定義Bus總線:main.js

new Vue({
  el: '#app',
  data(){
    return{
      Bus:new Vue()
    }
  },
  router,
  components: { App },
  template: '<App/>'
})

TopNav.vue:

methods:{
      doToggle(){//收起左側(cè)菜單事件
        this.collapsed=!this.collapsed;
        //將是否折疊的變量放入總線
        this.$root.Bus.$emit('aaa',this.collapsed);
      },
      exit(){//退出事件
        this.$router.push("/")
      }
    }

?collapsed默認(rèn)flase,當(dāng)我們點(diǎn)擊的時(shí)候就會(huì)取反,flase就會(huì)變?yōu)閠rue,并把是否折疊的變量放入總線中方便其他組件調(diào)取

LeftNav.vue:

              created(){
		      this.$root.Bus.$on('aaa',r=>{
		        this.collapsed=r;
		      });
		    }

在組件創(chuàng)建時(shí)訂閱了一個(gè)名為?'aaa'?的事件,并在事件觸發(fā)時(shí)將接收到的數(shù)據(jù)賦值給?collapsed?屬性。

AppMain.vue:

created(){
      this.$root.Bus.$on('aaa',r=>{
        this.asideClass=r ? 'main-aside-collapsed':'main-aside';
      });
    }

效果圖:?

【Vue.js】使用Element中的Mock.js搭建首頁導(dǎo)航&左側(cè)菜單---【超高級教學(xué)】,vue.js,前端,javascript文章來源地址http://www.zghlxwxcb.cn/news/detail-725185.html

到了這里,關(guān)于【Vue.js】使用Element中的Mock.js搭建首頁導(dǎo)航&左側(cè)菜單---【超高級教學(xué)】的文章就介紹完了。如果您還想了解更多內(nèi)容,請?jiān)谟疑辖撬阉鱐OY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來自互聯(lián)網(wǎng)用戶投稿,該文觀點(diǎn)僅代表作者本人,不代表本站立場。本站僅提供信息存儲(chǔ)空間服務(wù),不擁有所有權(quán),不承擔(dān)相關(guān)法律責(zé)任。如若轉(zhuǎn)載,請注明出處: 如若內(nèi)容造成侵權(quán)/違法違規(guī)/事實(shí)不符,請點(diǎn)擊違法舉報(bào)進(jìn)行投訴反饋,一經(jīng)查實(shí),立即刪除!

領(lǐng)支付寶紅包贊助服務(wù)器費(fèi)用

相關(guān)文章

  • 微信小程序之會(huì)議OA系統(tǒng)首頁布局搭建與Mock數(shù)據(jù)交互

    微信小程序之會(huì)議OA系統(tǒng)首頁布局搭建與Mock數(shù)據(jù)交互

    目錄 前言 一、Flex 布局(?分類?編程技術(shù)) 1、Flex布局是什么? 2、基本概念 3、容器的屬性 3.1 flex-direction屬性 3.2 flex-wrap屬性 3.3 flex-flow 3.4 justify-content屬性 3.5 align-items屬性 3.6 align-content屬性 4、項(xiàng)目的屬性 4.1 order屬性 4.2 flex-grow屬性 4.3 flex-shrink屬性 4.4 flex-basis屬性 4.5 fl

    2024年02月08日
    瀏覽(22)
  • Vue3中簡單使用Mock.js

    Vue3中簡單使用Mock.js

    mock.js簡介 ? 官方鏈接:Mock.js (mockjs.com) ????????前端開發(fā)人員用來模擬虛擬數(shù)據(jù),攔截ajax請求,方便模擬后端接口 安裝 使用 ????????本文主要介紹在Vue項(xiàng)目中使用mock.js,包括axios發(fā)送請求與請求簡單封裝 創(chuàng)建mock文件夾,新建index.js文件 ? ? ? ? 模擬數(shù)據(jù)可自己手動(dòng)

    2024年02月02日
    瀏覽(25)
  • 【vue3】固定上導(dǎo)航欄和左側(cè)導(dǎo)航欄,只顯示其他內(nèi)容在主內(nèi)容區(qū)域

    【vue3】固定上導(dǎo)航欄和左側(cè)導(dǎo)航欄,只顯示其他內(nèi)容在主內(nèi)容區(qū)域

    在一個(gè)單獨(dú)的vue組件文件中只寫出上導(dǎo)航欄和左側(cè)導(dǎo)航欄的內(nèi)容 將你想要展示的頁面主內(nèi)容寫到單獨(dú)的組件中 在index.js寫路由,將【想要展示的頁面主內(nèi)容的路由】作為【子路由】寫在【只寫出上導(dǎo)航欄和左側(cè)導(dǎo)航欄的路由】的下面; 在elment-plus官網(wǎng)上找到自己需要的布局容

    2024年02月12日
    瀏覽(24)
  • 解決Vue3 使用Element-Plus導(dǎo)航刷新active高亮消失

    解決Vue3 使用Element-Plus導(dǎo)航刷新active高亮消失

    啟用路由模式會(huì)在激活導(dǎo)航時(shí)以 index 作為 path 進(jìn)行路由跳轉(zhuǎn) 使用 default-active 來設(shè)置加載時(shí)的激活項(xiàng)。 接下來打印一下選中項(xiàng)index和index路徑, 刷新也是沒有任何問題的,active不會(huì)消失,整體代碼如下:

    2024年02月14日
    瀏覽(20)
  • 在dedecms模板中將面包屑導(dǎo)航中的"首頁"換成小圖標(biāo)的方法

    dedecms織夢模板將面包屑導(dǎo)航中的首頁換成圖片的方法 我們打開 /include/typelink.class.php 文件 找到: 修改為: ? yii666提醒您: 上面修改后,你的那個(gè)小圖標(biāo)要放到/style/目錄,文件名為genban.jpg

    2024年02月03日
    瀏覽(14)
  • Vue3 入門筆記 ---- 利用Element Plus對頁面進(jìn)行布局劃分以及實(shí)現(xiàn)左側(cè)公共菜單

    Vue3 入門筆記 ---- 利用Element Plus對頁面進(jìn)行布局劃分以及實(shí)現(xiàn)左側(cè)公共菜單

    這個(gè)系列的筆記重點(diǎn)會(huì)放在怎么樣利用Vue3把項(xiàng)目架設(shè)起來并跟后端API互動(dòng),不會(huì)介紹Vue的基礎(chǔ)特性,關(guān)于Vue的基礎(chǔ)特性可以參考這個(gè)視頻四個(gè)小時(shí)帶你快速入門Vue,我是看這個(gè)入門的,覺得還不錯(cuò)。 代碼地址: https://github.com/yexia553/vue_study/tree/%E9%85%8D%E7%BD%AEvue-router/vue3-note

    2024年02月04日
    瀏覽(28)
  • 【Vue+Element-plus】記錄后臺(tái)首頁多echart圖靜態(tài)頁面

    【Vue+Element-plus】記錄后臺(tái)首頁多echart圖靜態(tài)頁面

    ?Index.vue ?DataComparison.vue DateTime.vue HealPatient.vue PeopleNumber.vur TrackPatients.vue VisitsNumber.vue

    2024年02月13日
    瀏覽(18)
  • layui實(shí)現(xiàn)左側(cè)導(dǎo)航

    layui實(shí)現(xiàn)左側(cè)導(dǎo)航

    今日金句 戰(zhàn)術(shù)上的勤奮并不能掩蓋戰(zhàn)略上的懶惰 在上篇博客中,我們學(xué)習(xí)了layui的入門,還實(shí)現(xiàn)了后臺(tái)的登陸注冊,今天我們就來完成后臺(tái)首頁的重要組成部分——左側(cè)導(dǎo)航樹形菜單 導(dǎo)航一般指頁面引導(dǎo)性頻道集合,多以菜單的形式呈現(xiàn),可應(yīng)用于頭部和側(cè)邊,是整個(gè)網(wǎng)頁

    2024年02月13日
    瀏覽(21)
  • Vue.js 中使用 Element UI 實(shí)現(xiàn)異步加載分頁列表

    Vue.js 中使用 Element UI 實(shí)現(xiàn)異步加載分頁列表

    在前端開發(fā)中,我們常常需要展示大量數(shù)據(jù),并提供分頁瀏覽的功能。本篇博客將介紹如何使用 Vue.js 和 Element UI 組件庫創(chuàng)建一個(gè)簡單的異步加載分頁列表。 Vue.js Element UI JavaScript 我們將創(chuàng)建一個(gè)包含表格和分頁組件的 Vue 單文件組件。以下是組件的基本結(jié)構(gòu): 引入 Element U

    2024年02月04日
    瀏覽(33)

覺得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請作者喝杯咖啡吧~博客贊助

支付寶掃一掃領(lǐng)取紅包,優(yōu)惠每天領(lǐng)

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包