vue+elementUI項目實戰1

来源:https://www.cnblogs.com/wmc1125/archive/2020/07/01/13221524.html
-Advertisement-
Play Games

可視化新建項目 打開可視化面板 vue ui 創建項目 可以保存為預設,下次使用此預設時就不需要再次配置了 創建完成後我們可以看到他的文件結構 vue3初體驗 入口文件在public中,不在根目錄 配置全局變數 根目錄新建vue.config.js // Vue.config.js 配置選項 mod ...


可視化新建項目

打開可視化面板

vue ui

image-20200701103311705

創建項目

image-20200701103242645

image-20200701103418984

image-20200701103620582

image-20200701103707915

image-20200701103901875

可以保存為預設,下次使用此預設時就不需要再次配置了

創建完成後我們可以看到他的文件結構

image-20200701104332082

image-20200701104356103

vue3初體驗

入口文件在public中,不在根目錄

配置全局變數 根目錄新建vue.config.js

// Vue.config.js 配置選項
module.exports = {
    // 選項
    //  基本路徑 vue.cli 3.3以前請使用baseUrl
    publicPath: "/",
    //  構建時的輸出目錄
    outputDir: "dist",
    //  放置靜態資源的目錄
    assetsDir: "",
    //  是否為生產環境構建生成 source map?
    productionSourceMap: true,
    //  調整內部的 webpack 配置
    configureWebpack: () => {}, //(Object | Function)
    chainWebpack: () => {},

	// CSS 相關選項
    css: {
        // 將組件內的 CSS 提取到一個單獨的 CSS 文件 (只用在生產環境中)
        // 也可以是一個傳遞給 `extract-text-webpack-plugin` 的選項對象
        extract: true,
        // 是否開啟 CSS source map?
        sourceMap: false,
        // 為預處理器的 loader 傳遞自定義選項。比如傳遞給
        // Css-loader 時,使用 `{ Css: { ... } }`。
        loaderOptions: {},
        // 為所有的 CSS 及其預處理文件開啟 CSS Modules。
        // 這個選項不會影響 `*.vue` 文件。
        modules: false
    },

	// 配置 webpack-dev-server 行為。
    devServer: {
		//true  自動打開瀏覽器
        open: true,  
        port: 8088,
    },
	// 三方插件的選項
    pluginOptions: {
        // ...
    }
}

啟動命令:定位到根目錄,執行命令 npm run serve

自動打開項目網頁

image-20200701111048896

組件間的傳值

新建兩個文件child.vue parent.vue

image-20200701112505848

父子組件的傳值

  • props/$emit
  • $parent/children (獲取組件信息)
  • $ref (獲取組件信息 給了一個名稱)

app.vue

<template>  
      <!-- <router-link to="/">Home</router-link> |
      <router-link to="/about">About</router-link>
      <router-link to="/parent">Parent</router-link> -->
    <m-parent/>
</template>

<style>

</style>
<script>
import MParent from './views/Parent'

export default {
  components: {
    MParent
  }
}
</script>

parent.vue

<template>
    <div>
       <h1> Parent</h1>
        <div>
            <m-child msg="'hello world'" @showMsg="showMsg" ref="testRef"></m-child> 
        </div>
        <p>子組件向父組件傳過來的值:{{msg}}</p>
    </div>
</template>

<script>
import MChild from './Child'
export default {
    data(){
        return{
            msg:''
        }
    },
    components:{
      MChild
    },
    methods:{
        showMsg(val){
            this.msg = val
        }
    },
    // 鉤子
    mounted(){
        //列印子組件的數據
        console.log(this.$children)
        console.log(this.$children[0]['aa'])

        //ref
        //獲取上面ref="testRef" 的組件的信息
        console.log('ref',this.$refs.testRef)
    }
}
</script>
<style  scoped>
</style>

child.vue

<template>
    <div>
        <h3>Child</h3>
        <p>父組件傳過來的值:{{msg}}</p>
        <button @click="passMsg">向父組件傳值</button>
    </div>
</template>

<script>
export default {
    data(){
        return{
            aa:'測試aa'
        }
    },
    // 接收父組件傳過來的值
    props:{
        msg:{
            type:String,
            default:''
        }
    },
    methods:{
        passMsg(){
            // this.$emit('自定義的事件名','傳遞的值')
            this.$emit('showMsg','我是來自子組件的值')
        }
    },
    // 鉤子
    mounted(){
        console.log(this.$$parent)
    }
}
</script>

