繁体   English   中英

cordova Jquery 和 javascript 不会运行

[英]cordova Jquery and javascript wont run

我正在尝试使用 Cordova 构建一个应用程序。 可悲的是,我的 javascript 由于某种原因无法工作......有人可以帮忙解决这个问题吗?

我在 index.html 中拥有的所有(目前)

    <head>
        <meta charset="utf-8">
        <meta http-equiv="Content-Security-Policy" content="default-src 'self' data: gap: https://ssl.gstatic.com 'unsafe-eval'; style-src 'self' 'unsafe-inline'; media-src *; img-src 'self' data: content:;">
        <meta name="format-detection" content="telephone=no">
        <meta name="msapplication-tap-highlight" content="no">
        <meta name="viewport" content="initial-scale=1, width=device-width, viewport-fit=cover">
        <meta name="color-scheme" content="light dark">
        <link rel="stylesheet" href="css/index.css">
        <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.5.1/jquery.min.js"></script>
        <title>Hello World</title>
    </head>
    <body>
    <div class="app">
        <h1 id="title">Test</h1>
        <p id="change">The <span class="blink">best</span> app</p>
        <button id="btn">Change content of all p elements</button>
    </div>
    <script src="js/test.js"></script>
    </body>

在 js/test.js 中:

$("#btn").click(function(){
  $("#change").html("<b>Hello world!</b>");
});

所以不应该有太多可能 go 错误,除非它确实......

编辑:即使是正常的 Javascript 也不起作用?

正如控制台消息所阐明的,您的内容安全策略正在阻止外部 jquery 脚本。 您需要在 CSP 中允许该外部脚本。 为此,您需要更改此元标记

<meta http-equiv="Content-Security-Policy" content="default-src 'self' data: gap: https://ssl.gstatic.com 'unsafe-eval'; style-src 'self' 'unsafe-inline'; media-src *; img-src 'self' data: content:;"> to

<meta http-equiv="Content-Security-Policy" content="default-src 'self' data: gap: https://ssl.gstatic.com 'unsafe-eval'; style-src 'self' 'unsafe-inline'; media-src *; img-src 'self' data: content:;script-src https://ajax.googleapis.com">

我们刚刚添加了一个script-src规则来将我们的 jquery 脚本列入白名单。

要了解更多信息,您可以查看此帖子

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM