New Case Study:See how Anthropic automated 95% of dependency reviews with Socket.Learn More
Socket
Sign inDemoInstall
Socket

akfun

Package Overview
Dependencies
Maintainers
1
Versions
138
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

akfun

前端脚手架:支持Vue技术站和react技术栈

  • 1.3.5
  • npm
  • Socket score

Version published
Weekly downloads
104
increased by100%
Maintainers
1
Weekly downloads
 
Created
Source

AKFun 前端脚手架

AKFun 是一个基于 Webpack4.0 的打包工具,支持多种技术栈:Vue技术栈、React技术栈、React&TS技术栈(开发中)

  • 技术栈:node/webpack4.0/express/babel/eslint/stylelint

特性

  • ⚡️ 零配置,开箱即用
  • 👏 支持Vue和React项目的构建
  • 📤 支持单页面和多页面
  • 💪 提供三种构建场景: 本地开发调试模式(包含热更新、接口代理等功能)、构建生产环境代码、library库的构建(以umd进行输出)
  • ❤️ 开放配置能力: 可配置构建入口文件、是否开启ESLint代码规范检测、resolve和externals配置、接口代理配置等
  • 👍 支持 SassESLintStyleLintparams-replace-loader
  • 😀 提供完整的Vue和React项目模板

快速开始 / 使用方法一

全局安装AKFun,用于同时管理多个前端项目代码(可使用AKFun创建一个新项目)

  1. 全局安装
$ npm i -g akfun 或者 yarn add akfun global
  1. 初始化一个项目

可选择项目类型:vue或者react,默认react类型的项目,也可通过--dir参数指定存放项目模板的目录

$ akfun init -t=vue
  1. 开始使用:以全局命令方式构建项目(确保已yarn install或者npm install)
# 1、开启本地调试模式
$ akfun dev
# 2、构建生产环境代码
$ akfun build
# 3、构建第三方功能包
$ akfun build2lib

快速开始 / 使用方法二

在现有项目中局部安装AKFun,给现有项目赋予AKFun的前端工程能力

  1. 本地安装
$ npm i akfun --save-dev 或者 yarn add akfun --dev
  1. 在package.json中创建可执行脚本

打开package.json,在scripts中新增三条可执行命令

# 用于开启本地调试模式
"dev": "akfun dev"
# 用于构建生产环境代码
"build": "akfun build"
# 用于构建第三方功能包
"build2lib": "akfun build2lib"
  1. 开始构建当前项目

    3.1 开启本地调试模式

    $ npm run dev
    

    3.2 构建生产环境代码

    $ npm run build
    

    3.3 构建第三方功能包

    $ npm run build2lib
    

AKFun使用说明

  1. 使用AKFun新建一个新项目

    1.1 创建一个react项目

    $ akfun init
    

    1.2 创建一个vue类型项目

    $ akfun init -t=vue
    

    1.3 在指定的目录中创建一个新项目

    $ akfun init -t=vue --dir=myTest1
    
  2. 创建AKFun的配置文件

    $ akfun config init
    
  3. 关于AKFun提供三种构建场景

    1. dev: 本地开发调试模式,用于本地开发和调试项目(包含热更新、接口代理等功能),编译的代码没有压缩,默认会开启ESLint检测代码规范(可关闭)
    2. build: 用于构建生产环境代码,编译输出的代码会进行压缩优化
    3. build2lib: 用于构建library库,目前统一以umd进行输出
  4. 关于AKFun的配置文件

    1. AKFun会提供全量的默认配置,实现零配置、开箱即用的能力
    2. 自定义构建配置,请在当前项目根目录创建AKFun配置文件(akfun.config.js),AKFun提供初始化配置文件的方法:
    $ akfun config init
    
    1. akfun.config.js为当前项目的配置文件,优先级最高(可覆盖AKFun提供的默认配置)
  5. 配置构建入口文件(webpack.entry)

    1. 默认的构建入口文件: ./src/index.js
    2. 自定义构建入口(akfun.config.js中提供对应的配置入口)
      1. 在webpack.entry配置构建入口,dev\build\build2lib都会以此为构建入口 (关于entry的配置方法)
      2. 在dev.entry、build.entry、build2lib.entry中配置对应执行环境的构建入口,优先级高于webpack.entry
  6. 关于多页面

    1. 当akfun.config.js的entry只有一个入口配置,且对应的构建入口文件不存在时,AKFun会自动从src/pages中获取构建入口(支持多页面多模板)
    2. 多页面模式下,会自动将src/pages中以.ts、.tsx、.js、.jsx结尾(对应的匹配正则:/.[tj]sx?$/)的文件作为构建入口文件
  7. 关于多页面多模板

    1. 只有dev和build的构建过程中才会使用到页面模板,build2lib构建中不会将打包完成的代码输出到页面模板中
    2. 默认使用./src/index.html作为页面模板
    3. 当项目中./src/index.html不存在时,会使用AKFun的提供的默认页面模板
    4. 多页面模式时,如果pages下存在对应的html页面(与入口文件同名的html文件),会自动将其设置为页面模板

