vue+element-ui JYAdmin後臺管理系統模板-集成方案【項目搭建篇1】

来源:https://www.cnblogs.com/wxy-zhangxiaobin/archive/2020/06/30/13216262.html
-Advertisement-
Play Games

項目搭建時間:2020-06-29 本章節:講述基於vue/cli, 項目的基礎搭建。 本主題講述了vue+element-ui JYAdmin 後臺管理系統模板-集成方案,從零到一的手寫搭建全過程。 該項目不僅是一個持續完善、高效簡潔的後臺管理系統模板,還是一套企業級後臺系統開發集成方案,致力於打 ...


 

 

項目搭建時間:2020-06-29

本章節:講述基於vue/cli,

項目的基礎搭建。

本主題講述了vue+element-ui JYAdmin  後臺管理系統模板-集成方案,從零到一的手寫搭建全過程。

該項目不僅是一個持續完善、高效簡潔的後臺管理系統模板,還是一套企業級後臺系統開發集成方案,致力於打造一個
與時俱進、高效易懂、高復用、易維護擴展的應用方案。

 

(1)、 檢查環境


 

 

 

 

 

1、vue create vueapp 預設安裝


 

 

 

 

2、啟動項目




$ cd vueapp
$ npm run serve

 

 

 

 

 

  3、IE相容測試 支持IE11

4、安裝路由和vuex

cnpm install --save vue-router
cnpm install --save vuex

  

5、安裝sass和element-ui

cnpm install --save sass-loader
cnpm install --save node-sasscnpm i element-ui -S

  

5.1、按需引入element-ui

cnpm install babel-plugin-component -D

  

然後,將 .babelrc 修改為:

{
  "presets": [["es2015", { "modules": false }]],
  "plugins": [
    [
      "component",
      {
        "libraryName": "element-ui",
        "styleLibraryName": "theme-chalk"
      }
    ]
  ]
}

  

接下來,如果你只希望引入部分組件,比如 Button 和 Select,那麼需要在 main.js 中寫入以下內容:

 

import Vue from 'vue';
import { Button, Select } from 'element-ui';
import App from './App.vue';

Vue.component(Button.name, Button);
Vue.component(Select.name, Select);
/* 或寫為
 * Vue.use(Button)
 * Vue.use(Select)
 */

new Vue({
  el: '#app',
  render: h => h(App)
});

  

目錄結構如下

 

 

 

 

5、路由配置 (@/router/index.js)

 

import Vue from 'vue'

import Router from 'vue-router'

import routes from './router'

 

Vue.use(Router)

 

const router = new Router({

  routes,

  // mode: 'history',

  // base: '/html/chat'

})

 

// 登陸頁面路由 name

// const LOGIN_PAGE_NAME = 'login'

 

// 跳轉之前

router.beforeEach((to, from, next) => {

  if (to.name) {

    next()

  }

  // const token = getToken()

  // if (!token && to.name !== LOGIN_PAGE_NAME) {

  //   // 未登錄且要跳轉的頁面不是登錄頁

  //   next({

  //     name: LOGIN_PAGE_NAME // 跳轉到登錄頁

  //   })

  // } else if (!token && to.name === LOGIN_PAGE_NAME) {

  //   // 未登陸且要跳轉的頁面是登錄頁

  //   next() // 跳轉

  // } else if (token && to.name === LOGIN_PAGE_NAME) {

  //   // 已登錄且要跳轉的頁面是登錄頁

  //   next({

  //     name: 'index' // 跳轉到 index 頁

  //   })

  // } else {

  //   if (token) {

  //     next() // 跳轉

  //   } else {

  //     next({

  //       name: LOGIN_PAGE_NAME

  //     })

  //   }

  // }

})




// 跳轉之後

// router.afterEach(to => {

//   //

// })

 

export default router

  

5.1、路由配置 (@/router/router.js)

 

/**

 * meta 可配置參數

 * @param {boolean} icon 頁面icon

 * @param {boolean} keepAlive 是否緩存頁面

 * @param {string} title 頁面標題

 */

export default [

  {

    path: '/',

    redirect: '/jsDemo'

  },

  {

    path: '/jsDemo',

    name: 'jsDemo',

    component: () => import('@/pages/jsDemo/index.vue'),

    meta: {

      icon: '',

      keepAlive: true,

      title: 'jsDemo'

    }

  },

  {

    path: '/tsDemo',

    name: 'tsDemo',

    component: () => import('@/pages/tsDemo/index.vue'),

    meta: {

      icon: '',

      keepAlive: false,

      title: 'tsDemo'

    }

  }

]

  

6、store配置 (@/store/index.js)
import Vue from 'vue'

 

import Vuex from 'vuex'





// modules

 

import getters from './getters'

 

import user from './modules/user'

 

Vue.use(Vuex)





export default new Vuex.Store({

 

  state: {

 

    count: 1

 

  },

 

  mutations: {

 

    increment(state, n) {

 

      // 變更狀態

 

      state.count = n

 

    }

 

  },

 

  actions: {

 

    increment({ commit }, count) {

 

      commit('increment', count)

 

    },

 

    incrementA({ commit }, count) {

 

      return new Promise((resolve) => {

 

        commit('increment', count)

 

        resolve()

 

      })

 

    },

 

  },

 

  modules: {

 

    user

 

  },

 

  getters

 

})


  