非父子組件之間的傳值

  • 事件匯流排
App.vue 向child.vue傳值
1.新建bus.js
import Vue from 'vue'
export default new Vue;

2.app.vue
給出點擊按鈕  <button @click="passMsg">事件匯流排傳遞</button>
引入bus.js 
<script>
import bus from './util/bus'
export default {
  methods:{
    passMsg(){
      bus.$emit('msg','事件匯流排傳遞-----')
    }
  }
}
</script>
3. child.vue
<p>{{childMsg}}</p>

<script>
import bus from '../util/bus'
export default {
    // 接收父組件傳過來的值
    props:{
        childMsg:{
            type:String,
            default:''
        }
    },
    // 鉤子
    mounted(){
        bus.$on('msg',(val)=>{
            this.childMsg = val
        })

    }
}
</script>

  • $attrs/ $listeners

    解決多級組件傳值問題

路由

vue-router

跳轉

      <router-link to="/page">點擊跳轉</router-link>
      <button @click="toPage">通過事件跳轉</button>
      
methods:{
    toPage(){
      this.$router.push({path:'/page'})
    }
  }

動態路由

 {
    path: '/list/:id',
    name: 'List',
    component: () => import('../views/List.vue')
  },
  
  {{$route.params.id}}
  

Vuex

/store 中

import Vue from 'vue'
import Vuex from 'vuex'

Vue.use(Vuex)

export default new Vuex.Store({
  state: {
    count:9
  },
  mutations: {
    add(state){
      state.count++
    },
    decreate(state){
      state.count--
    }
  },
  // 非同步操作
  actions: {
    delayAdd(context){
      setTimeout(()=>{
        context.commit('add')
      },1000)
    }
  },
  modules: {
  }
})

獲取store中的值
<p>{{vuex_count}}</p>
computed:{
    vuex_count(){
      return this.$store.state.count
    }
  }

插件推薦

image-20200701112358247

本文由博客一文多發平臺 OpenWrite 發佈!


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

-Advertisement-
Play Games
更多相關文章
  • html簡述: HTML 指的是超文本標記語言 (Hyper Text Markup Language)是用來描述網頁的一種語言。 HTML 不是一種編程語言,而是一種標記語言 (markup language)。 標記語言是一套標記標簽 (markup tag)。 作用:網頁是由網頁元素組成的 , ...
  • 開放埠規劃: mysql-develop:3407 mysql-test: 3408 mysql-release: 3409 ps: 1.不推薦使用預設埠-3306,建議自定義埠 2.如果採用阿裡雲伺服器,在安全組開放埠 3.自建伺服器依據實際情況打開防火牆開放埠[各個系統防火牆不一樣,操 ...
  • 老孟導讀:這是老孟翻譯的付費文章,文章所有權歸原作者所有。 歡迎加入老孟Flutter交流群,每周翻譯2-3篇付費文章,精彩不容錯過。 原文地址:https://medium.com/swlh/flutter-vs-react-native-vs-native-deep-performance-co ...
  • 之前已經介紹了在Ubuntu 16.04上編譯OpenJDK8的源代碼和調試HotSpot源代碼。這一章將介紹HotSpot項目的目錄結構。 HotSpot目錄下主要由agent、make、src和test這4個子目錄構成。其中agent目錄下包含了Serviceability Agent的客戶端實 ...
  • 1 #!/usr/bin/env python 2 # -*- coding: utf-8 -*- 3 4 from tkinter import * 5 import math 6 import threading 7 import time 8 9 10 root = Tk() 11 cv = ...
  • >>> from docx import Document >>> word=Document(r'F:\word練習\qq.docx') >>> for 段落 in word.paragraphs: print(段落.text) 標題一 我是二級標題 今天下午下雨,但是我還是覺得好熱 我是一級標題 ...
  • 在學習C語言的時候,我們常常會碰到C語言NULL值和數字 0 ,很多小伙伴搞不清楚他們之間的一個區別,今天我們就瞭解一下他們之間的區別,一起來看看吧! 先看下麵一段代碼輸出什麼: 輸出<null> ,單步調試可以看出執行int *p=NULL,p的值為0x00000000,可以看出,NULL在實際底 ...
  • springboot 1:自動配置原理 出發: @SpringBootApplication註解:是springboot的核心註解 進入可以得到 可以看到:其具有以下兩個註解 @SpringBootConfiguration //表示這是springboot的一個參數 @EnableAutoConf ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...