AKFun开放的配置能力

AKFun配置文件(akfun.config.js),以下使用AKFunConfig代表akfun.config.js配置对象

  1. 开启/关闭 ESLint代码规范检测: AKFunConfig.settings.enableEslint
module.exports = {
  settings: {
    enableEslint: true,
  },
  ...
}
  1. 配置构建入口文件: 关于配置优先级请查看 AKFun使用说明 / 配置构建入口文件

以下是entry的配置位置,具体配置方法请查看Webpack官网 (关于entry的配置方法) 备注:建议以key/value形式(object { : string | [string] })配置entry

module.exports = {
  ...
  webpack: {
    entry: {
      index: './src/index.js',
    }
  },
  ...
  dev: {
    entry: {}
  }
  build: {
    entry: {}
  }
  build2lib: {
    entry: {}
  }
  ...
}
  1. 解析(resolve) / extensions配置: 自动解析确定的扩展(配置可识别的文件后缀)

以下是extensions的配置位置,具体配置方法请查看Webpack官网 (关于resolve-extensions的配置方法)

module.exports = {
  ...
  webpack: {
    resolve: {
        extensions: ['.js', '.jsx', '.vue', 'json'],
    }
  },
  ...
}
  1. 解析(resolve) / alias配置: 创建 import 或 require 的别名,来确保模块引入变得更简单

以下是alias的配置位置,具体配置方法请查看Webpack官网 (关于resolve-alias的配置方法)

module.exports = {
  ...
  webpack: {
    resolve: {
        alias: {},
    }
  },
  ...
}
  1. 页面模板路径配置:关于页面模板请查看 AKFun使用说明 / 关于页面模板
module.exports = {
  ...
  webpack: {
    template: '',
  }
  ...
}
  1. 注入公共的SASS文件

为项目中每个.scss后缀的样式文件注入公共的SASS内容(变量、mixin、function等)

module.exports = {
  ...
  webpack: {
    sassResources: [],
  }
  ...
}
  1. 项目源码环境变量批量替换

关于params-replace-loader的使用方法

module.exports = {
  ...
  envParams: {
    common: { // 通用参数
      '#version#': '20200810.1',
    },
    local: { // 本地开发环境
      '#dataApiBase#': 'http://localhost:1024', // 数据接口根地址
      '#assetsPublicPath#': 'http://localhost:1024', // 静态资源根地址
      '#routeBasePath#': '/', // 路由根地址
    },
  }
  ...
}
  1. 接口代理配置:目前只有dev本地开发调试模式下会启动

关于proxyTable的配置方法

module.exports = {
  ...
  dev: {
    proxyTable: {
    },
  }
  ...
}

8、用于开启本地调试模式的相关配置信息

module.exports = {
  ...
    dev: {
      NODE_ENV: 'development', // development 模式,不会启动UglifyJsPlugin服务
      port: 80, // 启动server服务的端口
      autoOpenBrowser: true, // 是否自动打开页面
      assetsPublicPath: '/', // 设置静态资源的引用路径(根域名+路径)
      assetsSubDirectory: '', // 资源引用二级路径
      hostname: 'localhost', // 自动打开的页面主机
      proxyTable: { // 接口代理
        '/apiTest': {
          target: 'http://api-test.com.cn', // 不支持跨域的接口根地址
          ws: true,
          changeOrigin: true
        }
      },
      cssSourceMap: false,
    },
  ...
}

9、用于构建生产环境代码的相关配置信息

module.exports = {
  ...
    build: {
      NODE_ENV: 'production', // production 模式,会启动UglifyJsPlugin服务
      assetsRoot: resolve('./dist'), // 打包后的文件绝对路径(物理路径)
      assetsPublicPath: '/', // 设置静态资源的引用路径(根域名+路径)
      assetsSubDirectory: '', // 资源引用二级路径
      productionSourceMap: false, // 是否显示原始源代码
      productionGzip: false, // 是否开启Gzip服务
      productionGzipExtensions: ['js', 'css', 'json'], // Gzip识别的文件后缀
      bundleAnalyzerReport: false, // 开启打包分析功能
    }
  ...
}

10、用于构建第三方功能包的配置

module.exports = {
  ...
    build2lib: {
      NODE_ENV: 'production', // production 模式,会启动UglifyJsPlugin服务
      libraryName: '', // 构建第三方功能包时最后导出的引用变量名
      assetsRoot: resolve('dist'), // 编译完成的文件存放路径
      assetsPublicPath: '/', // 设置静态资源的引用路径(根域名+路径)
      assetsSubDirectory: '', // 资源引用二级路径
      productionSourceMap: false, // 是否显示原始源代码
      productionGzip: false, // 是否开启Gzip服务
      productionGzipExtensions: ['js', 'css', 'json'], // Gzip识别的文件后缀
      bundleAnalyzerReport: false, // 开启打包分析功能
    },
  ...
}

Keywords

FAQs

Package last updated on 14 Aug 2020

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc