我在一个网站上工作,使用Gulp.js来编译和浏览器同步,以保持浏览器与我的更改同步。

Gulp.js任务正确地编译了所有内容,但在网站上,我无法看到任何样式,控制台显示以下错误消息:

拒绝应用样式 “http://localhost:3000/assets/styles/custom-style.css”,因为它 MIME类型('text/html')不是受支持的样式表MIME类型,并且 启用严格的MIME检查。

我真的不明白为什么会这样。

HTML包含如下文件(我很确定这是正确的):

<link rel="stylesheet" type="text/css" href="assets/styles/custom-style.css"/>

现在样式表是Bootstrap和Font Awesome样式的合并(还没有自定义)。

路径也是正确的,因为这是文件夹结构:

index.html
assets
|-styles
  |-custom-style.css

但是我总是得到错误。

会是什么呢?这是gulp/browsersync的一些东西(也许是一个设置?)


当前回答

我知道这可能是脱离了上下文,但链接一个不存在的文件可能会导致这个问题,因为它发生在我之前。

<!-- bootstrap grid -->
<link rel="stylesheet" href="./css/bootstrap-grid.css" />

如果这个文件不存在,您将面临这个问题。

其他回答

我也遇到了同样的问题,经过几个小时的调试后,我发现这与无法写入临时文件有关。

进入“管理→配置→文件系统”。设置正确的临时目录。确保您的服务器有权限写入该目录。

错的是道路。

我的道路是

href="public/css/style.css".  <!-- But it should be href="public/style.css" -->

但这并没有起作用。我试了所有其他的方法,但还是不管用。所以我复制了相对路径,将反斜杠改为正斜杠,然后它就开始工作了。

如果你不确定路径,右键单击style.css文件,单击“复制相对路径”,然后将其粘贴到

  href="public\style.css"

你只需要把反斜杠改成正斜杠。

  href="public/style.css"

如果你正在使用Express.js而没有任何JavaScript代码,请尝试使用:

app.use(express.static('public'));

例如,我的CSS文件在public/stylesheets/app.css。

该问题的主要原因之一是它试图加载的CSS文件不是有效的CSS文件。

原因:

无效的MIME类型 在样式表中包含JavaScript代码(可能是由于不正确的Webpack捆绑器配置造成的)

检查您正在尝试加载的文件是否是一个有效的CSS样式表(从network选项卡获取文件的服务器URL,并点击一个新选项卡并验证)。

在body标签中使用<link>时的有用信息。

虽然在正文中有一个链接标签并不是使用标签的标准方式。但是我们可以将它用于页面优化(更多信息:优化CSS交付)/如果业务用例需要(当您提供内容主体和服务器配置为必须呈现提供内容的HTML页面时)。

在保持在body标签内的同时,我们必须在link标签中添加itemProperty属性

<body>
    <!-- … -->
      <link itemprop="url" href="http://en.wikipedia.org/wiki/The_Catcher_in_the_Rye" />
    <!-- … -->
</body>

有关itemProperty的更多信息,请参阅能否在HTML文档正文中使用<link>标记?。

问题是,如果你有一个相对路径,你导航到一个嵌套的页面,这将解析到错误的路径:

<link rel="stylesheet" href='./index.css'>

所以最简单的解决办法就是去除。因为我的应用程序是单页的。

是这样的:

<link rel="stylesheet" href='/index.css'>

所以它总是解析为/index。css

这个问题有很多答案,但似乎没有一个真正有效。如果你删除rel="stylesheet",它将停止错误,但不会应用样式表。

真正的解决方案:

只要把…这样就行了。