正式学习react(二)[通俗易懂]

正式学习react(二)

大家好,又见面了,我是全栈君。

 

 

 

今天把上一篇还没学习完的 webpack部分学习完:

之前有说过关于css的webpack使用。我们讲了 

ExtractTextPlugin 来单独管理css

讲了module.loaders下关于 css的写法:
module: {
  
  
loaders: [
// Extract CSS during build
{
test: /\.css$/,
loader: ExtractTextPlugin.extract('style', 'css'),
include: paths
}
]
},

还讲了关于css?modules这个query 的作用,下面我们开始要用到Babel and babel-loader 来支持es6了!
默认大家都熟悉下面几种模块管理方式:

CommonJS

正式学习react(二)[通俗易懂]

ES6

正式学习react(二)[通俗易懂]

 

 

AMD

 正式学习react(二)[通俗易懂]

正式学习react(二)[通俗易懂]

 

 

 上面所有的格式规范,webpack都支持.

————————————————————————————————————–

 现在讲一下loader的定义:

 

正式学习react(二)[通俗易懂]

loader (接收 字符串)

loaders  (接收 数组) 

 

上面的都是数组,所以都写的是loaders.

 

 

 webpack的loader 是讲顺序的,一定记住是从右往左,从右往左,从右往左。重要的事情说三遍!

 

loaders: ['style', 'css'] 就相对于 style(css(input)) ,两者没有差别。

—————————————————————————————————————————

说完顺序,再说参数,还记得之前说的modules吗?

 

Passing Parameters to a Loader

{ test: /\.jsx?$/,

   loaders: [ ‘babel?cacheDirectory,presets[]=react,presets[]=es2015’ ],

   include: PATHS.app

}

我们之前都是这样写的,但是这样阅读性比较差,我们推荐这样的写法:

 

{ test: /\.jsx?$/,

   loader: ‘babel’,

   query: { cacheDirectory: true,

                presets: [‘react’, ‘es2015’] },

   include: PATHS.app

}

 

 

还有,我之前也推荐过 用include:这个key, 他接受string 也可以接收Array;

————————————————————————————————————————————————————–

我之前介绍过ExtractTextPlugin 这个插件,来讲css文件 output 到你的build里。

—————————————————————————————————————————————————————

Loading CSS

  It parses the styles in the given include path (accepts an array too) while making sure only files ending with .css are matched.

The definition then applies both style-loader and css-loader on it:

大意就是说 你写了include,在你的module.loaders下。那webpack就只从这个文件下找.css 结尾的文件,匹配到就用style-loader 和 css-loader 来操作这些css文件。

 

正式学习react(二)[通俗易懂]

 整个过程就是Webpack会判断这些文件,然后在匹配到的文件里将 @import 和 url()声明的字段,转化成require字段,然后就是用到style-loader了,

 下面我们还会介绍 file-loader or url-loader.

 

PS:如果你想确保CSS也能运用sourcemaps 。你可以使用[‘style’, ‘css?sourceMap’]

并且设置output.publicPath为绝对路径。

 

当然,我们可能在项目里用了less,sass。

 less-loader

 

  正式学习react(二)[通俗易懂]

 

 node-sass 

正式学习react(二)[通俗易懂]

 

你们的 LESS/SASS文件里可以使用import:

正式学习react(二)[通俗易懂]

 

也可以直接从node_modules文件夹里加载

 正式学习react(二)[通俗易懂]

还有一些自己去了解。

 —————————————————————————————————

导致我们的项目变慢,很可能是因为我们需要加载很多小资源。毕竟每个请求附带了一个开销。

HTTP / 2将帮助在这方面和改变现状。

 

Webpack 是允许在你的代码里内联加载资源的,不过要使用url-loader这个加载器。他会把图片

翻译成BASE64在你的JavaScript bundles。

 ———————————————————————————————–

Setting Up url-loader

做开发的时候,我们使用url-loader 是不错的选择。因为你可能并不关心生成包的大小。

它有一个限制选项,在达到一定的限制条件以后被使用(延迟image到file-loader)。


具体的说就是,url-loader 是将一些url()里需要下载的资源,下载下来!然后用BASE64编码

内联到我们bundles的js文件里。可以减少开销。但是如果文件太大,我们可能等不了。

我们就让他在浏览器里加载。这就是limit的作用。

正式学习react(二)[通俗易懂]