6.1、store配置 (@/store/getters.js)
const getters = {

 

    user: state => state.user,

 

}

 

export default getters

  

6.2、store配置 (@/store/modules/user.js)

 

const user = {

 

    state: {

 

        name: 'zxb'

 

    },





    mutations: {

 

        SET_NAME: (state, name) => {

 

            state.name = name

 

        }

 

    },





    actions: {

 

        setName({ commit }, name) {

 

            commit('SET_NAME', name)

 

        }

 

    },

 

    getters: {

 

        users(state) {

 

            return state

 

        }

 

    }

 

}





export default user

  

7、主路由組件調用 store (@/pages/jsDemo/index.vue)
<template>

  <div>jsDemo1</div>

</template>

 <script lang="js" src="./jsDemo.js"></script>

 <style lang="scss" src="./jsDemo.scss"  scoped>

  

7.1、主路由組件調用 store (@/pages/jsDemo/jsDemo.js)

 

export default {

    name: 'jsDemo',

    components: {

 

    },

    data() {

        return {

 

        }

    },

    props: {

 

    },

    computed: {

    },

    filters: {

    },

    activated() {

 

    },

    created() {




    },

    mounted() {

        this.$store.state.count = 1

        console.log(this.$store.state.count)

        this.$store.commit('increment', 10)

        console.log(this.$store.state.count)

        this.$store.dispatch('increment', 50)

        console.log(this.$store.state.count)

        this.$store.dispatch('incrementA', 60).then(() => {

            console.log(this.$store.state.count)

        })

        console.log(this.$store.state.count)

        this.$store.commit('SET_NAME', 'zxb1')

        console.log(this.$store.state.user.name)

 

    },

    updated() {

 

    },

    destroyed() {

 

    },

    methods: {

 

    }

}

  

最終效果如下:

 

 

 

 

本章節總結:講述基於vue/cli,

項目的基礎搭建。

1、vue/cl基礎配置,sass、element-ui安裝

2、基礎路由配置

3、ie瀏覽器相容測試

4、vuex安裝與使用

 

如需下載源代碼請聯繫博主

(微信號:lovehua_5360)

你也可以選擇留言反饋

 

     


下章節請關註個人微信公眾號【微信悅】,歡迎持續關註:

備註:(使用微信客戶端打開)

個人微信公眾號:【微信悅】

微信公眾號原文鏈接:http://mp.weixin.qq.com/mp/homepage?__biz=MzIyOTg4MzQyNw==&hid=15&sn=4bc799ac6079fd28d20365f92eb3cb91&scene=18#wechat_redirect

      

 

 

 

 

   

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 序 平時在Oracle的日常相關開發這種,總會遇到各種各樣的坑,索性在這裡記錄下,後續慢慢更新 如有問題,望指正,不勝感激! 1、Oracle 12c登錄問題 背景:之前一直在 Oracle 11g 資料庫上進行相關開發,最近新進項目組使用的是 Oracle 12c 遂入坑12c,瞭解一下新特性 問 ...
  • Redis的發佈與訂閱,有點類似於消息隊列,發送者往頻道發送消息,頻道的訂閱者接收消息。 1. 發佈與訂閱示例 首先,在本機開啟第1個Redis客戶端,執行如下命令訂閱blog.redis頻道: SUBSCRIBE "blog.redis" 然後,在本機開啟第2個Redis客戶端,執行相同的命令訂閱 ...
  • 本文更新於2019-06-23,使用MySQL 5.7,操作系統為Deepin 15.4。 和大多數資料庫不同,插件式存儲引擎是MySQL最重要的特性之一。 InnoDB InnoDB表提供事務安全。 InnoDB表支持外鍵。創建外鍵時,要求父表必須有對應的索引,子表在創建外鍵時也會自動創建對應的索 ...
  • 索引用於快速找出在某個列中某一特定值的行。不使索引,資料庫必須從第一條記錄開始讀完整個表,直到找到相關行。如果表中查詢的列有一個索引,資料庫能快速到達一個位置去搜尋數據,而不必查看所有數據。 索引的含義和特點: 索引是一個單獨的、存儲在磁碟上的數據結構,他們包含著對數據表裡所有記錄的應用指針。使用索 ...
  • 前言: 最近在整理自己的技術棧,收集了一些自己認為比較重要的知識點分享給大家。 runloop 1. iOS中觸摸事件傳遞和響應原理 2. 為什麼只有主線程的runloop是開啟的 3. 為什麼只在主線程刷新UI 4. PerformSelector和runloop的關係 KVO 1. 實現原理 2 ...
  • 為了不顯示標題欄,所以主題使用了 NoActionBar,這也直接導致選項菜單無處顯示,添加一個ToolBar,自定義標題欄。添加menu資源文件夾,添加menu文件,在activity創建的時候創建menu,重載onCreateOptionsMenu,添加菜單項點擊事件onOptionsItemS... ...
  • 切記,一定要先綁定viewpage再添加tab,否則tab的標題無法正常顯示出來。setupwithviewpager會在後臺做很多事,比如清空tabs等,為了更安全的顯示我們的tabs,在綁定viewpager之後,先清空一下tabs再添加 ...
  • 迴圈引用對象序列化?這似乎是一個老生常談的問題,但是99.9%的人所謂的『解決』,都是在『逃避』這個問題。 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...