欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

webpack如何將vue3單頁面應(yīng)用改造成多頁面應(yīng)用

 更新時間:2023年05月23日 16:42:42   作者:自己瞎琢磨  
這篇文章主要介紹了webpack如何將vue3單頁面應(yīng)用改造成多頁面應(yīng)用,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下

上篇文章搞了個單頁面vue,現(xiàn)在要將其改成多頁面,只是簡單嘗試,給了例子

其實(shí)也就是改個webpack的入口和html模版的配置,其他的話,每個頁面都有自己的vue和路由實(shí)例,pinia的話就共享吧

!important,這里是根據(jù)上篇文章配置的更改,更具體的配置可以參考上篇文章

一、改一下項(xiàng)目結(jié)構(gòu)

大概就是在src下新建一個pages目錄,然后再文件件下新建一個單頁面運(yùn)用,每個頁面都有自己的main.js和App.vue,此外還有自己的views和router,至于通用組件components和pinia文件夾就放在pages的目錄的同級區(qū)域,截圖如下:

這里我把index文件夾具體展開了,page1里面也是類似的結(jié)構(gòu),只不過page1當(dāng)中的index.js換成了page1.js,index.vue換成了page1.vue(實(shí)際上全寫成main.js和App.vue也沒啥事,我就是手欠)。每個page的配置其實(shí)類似vue-cli生成的單頁面運(yùn)用。( 忽略一下最下面的templates,那是存放html模板的地方)

二、更改webpack的配置

兩個部分,首先我們這里有兩個page,就有兩個入口文件

entry: {
        index: path.resolve(__dirname, './src/pages/index/index.js'),
        page1: path.resolve(__dirname, './src/pages/page1/page1.js')
    },
    output: {
        path: path.resolve(__dirname, 'dist'), // 打包出口
        filename: '[name].js', // 打包完的靜態(tài)資源文件名
        clean: true,//每次打包都會刪除dist里面舊的內(nèi)容
    },

注意和上篇比較,我這里的output的filename有些更改,這些配置不是最終的,最后還有優(yōu)化一下結(jié)構(gòu)

第二個則是html模板的改變,這里的話需要創(chuàng)建兩個模板

plugins: [
        new HtmlWebpackPlugin({
            template: path.resolve(__dirname, './templates/index.html'), // 我們要使用的 html 模板地址
            filename: 'index.html', // 打包后輸出的文件名
            title: 'index頁面',
            chunks: ["index"]
        }),
        new HtmlWebpackPlugin({
            template: path.resolve(__dirname, './templates/page1.html'), // 我們要使用的 html 模板地址
            filename: 'page1.html', // 打包后輸出的文件名
            title: 'page1頁面',
            chunks: ["page1"]
        }),
        new VueLoaderPlugin() //vue-loader插件
    ],

 這里有兩個htmlwebpackplugin的插件配置,每個配置對應(yīng)了一個頁面,兩個模板我也放在了pages同級的template文件夾之中,template文件夾如下:

 里面的模版都是一樣的,如下

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>
        <%= htmlWebpackPlugin.options.title %>
    </title>
</head>
<body>
    <div id="root"></div>
</body>

 就是body里面加了個id是root的格子,方便我們vue實(shí)例的掛載

另外要注意一下,我們兩個page的vue實(shí)例是公用的一個pinia例子,我不太確定能不能用,所以的話,測試了一下,大體就是創(chuàng)建了一個userInfor的pinia模塊,寫下如下的配置

import { defineStore } from 'pinia'
export const useUserStore = defineStore('user', {
    state: () => {
        return { userName: "黃烽" }
    },
    // 也可以這樣定義
    // state: () => ({ count: 0 })
    actions: {
        changeName () {
            this.userName = "gss"
        }
    },
})

在index頁面的views的Home.vue上進(jìn)行一下展示,這個頁面還有一個按鈕,觸發(fā)之后會觸發(fā)change函數(shù),將頁面導(dǎo)向page1.html

<template>
    <div class="msg">this msg is from page index
        <span>this is from span</span><br />
        <span>{{ "userName: " + user.userName }}</span>
        <button @click="change">跳轉(zhuǎn)</button>
    </div>
</template>
<script setup>
import { onMounted } from 'vue';
import { useUserStore } from "../../../pinia/userInfor.js"
const user = useUserStore()
const testFunction = (msg) => {
    alert(msg)
}
onMounted(() => {
    testFunction("hhhh")
})
const change = () => {
    window.location.href = "./page1.html"
}
</script>
<style scoped lang="scss">
.msg {
    color: red;
    span {
        color: green;
    }
}
</style>

對應(yīng)的page1當(dāng)中的Home.vue的配置如下

<template>
    <div class="msg">this msg is from page1
        <span>this is from span</span><br />
        <span>{{ "userName: " + user.userName }}</span>
        <button @click="change">改變用戶姓名</button>
    </div>
</template>
<script setup>
import { onMounted } from 'vue';
import { useUserStore } from "../../../pinia/userInfor.js"
const user = useUserStore()
const change = () => {
    user.changeName()
}
const testFunction = (msg) => {
    alert(msg)
}
onMounted(() => {
    testFunction("hhhh")
})
</script>
<style scoped lang="scss">
.msg {
    color: red;
    span {
        color: green;
    }
}
</style>

