webpack处理js和css模块化导入导出示例:

webpack默认并不能处理js模块化的导入和导出,依赖于ts-loader和babel-loader

javascript 复制代码
webpack.config,js
module.exports = {
    entry: './src/index.ts',
    output: {
        filename: 'main.js',
    },
    mode: 'development', // 或者 'production'
    module: {
        rules: [
            {
                test: /\.ts/,
                exclude: /(node_modules)/,
                use: 'ts-loader'
            }
    ]
    },
    resolve: {
        // 确保webpack可以找到.ts和.tsx文件
        extensions: ['.tsx', '.ts', '.js']
    }
}
javascript 复制代码
src/index.ts
import {util} from './b'

let zhang: string = util()

zhang += 'zhang'

src/a.ts
export const util = () => {
    return 'util'
}

webpack默认并不能处理css模块化的导入和导出,依赖于css-loader

javascript 复制代码
webpack.config.js
module.exports = {
    entry: './src/index.js',
    output: {
        filename: 'main.js',
    },
    mode: 'development', // 或者 'production'
    module: {
        rules: [
            {
                test: /\.css/,
                exclude: /(node_modules)/,
                use: ['style-loader', 'css-loader']
            }
    ]
    },
}
javascript 复制代码
src/index.js
import './style.css'

src/style.css
@import './module.css';
.body div {
  background-color: red;
}


src/module.css
body {
    font-size: 28px;
}
相关推荐
dlnu20152506223 分钟前
ssr实现方案
前端·javascript·ssr
轻口味2 小时前
命名空间与模块化概述
开发语言·前端·javascript
前端小小王2 小时前
React Hooks
前端·javascript·react.js
迷途小码农零零发2 小时前
react中使用ResizeObserver来观察元素的size变化
前端·javascript·react.js
娃哈哈哈哈呀3 小时前
vue中的css深度选择器v-deep 配合!important
前端·css·vue.js
sunshine6415 小时前
【CSS】实现tag选中对钩样式
前端·css·css3
真滴book理喻6 小时前
Vue(四)
前端·javascript·vue.js
程序员_三木6 小时前
Three.js入门-Raycaster鼠标拾取详解与应用
开发语言·javascript·计算机外设·webgl·three.js
开心工作室_kaic7 小时前
springboot476基于vue篮球联盟管理系统(论文+源码)_kaic
前端·javascript·vue.js