• vue--配置根目录(用@代表src目录)


    原文网址:vue--配置根目录(用@代表src目录)_IT利刃出鞘的博客-CSDN博客

    简介

            本文介绍vue如何配置根目录(用@代表src目录)。

            默认情况下是不能用@代替/src的,需要经过配置才可以。

    根目录的用法

    在Vue中的JS里使用

            vue通常会用@来代表项目的src目录。这样一来,输入路径时就不用输入/src了,可以直接用@来替换。

            例如:有一个vue文件,路径为:/src/layout/index.vue,如下图所示:

    如果直接导入,则代码应该这么写:

    import Layout from '/src/layout'

    如果使用@来替换,就更简洁了:

    import Layout from '@/layout'
    

    在Vue文件的CSS里使用

    可以这样使用:

    1. <div class="login-center-left">
    2. <h2><img src="@/assets/logo.png" />{{ title }}</h2>
    3. </div>

    注意

            vue文件里style的css中不能使用@来获取路径,CSS loader 会把把非根路径的url解释为相对路径。

    解决方案:加~前缀(~@代表根路径) 。即:加~前缀才会解释成模块路径

    例如:

    background: rgb(73, 123, 199) url("~@/assets/login-bg.png") left center

    vue cli3及之后的配置

    步骤1:配置jsconfig.js

    位置:项目根目录/jsconfig.js

    1. {
    2. "compilerOptions": {
    3. "baseUrl": "./",
    4. "paths": {
    5. "@/*": ["src/*"]
    6. }
    7. },
    8. // @ 不能在以下目录的文件中使用
    9. "exclude": ["node_modules", "dist"]
    10. }

    步骤2:配置vue.config.js

    位置:项目根目录/vue.config.js

    法1:配置chainWebpack

    1. 'use strict'
    2. const path = require('path')
    3. const resolve = dir => path.join(__dirname, dir)
    4. module.exports = {
    5. chainWebpack: config => {
    6. config.resolve.alias
    7. .set('@', resolve('src'))
    8. }
    9. }

    法2:配置configureWebpack

    1. 'use strict'
    2. const path = require('path')
    3. const resolve = dir => path.join(__dirname, dir)
    4. module.exports = {
    5. configureWebpack: {
    6. name: 'vue Element Admin',
    7. resolve: {
    8. alias: {
    9. '@': resolve('src')
    10. }
    11. }
    12. }
    13. }

    vue cli2的配置

    webpack.base.conf(位置:项目根目录/config/webpack.base.conf)

    1. resolve: {
    2. extensions: ['.js', '.vue', '.json'],
    3. alias: {
    4. 'vue$': 'vue/dist/vue.esm.js',
    5. '@': resolve('src'),
    6. '#'resolve('statis')
    7. }
    8. }

  • 相关阅读:
    JAVA经典百题之计算商和余数
    【ES专题】ElasticSearch功能详解与原理剖析
    白话谈区块链和其应用场景
    如何设计科研问卷?
    七夕节,我用代码制作了表白信封
    牛亚男:基于多Domain多任务学习框架和Transformer,搭建快精排模型
    附下载,《数据传输安全白皮书》上新,90页详解安全策略
    1.1.7 CentOS 部署Docker环境
    MyBatis一对多关联查询
    Kafka JNDI 注入分析(CVE-2023-25194)
  • 原文地址:https://blog.csdn.net/feiying0canglang/article/details/125463222