本文讲解了使用taro+nutui3构建微信小程序,并对组件实现按需引入的流程

在刚开始尝试的时候,一直下载的都是taro的最新版本,导致没法对组件进行按需引入,或者一些奇奇怪怪的问题。

1. 安装taro

通过cmd进入终端 

npm install -g @tarojs/cli@3.5.6    //下载3.5.6版本  可以通过taro--version验证

2.搭建项目

接下来 在磁盘创建一个文件夹 命名为myTaroApp 

点击进入此文件夹 执行cmd 进入终端

然后执行taro init myApp

这里选择vue3+ts+nutui3+sass预处理语言来构建项目

这样项目就初始化完成了

在进入项目的目录后,我们可能会发现一些问题,比如tsconfig.json文件可能会有爆红提示,

这边已经准备好了解决的办法

先执行yarn add @types/sass@1.43.1 --save-dev  安装稳定版本

再在tsconfig.json文件中 的对象里面加入
 { "types": ["sass"] }  
就可以解决这个问题啦

3.拓展

如需使用 css modules 功能,找到config文件夹下的index.js文件,将mini对象里面的enable设置为true

4.路径别名的配置

仍然config文件夹下的index.js文件中配置 这里直接附上代码 方便观看x

const path = require('path');

const config = {
  projectName: 'myApp',
  date: '2024-2-5',
  designWidth: 375,
  deviceRatio: {
    640: 2.34 / 2,
    750: 1,
    828: 1.81 / 2,
    375: 2 / 1
  },
  sourceRoot: 'src',
  outputRoot: 'dist',
  plugins: ['@tarojs/plugin-html','taro-plugin-pinia'],
  defineConstants: {
  },
  copy: {
    patterns: [
    ],
    options: {
    }
  },
  framework: 'vue3',
  compiler: 'webpack5',
  cache: {
    enable: false // Webpack 持久化缓存配置,建议开启。默认配置请参考:https://docs.taro.zone/docs/config-detail#cache
  },
  sass:{
    data: `@import "@nutui/nutui-taro/dist/styles/variables.scss";`
  },
  mini: {
    postcss: {
      pxtransform: {
        enable: true,
        config: {
          selectorBlackList: ['nut-']
        }
      },
      url: {
        enable: true,
        config: {
          limit: 1024 // 设定转换尺寸上限
        }
      },
      cssModules: {
        enable: true, // 默认为 false,如需使用 css modules 功能,则设为 true
        config: {
          namingPattern: 'module', // 转换模式,取值为 global/module
          generateScopedName: '[name]__[local]___[hash:base64:5]'
        }
      }
    },
    alias: {
      '@/assests': path.resolve(__dirname, '..', 'src/assests'),
      '@/pages': path.resolve(__dirname, '..', 'src/pages'),
      '@/http': path.resolve(__dirname, '..', 'src/http'),    
      '@/store': path.resolve(__dirname, '..', 'src/store'),
      '@/api': path.resolve(__dirname, '..', 'src/api'), 
    },
  },
  h5: {
    publicPath: '/',
    staticDirectory: 'static',
    esnextModules: ['nutui-taro'],
    postcss: {
      autoprefixer: {
        enable: true,
        config: {
        }
      },
      cssModules: {
        enable: false, // 默认为 false,如需使用 css modules 功能,则设为 true
        config: {
          namingPattern: 'module', // 转换模式,取值为 global/module
          generateScopedName: '[name]__[local]___[hash:base64:5]'
        }
      }
    }
  }
}

module.exports = function (merge) {
  if (process.env.NODE_ENV === 'development') {
    return merge({}, config, require('./dev'))
  }
  return merge({}, config, require('./prod'))
}

 这里先const path = require('path') 引入路径

然后在mini对面里面加上ailas对象去配置对应的路径  下方图片是我的文件目录

最后一步 需要在tsconfig.ts文件进行配置

{
  "compilerOptions": {
    "target": "es2017",
    "module": "commonjs",
    "removeComments": false,
    "preserveConstEnums": true,
    "moduleResolution": "node",
    "experimentalDecorators": true,
    "noImplicitAny": false,
    "allowSyntheticDefaultImports": true,
    "outDir": "lib",
    "noUnusedLocals": true,
    "noUnusedParameters": true,
    "strictNullChecks": true,
    "sourceMap": true,
    "baseUrl": ".",
    "rootDir": ".",
    "jsx": "preserve",
    "allowJs": true,
    "resolveJsonModule": true,
    "typeRoots": ["node_modules/@types"],
    "paths": {
      "@/*": ["./src/*"],
      "@/http/*": ["./src/http/*"],
      "@/pages/*": ["./src/pages/*"],
      "@/assests/*": ["./src/assests/*"],
      "@/store/*": ["./src/store/*"],
      "@/api/*": ["./src/api/*"],
    }
  },
  "include": ["./src", "./types"],
  "compileOnSave": false,
  "types": ["sass"],
}

配置完成后即可使用了,欢迎补充

GitHub 加速计划 / vu / vue
207.55 K
33.66 K
下载
vuejs/vue: 是一个用于构建用户界面的 JavaScript 框架,具有简洁的语法和丰富的组件库,可以用于开发单页面应用程序和多页面应用程序。
最近提交(Master分支:3 个月前 )
73486cb5 * chore: fix link broken Signed-off-by: snoppy <michaleli@foxmail.com> * Update packages/template-compiler/README.md [skip ci] --------- Signed-off-by: snoppy <michaleli@foxmail.com> Co-authored-by: Eduardo San Martin Morote <posva@users.noreply.github.com> 5 个月前
e428d891 Updated Browser Compatibility reference. The previous currently returns HTTP 404. 5 个月前
Logo

旨在为数千万中国开发者提供一个无缝且高效的云端环境,以支持学习、使用和贡献开源项目。

更多推荐