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


您可以打开谷歌Chrome工具,选择网络选项卡,重新加载您的页面,找到CSS的文件请求,并寻找它在文件中有什么。

也许你在合并文件中的两个库时做错了什么,包括一些不适合CSS的字符或头文件?


我认为,问题在于CSS库从注释开始。

在开发过程中,我没有缩小文件,也没有删除注释。这意味着样式表以一些注释开始,导致它被视为与CSS不同的东西。

删除库并将其放入供应商文件(该文件总是最小化,没有注释)解决了这个问题。

同样,我不能100%确定这是一个修复,但它仍然是我的胜利,因为它的工作正如预期的现在。


对于Node.js应用程序,检查你的配置:

app.use(express.static(__dirname + '/public'));

注意/public在结尾没有正斜杠,所以你需要在HTML的href选项中包含它:

href="/css/style.css">

如果你确实包含了一个正斜杠(/public/),那么你可以只做href="css/style.css"。


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

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

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

是这样的:

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

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

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

真正的解决方案:

只要把…这样就行了。


对于Node.js应用程序,只需在服务器文件中导入所有必需的模块后使用:

app.use(express.static("."));

表达。<link rel="stylesheet" href="style.css">


按照Angular的结构,在style.css文件的下面/上面创建一个文件夹,并提供一个链接,如<link href="vendor/bootstrap/css/bootstrap.min.css" rel="stylesheet">。


对于其他使用Angular-CLI并发布到web服务器上的子文件夹的情况,请检查以下答案:

当你部署到域中的非根路径时,你需要手动更新dist/index.html中的<base href="/">标记。

在这种情况下,您将需要更新到<base href="/sub-folder/">

https://github.com/angular/angular-cli/issues/1080


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

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

然后我改成了

<base href="/">

然后它运行得很好。


你文件中的注释会使它出错。有些迷你器不会删除注释。

Also

如果你使用Node.js并使用express设置你的静态文件,例如:

app.use(express.static(__dirname + '/public'));

您需要正确地对文件进行寻址。

在我的情况下,这两个都是问题,所以我的CSS链接前缀为“/ CSS /styles.css”。

例子:

<link type="text/css" rel="stylesheet" href='/css/styles.css">

这个解决方案是完美的,因为路径是CSS无法获得渲染的主要问题


在我的例子中,当我实时部署包时,我将它从公共HTML文件夹中取出。这是有原因的。

但显然一个严格的MIME类型检查已经被激活,我不太确定它是在我这边还是由我托管的公司。

但是当我将样式化文件夹移动到index.php文件所在的目录中时,我就不再得到错误,样式化被完美地激活了。


当您没有正确引用CSS文件时,也会出现此错误。

例如,如果你的链接标签是

<link rel="stylesheet" href="styles.css">

但是你的CSS文件名为style.css(没有第二个s),那么你很有可能会看到这个错误。


反复检查文件的名称和路径。在我的情况下,我在目标文件夹中有这样的内容:

lib
    foobar.bundle.js
    foobr.css

还有这个链接:

<link rel="stylesheet" href="lib/foobar.css">

我猜浏览器试图加载JavaScript文件,并抱怨它的MIME类型,而不是给我一个文件未找到错误。


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

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


我在Angular中遇到了这个错误。我解决这个问题的方法是在我的link元素上放一个ngIf,这样它就不会出现在DOM中,直到我的动态URL被填充。

这可能和问题有点不相关,但我最终在这里寻找答案。

<link *ngIf="cssUrl" rel="stylesheet" type="text/css" [href]="sanitizer.bypassSecurityTrustResourceUrl(cssUrl)">

该问题的主要原因之一是它试图加载的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>标记?。


我只是在Angular 6构建配置的Angular .json中的样式部分引用了CSS文件(在我的例子中是Angular主题):

这并没有回答问题,但它可能是一个合适的变通方法,就像对我来说一样。


我遇到了这个问题。

我拒绝应用'http://m.b2b-v2-pre1.jcloudec.com/mobile-dynamic-load-component-view/resource/js/resource/js/need/layer.css?2.0'的样式,因为它的MIME类型('text/html')不是一个受支持的样式表MIME类型,并且启用了严格的MIME检查。

改变路径可以解决这个问题。


我有这个错误的引导模板。

<link href="starter-template.css" rel="stylesheet">

然后我从链接中删除了rel="stylesheet",即:

<link href="starter-template.css">

一切都很正常。如果您正在使用Bootstrap模板,请尝试此操作。


如果你在JavaScript中设置样式为:

    var cssLink = document.createElement("link");
    cssLink.href = "./content.component.scss";
    cssLink.rel = "stylesheet";

    /*  →  */   cssLink.type = "html/css";
    (iframe as HTMLIFrameElement).contentDocument.head.appendChild(cssLink);