基本上是一樣的,除了msg內(nèi)容不同之外,就是這里的change函數(shù)測試的是pinia當(dāng)中的一個mutation。

最后一步就是打開dev 服務(wù)器測試,npm run dev,然后就行了,雖然有點(diǎn)簡單,但是基本的意思是有了 ,打包之后dist文件夾里就是這個樣子

三、結(jié)尾

其實(shí)還是比較簡單的,難的還是相關(guān)的優(yōu)化,我個人對優(yōu)化還是有些模糊的,有機(jī)會寫幾個優(yōu)化的例子。

到此這篇關(guān)于webpack將vue3單頁面應(yīng)用改造成多頁面應(yīng)用的文章就介紹到這了,更多相關(guān)vue單頁面應(yīng)用改造成多頁面應(yīng)用內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 一文詳解Vue3中的setup函數(shù)的用法和原理

    一文詳解Vue3中的setup函數(shù)的用法和原理

    在 Vue3 中,setup 函數(shù)是一個新引入的概念,它代替了之前版本中的 data、computed、methods 等選項(xiàng),用于設(shè)置組件的初始狀態(tài)和邏輯,本文將主要介紹Setup的基本用法和少量原理
    2024-02-02
  • elementUI實(shí)現(xiàn)下拉選項(xiàng)加多選框的示例代碼

    elementUI實(shí)現(xiàn)下拉選項(xiàng)加多選框的示例代碼

    因產(chǎn)品需求和UI樣式調(diào)整,本文主要實(shí)現(xiàn)elementUI下拉選項(xiàng)加多選框的示例代碼,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-10-10
  • vue?模板循環(huán)繪制多行上傳文件功能實(shí)現(xiàn)

    vue?模板循環(huán)繪制多行上傳文件功能實(shí)現(xiàn)

    這篇文章主要為大家介紹了vue?模板循環(huán)繪制多行上傳文件功能實(shí)現(xiàn)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-07-07
  • 超詳細(xì)動手搭建一個VuePress 站點(diǎn)及開啟PWA與自動部署的方法

    超詳細(xì)動手搭建一個VuePress 站點(diǎn)及開啟PWA與自動部署的方法

    這篇文章主要介紹了超詳細(xì)動手搭建一個VuePress 站點(diǎn)及開啟PWA與自動部署的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-01-01
  • Vue中引入第三方JS庫的四種方式

    Vue中引入第三方JS庫的四種方式

    在開發(fā)Vue項(xiàng)目的時候,有時需要使用一些非ES6格式的沒有export的js庫,下面這篇文章主要給大家介紹了關(guān)于Vue中引入第三方JS庫的詳細(xì)步驟,需要的朋友可以參考下
    2022-04-04
  • 基于Vue自定義指令實(shí)現(xiàn)按鈕級權(quán)限控制思路詳解

    基于Vue自定義指令實(shí)現(xiàn)按鈕級權(quán)限控制思路詳解

    這篇文章主要介紹了基于vue自定義指令實(shí)現(xiàn)按鈕級權(quán)限控制,本文給大家介紹的非常詳細(xì),感興趣的朋友跟隨腳本之家小編一起學(xué)習(xí)吧
    2018-05-05
  • Vue3中級指南之如何在vite中使用svg圖標(biāo)詳解

    Vue3中級指南之如何在vite中使用svg圖標(biāo)詳解

    在以webpack為構(gòu)建工具的開發(fā)環(huán)境中我們可以很方便的實(shí)現(xiàn)SVG圖標(biāo)的組件化,下面這篇文章主要給大家介紹了關(guān)于Vue3中級指南之如何在vite中使用svg圖標(biāo)的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-04-04
  • vue實(shí)現(xiàn)頁面切換滑動效果

    vue實(shí)現(xiàn)頁面切換滑動效果

    這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)頁面切換滑動效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-06-06
  • 詳解Vue如何通過URL傳遞與獲取參數(shù)

    詳解Vue如何通過URL傳遞與獲取參數(shù)

    Vue Router 路由實(shí)際上就是一種映射關(guān)系,例如,多個選項(xiàng)卡之間的切換就可以使用路由功能來實(shí)現(xiàn),在實(shí)際的開發(fā)中,經(jīng)常需要通過URL來傳遞參數(shù),同時在 JavaScript 腳本中需要獲取URL中的參數(shù),下面將介紹 Vue 項(xiàng)目中,如何通過 URL 對參數(shù)進(jìn)行傳遞與獲取,需要的朋友可以參考下
    2024-09-09
  • vue3學(xué)習(xí)筆記之自定義組件舉例

    vue3學(xué)習(xí)筆記之自定義組件舉例

    這篇文章主要給大家介紹了關(guān)于vue3學(xué)習(xí)筆記之自定義組件的相關(guān)資料,組件系統(tǒng)是Vue.js其中一個重要的概念,它提供了一種抽象,讓我們可以使用獨(dú)立可復(fù)用的小組件來構(gòu)建大型應(yīng)用,需要的朋友可以參考下
    2023-08-08

最新評論