就这样小于25k的图片将直接以base64的形式内联在代码中,可以减少一次http请求。

 style.js

正式学习react(二)[通俗易懂]

 

webpack.config.js

正式学习react(二)[通俗易懂]

 

 

运行webpack后:

正式学习react(二)[通俗易懂]

 

 

—————————————————————————–

Setting Up file-loader

url-loader是对file-loader的上层封装,如果你忽略内联url,我们可以直接使用 file-loader

正式学习react(二)[通俗易懂]

 

The following setup customizes the resulting filename. By default file-loaderreturns the MD5 hash of the file’s contents with the original extension:

开发者可以根据自己的需求自己定制文件名,默认 file-loader 会返回一个内容是MD5散列的原始扩展文件。

不过这里我自己定义了文件名,打包处理后:

正式学习react(二)[通俗易懂]

 

关于打包 svg , 压缩图片等loader,大家有兴趣自己去了解。

 ———————————————————————————————————————————————————————-

 我们的website也经常需要用到各种字体:最后介绍一下字体的打包:

依靠file-loader或者url-loader 都可以实现字体打包,最简单的方式:

正式学习react(二)[通俗易懂]

 

 想弄的好一点:

正式学习react(二)[通俗易懂]

 

 

 有时候为了权衡网站的性能与美观,我们可能会放弃内联方式【增加request】,直接选择打包,而且打包好多种字体样式:

正式学习react(二)[通俗易懂]

 

 

—————————————————————————————到此为止,webpack基本内容介绍,最后一篇会介绍webpack一下原理——————————-

 

转载于:https://www.cnblogs.com/huenchao/p/6074888.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/108773.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Linux Oracle 创建用户

    Linux Oracle 创建用户1、启动Oracle(Oracle没启动的情况下)su-oracle,切换成oracle用户lsnrctlstartsqlplus/nologconn/assysdbastartup(若数据库处于启动状态,则无需再次启动)2、查询临时表空间和表空间的存储位置selectnamefromv$tempfile;selectnamefromv$datafile从结果可以看出有…

    2022年5月12日
    55
  • 密码攻略 黑客亲手打造QQ密码激活成功教程器(转)

    密码攻略 黑客亲手打造QQ密码激活成功教程器(转)密码攻略黑客亲手打造QQ密码激活成功教程器(转)[@more@]现在使用QQ的网友越来越多了。可是如果密码忘记了或嫌输入QQ密码过于麻烦,那怎么办呢。我们可以自己制作一款QQ密码器。如果你感兴趣的话。可以和我一起自己动手做一个这样的Q…

    2022年7月20日
    25
  • 学习Java分为几个阶段?

    学习Java分为几个阶段?学习Java分为几个阶段?

    2022年4月22日
    50
  • 软件工程项目_软件工程对象模型图

    软件工程项目_软件工程对象模型图软件工程中应用的几种图辨析:系统流程图、数据流图、数据字典、实体联系图、状态转换图、层次方框图、Warnier图、IPO图、层次图、HIPO图、结构图、程序流程图、盒图、PAD图、判定表、判定树、Jackson图、流图、甘特图、工程网络图我们先将这几种图按照软件工程中的阶段分类~接下来看一下这些图都长什么样子~1.系统流程图2.数据流图3.数据字典4.E-R图5.状态转换图:6…

    2022年8月13日
    5
  • 使用ParameterizedThreadStart委托向线程函数传送参数「建议收藏」

    使用ParameterizedThreadStart委托向线程函数传送参数「建议收藏」在不传递参数情况下,一般大家都使用ThreadStart代理来连接执行函数,ThreadStart委托接收的函数不能有参数,也不能有返回值。如果希望传递参数给执行函数,则可以使用带参数的ParameterizedThreadStart委托,     publicdelegatevoidParameterizedThreadStart(Objectobj)可以将要传送给

    2022年7月15日
    20
  • 几种测试技术

    几种测试技术一、单元测试技术1.定义:单元测试又称为模块测试(程序测试),即集中力量来检验软件设计的最小单位——模块。       单元测试(unittesting),是指对软件中的最小可测试单元进行检查和验证。2.目的:单元测试的目的在于发现各模块内部可能存在的各种差错。3.内容/任务:    (1)模块接口测试(单元测试的基础):当模块通过外部设备进行输入/输出…

    2022年9月18日
    1

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号