亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

詳解Vue Elememt-UI構建管理后臺

2019-11-19 14:17:23
字體:
來源:轉載
供稿:網友

安裝

我使用的是 vue-cli 初始化項目,命令如下:

npm i -g vue-climkdir my-project && cd my-projectvue init webpack

修改 package.json 文件:

..."dependencies": { "vue": "^2.5.2", "vue-router": "^3.0.1", "element-ui": "^2.0.7", // element-ui "axios": "^0.17.1" // http 請求庫}...

之后執行 npm install 進行安裝依賴,如果安裝速度有點慢的話,可以試一下 cnpm ,具體安裝和用法自行查找。

簡單介紹下項目的目錄結構:

├─build // 構建配置├─config // 配置文件├─src // vue 開發源文件目錄├────assets // css/js 文件├────components // vue 組件├────router  // 路由├────App.vue  // 啟動組件├────main.js // 入口文件├─static // 靜態文件目錄├─test // 測試目錄

之后在項目根目錄執行 npm run dev ,打開瀏覽器輸入 http://localhost:8080 就可以查看了。

目標

  • 登錄頁面,登錄,退出功能
  • 首頁,調用接口渲染列表

路由

路由使用的是 vue-router,具體用法可參考 官方文檔

我們這里需要兩個路由:

src/router/index.js

import Vue from 'vue'import Router from 'vue-router'import Index from '@/components/Index'import Login from '@/components/Login'Vue.use(Router)const routers = new Router({ routes: [  {   path: '/index',   name: 'index',   component: Index  },  {   path: '/login',   name: 'login',   component: Login  } ]})routers.beforeEach((to, from, next) => { if (to.name !== 'login' && !localStorage.getItem('token')) {  next({path: 'login'}) } else {  next() }})export default routers

登錄頁面

src/components/Login.vue

<template> <div class="login">  <el-form name="aa" :inline="true" label-position="right" label-width="80px">    <el-form-item label="用戶名">     <el-input v-model="user.name"></el-input>    </el-form-item>    <el-form-item label="密碼">     <el-input type="password" v-model="user.password"></el-input>    </el-form-item>    <el-form-item label=" ">     <el-button type="primary" @click="login()">登錄</el-button>    </el-form-item>  </el-form> </div></template><script>import $http from '@/api/'import config from '@/config'export default { data () {  return {   user: {    name: '',    password: ''   }  } }, mounted: function () {  var token = localStorage.getItem('token')  if (token) {   this.$router.push('/index')  } }, methods: {  login: function () {   var data = {    grant_type: 'password',    client_id: config.oauth_client_id,    client_secret: config.oauth_secret,    username: this.user.name,    password: this.user.password   }   var _this = this   $http.login(data).then(function (res) {    if (res.status === 200) {     $http.setToken(res.data.access_token)     _this.$message({      showClose: false,      message: '登錄成功',      type: 'success'     })     _this.$router.push('/index')    } else {     _this.$message({      showClose: false,      message: '登錄失敗',      type: 'error'     })    }   })  } }}</script><style>.login{  width: 300px;  margin: 100px auto;  background-color: #ffffff;  padding: 30px 30px 5px;  border-radius: 5px;}</style>

首頁

src/components/Index.vue

<template> <div class="main">  <el-table   stripe   v-loading="loading"   element-loading-background="#dddddd"   :data="tableData"   style="width: 100%">   <el-table-column    prop="id"    label="ID">   </el-table-column>   <el-table-column    prop="name"    label="名稱">   </el-table-column>  </el-table>  <el-pagination   background   layout="prev, pager, next"   :total="total"   class="page"   @current-change="pageList">  </el-pagination> </div></template><script>import $http from '@/api/'export default { data () {  return {   tableData: [],   total: 0,   loading: false  } }, mounted: function () {  this.getList() }, methods: {  pageList: function (page) {   this.search.page = page   this.getList()  },  getList: function () {   var _this = this   _this.loading = true   $http.index().then(function (res) {    if (res.status === 200) {     _this.tableData = res.data.data.lists     _this.total = res.data.data.total    }    _this.loading = false   })  } }}</script>

App

src/App.vue

<template> <div id="app">  <el-row v-if="token">   <menus class="left-menu">    <h3 class="logo"><a href="/" rel="external nofollow" >Admin</a></h3>   </menus>   <el-col :span="21" :gutter="0" :offset="3">    <el-breadcrumb separator-class="el-icon-arrow-right" class="breadcrumb">     <el-breadcrumb-item :to="{ path: '/' }">首頁</el-breadcrumb-item>     <el-breadcrumb-item class="active">列表</el-breadcrumb-item>    </el-breadcrumb>    <el-dropdown @command="operate" class="header">     <img src="/static/image/head.jpg" />     <el-dropdown-menu slot="dropdown" :click="true">      <el-dropdown-item command="/user/profile">基本資料</el-dropdown-item>      <el-dropdown-item command="/logout">安全退出</el-dropdown-item>     </el-dropdown-menu>    </el-dropdown>    <router-view/>   </el-col>   <el-col :span="21" :gutter="0" :offset="3" class="footer">Copyright © 2017 Flyerboy All Rights Reserved</el-col>   </el-row>  <router-view v-if="!token" /> </div></template><script>import Menus from '@/components/Menu'export default { name: 'App', data () {  return {   token: false  } }, mounted: function () {  this.token = localStorage.getItem('token') ? true : false }, watch: {  '$route.path': function ($newVal, $oldVal) {   this.token = localStorage.getItem('token') ? true : false  } }, methods: {   operate: function (command) {   if (command === '/logout') {    localStorage.removeItem('token')    this.$router.push('login')   } else {    this.$router.push(command)   }  } }, components: {  Menus }}</script><style>body{ margin: 0; padding: 0; background-color: #eeeeee;}.header{ position: absolute; top: 5px; right: 20px;}.header img{ width: 38px; height: 38px; border-radius: 20px; border: 1px solid #aaaaaa;}#app { font-family: 'Avenir', Helvetica, Arial, sans-serif; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale;}.main{ padding: 20px; min-height: 600px; margin-bottom: 20px;}.main table{ background: #ffffff;}.left-menu{ background-color: #33374B;}.logo{ padding: 20px 0 15px 20px; font-size: 24px; border-bottom: 2px solid #3a8ee6;}.logo a{ color: #ffffff; text-decoration: none;}.left-menu .el-menu{ border-right: 0;}.breadcrumb{ line-height: 40px; padding: 5px 20px; background: #ffffff;}.breadcrumb span{ color: #069; font-weight: normal;}.breadcrumb .active{ color: #aaaaaa;}.page{ margin: 20px 0 0; margin-left: -10px;}.page .el-pager li.number{ background-color: #ffffff;}.el-submenu .el-menu-item{ padding-left: 60px !important;}.footer{ position: fixed; bottom: 0; right: 0; font-size: 12px; color: #888888; padding: 15px 20px; text-align: center; background-color: #ffffff; margin-top: 40px;}</style>

調用 API

src/api/index.js

import axios from 'axios'axios.defaults.baseURL = 'http://localhost:8000/'axios.defaults.headers.post['Content-Type'] = 'application/x-www-form-urlencoded'axios.defaults.headers.common['Authorization'] = 'Bearer ' + localStorage.getItem('token')export default { setToken: function (token) {  localStorage.setItem('token', token)  axios.defaults.headers.common['Authorization'] = 'Bearer ' + token }, login: function (param) {  return axios.post('oauth/token', param) }, index: function (params) {  return axios.get('api/user/list', {   params: params  }) }}

config

src/config.js 這里配置登錄 oauth 需要的 client_id 和 secret

export default { oauth_client_id: 2, oauth_secret: ''}

main.js

src/main.js

import Vue from 'vue'import App from './App'import router from './router'import ElementUI from 'element-ui'import 'element-ui/lib/theme-chalk/index.css'Vue.use(ElementUI)Vue.config.productionTip = falsenew Vue({ el: '#app', router, components: { App }, template: '<App/>'})

api 接口

主要用到兩個接口,一個是 api/oauth/token 登錄獲取 token 接口,一個獲取列表 api/user/list。

第一個接口是用到 laravel oauth,第二個接口直接是一個簡單的查詢用戶列表接口,詳細講會在下一篇文章中講述。

以上就是本次整理的關于Vue Elememt-UI構建管理后臺的全部內容,感謝大家對武林網的支持。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美视频第一页| 中文在线资源观看视频网站免费不卡| 2019国产精品自在线拍国产不卡| 国产精品第10页| 成人国产亚洲精品a区天堂华泰| 欧美精品在线极品| 亚洲性夜色噜噜噜7777| 久久久久久久一区二区三区| 久久中文字幕在线视频| 亚洲久久久久久久久久久| 97免费视频在线| 亚洲成年人在线| 亚洲电影免费观看高清| 狠狠色狠狠色综合日日五| 久久久久久成人精品| 欧美日韩精品在线观看| 国产精品久久久久久久久久新婚| 91av在线国产| 日本精品视频在线播放| 日韩视频亚洲视频| 91精品国产99久久久久久| 亚洲第一中文字幕在线观看| 96国产粉嫩美女| 久久理论片午夜琪琪电影网| 2019亚洲日韩新视频| 日韩中文字幕第一页| 亚洲国产日韩欧美在线99| 国产欧美 在线欧美| 欧美大片免费观看在线观看网站推荐| 亚洲欧美综合精品久久成人| 精品动漫一区二区三区| 日韩一级黄色av| 91成人在线观看国产| 久久久av亚洲男天堂| 日韩国产精品亚洲а∨天堂免| 久久成人在线视频| 国产做受高潮69| 这里精品视频免费| 欧美日韩激情美女| www.亚洲免费视频| 欧美精品在线观看| 最近免费中文字幕视频2019| 中文字幕精品www乱入免费视频| 中文字幕日韩视频| 亚洲精选一区二区| 亚洲精品永久免费| 国语自产偷拍精品视频偷| 日韩高清电影好看的电视剧电影| 亚洲精品www久久久| 欧美一区视频在线| 三级精品视频久久久久| 欧美成aaa人片在线观看蜜臀| 久久久免费在线观看| 日韩成人免费视频| 亚洲成人激情图| 久久激情视频免费观看| 国产不卡av在线| 欧美激情一区二区三级高清视频| 国产精品精品久久久久久| 日韩av在线天堂网| 亚洲第一精品夜夜躁人人爽| 岛国视频午夜一区免费在线观看| 亚洲xxxx妇黄裸体| 国产不卡精品视男人的天堂| 亚洲国产成人精品女人久久久| yw.139尤物在线精品视频| 92福利视频午夜1000合集在线观看| 亚洲成人网在线| 一区二区三区四区视频| 国产视频精品自拍| 亚洲第一福利网| 欧美色另类天堂2015| 日韩福利在线播放| 成人一区二区电影| 亚洲精品电影网| 日本高清久久天堂| 亚洲欧美国产精品va在线观看| 91最新国产视频| 欧美亚洲国产日韩2020| 久久久国产精品亚洲一区| 久久人人爽亚洲精品天堂| 亚洲免费电影在线观看| 亚洲精品一二区| 欲色天天网综合久久| 久久精品国产久精国产一老狼| 亚洲一区二区三区在线视频| 日韩国产欧美精品一区二区三区| 国产不卡av在线免费观看| 亚洲最大av网站| 精品欧美激情精品一区| 精品国产91久久久| 欧美国产日产韩国视频| 日韩中文字幕不卡视频| 久久免费视频网站| 欧美激情一级欧美精品| 18性欧美xxxⅹ性满足| 亚洲国产成人91精品| 亚洲高清福利视频| 69av视频在线播放| 国产在线播放不卡| 久久人人97超碰精品888| 精品久久香蕉国产线看观看亚洲| 日韩高清a**址| 在线观看国产精品91| 欧美亚洲午夜视频在线观看| 久久理论片午夜琪琪电影网| 亚洲午夜久久久影院| 国产97在线|亚洲| 欧美激情亚洲激情| 九九视频直播综合网| 亚洲成色www8888| 一本色道久久88亚洲综合88| 2019亚洲男人天堂| 欧美激情中文字幕在线| 78m国产成人精品视频| 国产亚洲欧洲黄色| 91久久综合亚洲鲁鲁五月天| 91精品久久久久久久久久另类| 欧美在线视频免费| 国产精品永久免费观看| 日韩经典第一页| 亚洲毛茸茸少妇高潮呻吟| 日韩欧美在线看| 国产色视频一区| 亚洲人av在线影院| 8090理伦午夜在线电影| 国产成人一区二区三区电影| 美日韩精品免费观看视频| 91精品视频免费| xxxx欧美18另类的高清| 欧美疯狂xxxx大交乱88av| 亚洲日本aⅴ片在线观看香蕉| 久久久久久一区二区三区| 中文字幕在线观看亚洲| 中文.日本.精品| 中文字幕亚洲色图| 日韩精品中文字幕有码专区| 97涩涩爰在线观看亚洲| 欧美日韩性视频在线| 久久露脸国产精品| 亚洲精品久久久久国产| 午夜精品一区二区三区在线播放| 久久久久国产精品免费网站| 中文在线资源观看视频网站免费不卡| 日韩精品极品视频免费观看| 欧美一级片一区| 欧美一级大片在线观看| 国内精品伊人久久| 亚洲精品日韩激情在线电影| 国产一区二区三区在线| 亚洲视频在线免费观看| 日韩精品在线视频| 亚洲第一精品夜夜躁人人躁| 精品视频在线播放免| 亚洲视频一区二区三区| 91wwwcom在线观看| 成人中文字幕在线观看| 最近2019年手机中文字幕| 在线观看国产成人av片| 精品国产一区二区三区久久狼5月| 国产精品视频地址| 456亚洲影院| 国内外成人免费激情在线视频网站| 亚洲自拍偷拍色片视频|