JS引号字符被删除

JS Quote Characters Are Stripped

本文关键字:删除 字符 JS      更新时间:2023-09-26

我正在尝试使用JS提取媒体查询内容css属性。然而,引号似乎被剥去了。参见以下内容:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Untitled Document</title>
<script type="text/javascript" src="https://ajax.googleapis.com/ajax/libs/jquery/1.7.1/jquery.min.js"></script>
<script type="text/javascript">
    $(window).load(function() { 
        for(var i = 0; i < document.styleSheets.length; i++){
            for(var j = 0; j < document.styleSheets[i].cssRules.length; j++){
                for(var k = 0; k < document.styleSheets[i].cssRules[j].cssRules.length; k++){
                    var css_text = document.styleSheets[i].cssRules[j].cssRules[k].cssText;
                    console.log('css_text');
                    console.log(css_text);
                }
            }
        }
   });
</script>
<style type="text/css">
    @media screen and (max-width: 960px) {
        body:after{
            content: "hello";   
        }
    }
</style>
</head>
<body style="margin: 0px;">
   some stuff here...
</body>
</html>

以上返回:

css_text
body::after { content: hello; }

我希望的回报:

css_text
body::after { content: "hello"; }

我正在使用谷歌Chrome浏览器。

有什么办法可以保留原来围绕hello的引号吗?

您需要转义引号。以下链接是一种方法。。http://magp.ie/2011/01/20/addslashes-and-stripslashes-in-javascript/

所以你会写
console.log(addslashes(css_text))

让我知道它是否有效:)