【React】dva-cli建立脚手架后发现页面样式不对的问题

用dva-cli作为脚手架建立工程后,开始尝试编写页面。然后立马发现一个坑爹的问题。

在我less文件里面写了一个class ,比如:MainHead。

但是编译出来之后发现css文件里面变成了 MainHead__xuaz,多了一个后缀,坑爹嘛这是!!!

一番查找后发现原来是引用了css-modules这个包。

为了卸载这个包,我翻找了半天。照例来说应该在webpack的时候屏蔽这个包。

可惜node项目不知道说封装了太好了还是怎么的,dva生成的脚手架里面根本就没有webpack.config.js这个包。

终于,在我的不懈努力下终于发现问题的主因了。

原因就在于dva是用一个叫rodhog的工具打包的。

在root目录下,有一个叫.roadhogrc的配置文件。

打开这个文件,里面有一个【disableCSSModules】的配置项。默认是false,启动css-modules,只要将它改成true,就可以屏蔽掉css-modules了。

 

-----------------------------------------------------------------一年后的分割线--------------------------------------------------------------------------------------------------

因为项目时间关系,转而使用相对简单易懂的Vue来开发项目。

吭哧吭哧整了一年终于将项目完结,重新拾起React后,发现自己犯了一个很基础的错误。

 

react里使用css-modules是正确的。目的是防止组件间的css名称污染。

而react中调用less中的class时,应该使用className,这样编译的时候能保证组件中的class名和less中的class名保持一致。

 

如此粗浅而深刻的教训实在是令人惭愧。同时也证明入门的时候要找本好的入门教程,先看书再看代码,好过直接上手代码。

猜你喜欢

转载自blog.csdn.net/qq_40963664/article/details/80833700