簡體   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