然后更改字段cssLint。type(由上面描述中的箭头表示)到"MIME":

   cssLink.type = "MIME";

它将帮助你消除错误。


我也遇到过同样的问题。

如果你的项目结构像下面的树:

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

我建议在server.js中添加以下代码段:

var path = require('path')
var express = require('express')
var app = express()

app.use('/assets', express.static(path.join(__dirname, "../assets")));

注意:Path是一个内置的Node.js模块,所以它不需要通过npm安装这个包。


在大多数情况下,这可能只是CSS文件路径错误。因此web服务器返回status: 404和一些html类型的Not Found内容有效负载。

浏览器遵循这个(错误的)路径从<link rel="stylesheet"…>标记,目的是应用CSS样式。但是返回的内容类型相互矛盾,因此会记录一个错误。


我也遇到了同样的问题,在我的情况下,这是由于我手动尝试在HTML文件中导入CSS文件(就像我们总是对静态网站所做的那样),而实际上这些文件必须在Webpack使用的入口点JavaScript文件中导入。

当样式表被导入到主JavaScript文件中,而不是手动地在HTML中编写时,一切都按预期工作。


我把href改成了src。所以从这里:

<link rel="stylesheet" href="dist/photoswipe.css">

:

<link rel="stylesheet" src="dist/photoswipe.css">

它工作。我不知道为什么,但它起作用了。


这个线程的解决方案解决了我的问题:

不确定这是否对任何人都有帮助,但如果你正在使用angular-cli,我通过从index.html中删除CSS引用并将其添加到angular-cli中来解决这个问题。Json文件下的“样式”部分。 重启我的网络服务器后,我不再有这个问题。


在一长串的答案中,这个问题也发生在我身上,因为从浏览器同步的角度来看,我没有意识到路径是错误的。

给出这个简单的文件夹结构:

package.json
app
  |-index.html
  |-styles
          |-style.css

index.html文件中<link>中的href属性必须是app/styles/style.css而不是styles/style.css。


保存一个.ts文件(迫使Ionic重新构建)为我解决了这个问题。

这真的说不通……但只要它能起作用,我又有什么资格去评判呢?

在这里我看到了这个解决方案: Ionic和Angular 2 -拒绝应用来自'http://localhost:8100/build/main.css'的样式,因为它的MIME类型('text/html')不受支持


正如在这篇文章中提到的解决方案,一些解决方案为我工作,但CSS不适用于页面。

简单地说,我只是把“css”目录移动到“资产/”目录,一切都很好。

<link rel="stylesheet" type="text/css" href="assets/css/bootstrap.css">
<link rel="stylesheet" type="text/css" href="assets/css/site.css" >

删除rel="stylesheet",添加type="text/html"。所以它看起来是这样的

<link href="styles.css" type="text/html" />

引导样式没有加载#3411

https://github.com/angular/angular-cli/issues/3411

我安装了Bootstrap v. 3.3.7 NPM安装引导——保存 然后我将所需的脚本文件添加到应用程序[0]。angular-cli中的脚本。json文件: “脚本”:( “. . / node_modules /引导/ dist / js / bootstrap.js” ), //和应用程序[0]的引导CSS。风格数组 “风格”:( “styles”css, “. . / node_modules /引导/ dist / css / bootstrap.css” ), 我重新开始发球

这对我很管用。


我试着重启我的Windows电脑,重新安装“npm I”。

这对我很管用。


当我把它移动到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">

当你在React或Angular中使用命令行工具时,这个问题就会发生,所以关键是要从这些工具中复制整个最终版本,因为它们会初始化自己的轻服务器,这会混淆你的url和你创建的后端服务器……

将整个构建文件夹转储到后端服务器项目的资产文件夹中,并从后端服务器引用它们,而不是从Angular或React附带的服务器引用。否则,您将使用它作为来自某个API服务器的前端。


也许你对巴迪的授权有问题:

试试下面这些步骤:

进入ISS→找到列出的项目→单击它→单击操作下右侧窗格中的编辑权限 您将看到项目属性向导。点击证券 在组或用户名下→如果你看到“已验证用户”,那么你是被授权的,如果没有,那么你必须这样做。 一旦你添加了它(自己或在你的管理员的帮助下,如果你在一家公司工作:)),网站将开始加载资源。您可能需要在ISS下重新启动您的项目。


我遇到过这个问题,在向Azure B2C用户流添加自定义外观时遇到了同样的问题。我发现HTML页面引用的根是../oauth/v2(即oauth服务器路径)而不是我的存储bob的路径。

