我在一个网站上工作,使用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的一些东西(也许是一个设置?)


当前回答

当我把它移动到localhost和PhpStorm时,我在一个网站上遇到了这个问题。

这在网上效果很好:

<link rel="stylesheet" href="/css/additional.css">

但是对于localhost,我需要去掉斜杠:

<link rel="stylesheet" href="css/additional.css">

所以我在这里强调一些已经提供的答案-这可能是一个路径或拼写错误,而不是任何复杂的服务器设置问题。控制台中的错误是转移注意力的东西;首先需要检查网络选项卡是否有404错误。

在这里提供的答案中,有一些解决方案是不正确的。添加type="text/html"或将href更改为src都不是答案。

如果你想拥有所有的属性,所以它在最敏感的验证器和你的IDE上进行验证,那么应该提供媒体值,并且rel应该是样式表,例如:

<link rel="stylesheet" href="css/additional.css" type="text/css" media="all">

其他回答

我几乎尝试了所有已知的解。对我来说,问题是我在IIS中没有任何MIME类型选项,也就是说,我错过了这个Windows功能。

我的解决方案是:

如果你使用的是非服务器操作系统,如Windows 8或10,在开始页面上搜索“打开或关闭Windows功能”并启用:Internet信息服务->万维网服务->通用HTTP功能->静态内容”

启用IIS静态内容

请检查你的文件名是否有错别字。这发生在我身上:

style.css.css

进入我的浏览器控制台→网络→样式。css…点击它,它显示“cannot get /path/to/my/CSS”,这告诉我我的链接是错误的。 我把它改成了CSS文件的路径。

更改前的原始路径为localhost:3000/Example/public/style.css。将其更改为localhost:3000/style.css解决了这个问题。

如果你从app.use(express.static(path. use)提供文件。加入(__dirname,“公共”)));或app.use (express.static(“公共”);你的服务器会把“那个文件夹”传递给浏览器,所以在浏览器中添加一个“/yourCssName.css”链接就能解决这个问题

通过在浏览器的CSS链接中添加其他路由,你会告诉浏览器在指定的路由中搜索CSS。

总之:检查您的浏览器CSS链接指向哪里。

我遇到了同样的问题,然后我检查了一下我写的是:

<基地href = "。index.html中的>

然后我改成了

<base href="/">

然后它运行得很好。

在我的情况下,我必须确保链接是相对的,rel属性是在href属性之后:

<link href="/assets/styles/iframe.css" rel="stylesheet">