使用页面的完整URL为我解决了这个问题。


检查是否启用或禁用了压缩。如果你使用了它,或者有人启用了它,那么app.use(express.static(xxx))将不起作用。确保您的服务器允许压缩。

当我将Brotli和压缩插件添加到Webpack中时,我开始看到类似的错误。然后,您的服务器也需要支持这种类型的内容压缩。

如果你正在使用Express.js,那么下面的代码应该会有所帮助:

app.use(url, expressStaticGzip(dir, gzipOptions)

模块名为:express-static-gzip

我的设置是:

const gzipOptions = {
  enableBrotli: true,
  customCompressions: [{
  encodingName: 'deflate',
  fileExtension: 'zz'
 }],
 orderPreference: ['br']
}

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

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

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


导致此错误的另一个原因可能是CSS文件权限不正确。在我的例子中,文件无法访问,因为所有权已更改为根用户——这是由于以根用户推送Git文件造成的。


在我的例子中,它是由Grunt运行的任务的执行顺序。

它执行任务connect来设置本地服务器,并在执行less和postcss来转换样式之前在一个新选项卡中自动打开应用程序。

基本上,我改变了这个:

grunt.registerTask('default', 'Start server. Process styles.', ['connect', 'less', 'postcss']);

:

grunt.registerTask('default', 'Process styles. Start server.', ['less', 'postcss', 'connect']);

它成功了!


如果浏览器找不到相关的CSS文件,就会给出这个错误。

如果你使用的是Angular应用,你不需要在file index.html中使用CSS文件路径:

<link href="xxx.css" rel="stylesheet"> 

您可以在styles.css文件中使用相关的CSS文件路径。

@import "../node_modules/material-design-icons-iconfont/dist/material-design-icons.css";

您必须导入多个样式表。试着删除一个,然后再试一次。


我正在使用React应用程序,也有这个错误引导我到这里。这对我很有帮助。

我没有把<link>添加到index.html中,而是在需要使用这个样式表的组件中添加了一个导入:

import 'path/to/stylesheet.css';

我遇到了类似的错误,发现错误是在style.css link href的末尾添加'/'。

用<link rel="stylesheet" href="style.css/">替换<link rel="stylesheet" href="style.css">修复了这个问题。


如果您正在使用Node.js应用程序,请确保\public文件夹位于根文件夹的下面,而不是在views文件夹中。

这可能会很麻烦。将\public立即移到根目录下面,然后重新启动服务器并观察变化。


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

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

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

我的解决方案是:

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

启用IIS静态内容


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

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

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


我也面临着同样的问题。

我将我的目录权限更改为755 ((U)用户/所有者可以读、写和执行。(G)组能读,不能写,能执行。(其他人可以读,不能写,但可以执行)现在所有的文件都在加载中。

你也可以试试我的答案。我希望这对你有用。


我在Select2中遇到了这个挑战。在我下载了最新版本的库并替换了我的项目中的一个(CSS和JavaScript文件)后,问题得到了解决。


进入我的浏览器控制台→网络→样式。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链接指向哪里。


在我的例子中,在改变.scss文件中的随机值后,问题就解决了。重新加载后,问题消失,样式开始加载良好。简单,但有效:P


我在XAMPP安装中使用了虚拟域,并得到了这个问题。所以在httpd-vshosts.conf文件中,当我检查时,我已经显式地指向了index.php文件,这导致了问题。

所以我改了这个:

<VirtualHost *:80>
    DocumentRoot "C:/xampp/htdocs/cv/index.php"
    ServerName cv.dv
</VirtualHost>

:

<VirtualHost *:80>
    DocumentRoot "C:/xampp/htdocs/cv/"
    ServerName cv.dv
</VirtualHost>

然后文件就加载好了。


在我的Angular-Ionic项目中,我有一个这样的CSS条目,它只在我请求时加载组件。

 .searchBar {
    // --placeholder-color: white;
    // --color: white;
    // --icon-color: white;
    // --border-radius: 20px;
    // --background: color:rgba(73,76,67,1.0);
    // --placeholder-opacity: 100%;
    // background-color: red;
  }

当我注释掉CSS类条目中的所有值时,它又开始工作了。

我认为这是由于将这些属性background-color和background放在一起。


这是针对TypeScript和Express.js的

我按Ctrl + F“TypeScript”和“。ts”,在这些答案中没有发现任何东西,所以我将在这里添加我的解决方案,因为这是由(我对TypeScript缺乏经验)引起的,我读过的解决方案并没有明确解决这个特定的问题。

问题是TypeScript正在把我的app.ts文件编译成我项目dist目录dist/app.js中的JavaScript文件。

这是我的目录结构。看看你是否能发现问题所在:

.
├── app.ts
├── dist
│   ├── app.js
│   ├── app.js.map
│   └── js
│       ├── dbclient.js
│       ├── dbclient.js.map
│       ├── mutators.js
│       └── mutators.js.map
├── public
│   ├── css
│   │   └── styles.css
├── tsconfig.json
├── tslint.json
└── views
    ├── index.hbs
    └── results.hbs

我的问题是,在app.ts中,我告诉express将我的公共目录设置为/public,如果Node.js实际运行TypeScript,这将是一个有效的路径。但是Node.js运行的是编译后的JavaScript, app.js,在dist目录下。

所以让app.ts假装它是dist/app.js解决了我的问题。因此,我通过更改app.ts解决了这个问题

app.use(e.static(path.join(__dirname, "/public")));

to

app.use(e.static(path.join(__dirname, "../public")));

除了使用:

<base href="/">

从CSS链接中删除rel="stylesheet"部分:

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

我是如何解决这个问题的。 对于Node.js应用程序,你需要设置你的**公共**文件夹配置。

// Express js
app.use(express.static(__dirname + '/public'));

否则,你需要像href="public/css/style.css"这样做。

<link href="public/assets/css/custom.css">
<script src="public/assets/js/scripts.js"></script>

注意:它将适用于http://localhost:3000/public/assets/css/custom.css。但在构建后无法工作。您需要设置app.use(express。Static (__dirname + '/public'));为表达


我想在这里分享一些关于这个话题的想法,当我的地方

app.use(expres.static('../frontEnd/public'))

不管用,但我用的时候

app.use(express.static('/frontEnd/public'))

它工作得很好。


每个人的评论都没有帮助我,解决方案是修复路线,因为从主页我发现文件,但当我导航它消失了,正确的解决方案会说,有这些东西很好地放置


我也遇到了同样的问题:这是解决方案。不要在。html文件的CSS链接的路径中写入public。虽然你的。css文件在公共文件夹中。

例子:

JavaScript文件

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

HTML文件

使用这个

<link href="styles.css" rel="stylesheet">

而不是

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

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

style.css.css

添加Express.js默认静态中间件如下:

Import express const express = require("express")

初始化表达式const app = express()

app.use(express.static(__dirname));

然后需要使用公共目录的完整路径

例如:

您的文件结构在公共目录

Public > CSS > style.css

你的道路将是

<link rel="stylesheet" type="text/css" href="./public/css/style.css"/>

注1:

您可以使用任何名称而不是公共名称,即assets myassets any other。

注意2:你的服务器应该在主目录下运行。 如果您的服务器在子目录中运行,那么您可以使用../出来


https://github.com/froala/angular-froala/issues/170#issuecomment-386117678 找到了上面的加法解

href="/">

就在index.html的样式标签之前


有时,这种情况发生在找不到CSS文件时。检查文件的基本URL /路径是值得的。


遇到类似的问题时,使用以下简单的修复方法解决了它。如果你的项目是基于React的,那么不要在“index.html”中导入你的“styles.css”,而是在“index.js”中导入它,它通常位于项目的“src”文件夹中。这将确保React应用程序中的所有路由都可以访问样式文件。


我在EJS和Node.js中也遇到了同样的问题。

我已经像这样设置了我的视图引擎的公共文件夹:

app.use('/public', express.static(process.cwd() + '/public'));

app.set('view engine', 'ejs');

我的目录结构是这样的

public
|
-assets
 |
  --CSS
  |---style.css

我试图链接我的样式。css在EJS头像这样

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

添加公共解决了问题(确保检查网络选项卡)

<link href="/public/assets/css/style.css" rel="stylesheet" type="text/css">

错的是道路。

我的道路是

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

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

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

  href="public\style.css"

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

  href="public/style.css"


对于nodejs用户,使用这个。 这应该可以解决Node的问题。

app.use (express.static(静态));


一个对我有效的解决方案是将css文件名从“style.css”更改为另一个名称,如“component.css”。效果很好。


另一个原因可能是2个apache .conf文件,其中,如果你的配置强制https,那么你的服务器将忽略在sites-enabled/http-default.conf中设置的变量。例如,如果你在http-default.conf中定义了“/static”,但没有在http- ssl.conf中定义,那么你的静态文件可能找不到,即404。


对于localhost,路径是不同的,而通过file:// &部署时…


在我的React应用程序的public/index.html中添加<base href="/">也为我解决了这个问题。


对我来说,这是一个磁盘空间满的问题,抛出这个控制台错误。增加磁盘空间,使应用程序能够再次正确地构建资产。