Javascript 代码在 jsfiddle 中工作,但不在浏览器中工作

IT技术 javascript jquery html loading
2021-03-03 21:57:32

我曾尝试搜索类似的问题,但无法找到我的代码在 jfiddle 中运行但在浏览器中不起作用的原因。我还尝试将我的代码从 jfiddle 复制到另一个小提琴项目,但该代码在新项目中不起作用。你可以在这里找到我的项目我正在制作一个交互式食物游戏,其中有人选择食物,例如橡子南瓜,然后用户可以拖动该图像。

我的第一次尝试是在头部粘贴代码。

<script language="JavaScript">
code
</script>

我需要一个页面加载事件吗?javascript 需要放在一个函数中吗?我是否使用了 jfiddle 框架中没有在我需要调用的本地主机上使用的东西?

下面是我在没有额外食物选项的情况下使用的代码

var stage, layer;

var sources = {
    plate: 'http://www.healncure.com/wp-content/uploads/2014/03/plate1.jpg',
    acornsquash: 'http://www.healncure.com/wp-content/uploads/2014/03/acorn-squash.png',

};
loadImages(sources, initStage);

function loadImages(sources, callback) {
    var images = {};
    var loadedImages = 0;
    var numImages = 0;
    // get num of sources
    for (var src in sources) {
        numImages++;
    }
    for (var src in sources) {
        images[src] = new Image();
        images[src].onload = function () {
            if (++loadedImages >= numImages) {
                callback(images);
            }
        };
        images[src].src = sources[src];
    }
}

function initStage(images) {
    stage = new Kinetic.Stage({
        container: 'container',
        width: 936,
        height: 550
    });
    layer = new Kinetic.Layer();
    stage.add(layer);

    // plate
    var plateImg = new Kinetic.Image({
        image: images.plate,
        x: 218,
        y: 20,
        width: 503,
        hei4ht: 502,
        draggable: false,
        visible: true
    });
    layer.add(plateImg);

    // acornsquash
    var acornsquashImg = new Kinetic.Image({
        id: "acornsquash",
        image: images.acornsquash,
        x: 50,
        y: 20,
        width: 134,
        height: 114,
        draggable: true,
        stroke: 'orange',
        strokeWidth: 5,
        strokeEnabled: false,
        visible: false

    });
    layer.add(acornsquashImg);

    layer.draw();

    $(".food").click(function () {
        var node = stage.find("#" + $(this).attr("id"));
        node.show();
        layer.draw();
        console.log($(this).attr("id"));
    });

    document.getElementById('hide').addEventListener('click', function () {
        acornsquashImg.hide();
        layer.draw();
    }, false);
}
2个回答

通常的原因是,你把你的代码上面的元素,它在运行,并使用不延迟代码onload或“准备”的事件。的jsfiddle默认的是把你的JavaScript在onload处理程序,延迟,直到非常在页面加载过程中下旬。

从根本上说,在您的代码可以对页面上的元素执行某些操作之前,该元素必须存在。要使其存在,浏览器必须已经为它处理了 HTML。所以这失败了:

<html>
<head>
<script>
// FAILS
document.getElementById("foo").style.color = "green";
</script>
</head>
<body>
<div id="foo">This is foo</div>
</body>
</html>

但这有效:

<html>
<head>
</head>
<body>
<div id="foo">This is foo</div>
<script>
// Works
document.getElementById("foo").style.color = "green";
</script>
</body>
</html>

我需要一个页面加载事件吗?

几乎可以肯定不是。

javascript 需要放在一个函数中吗?

不必要。你要做的是把script标签放在 HTML 的最后,就在结束</body>标签之前

@user3251146:听起来您正在使用KineticJS,但不包括 KineticJS 脚本,该脚本需要在您的代码使用它之前包含。
2021-04-16 21:57:32
@TJCrowder,我似乎遇到了类似的问题,尽管在我的情况下,完全按照我的浏览器运行由 JSFiddle iframe 生成的代码仍然无法正常工作。那就请有可能看看我的问题在这里,在您方便?我是 Web 开发的新手,所以我很难隔离这个问题。
2021-04-17 21:57:32
谢谢你的例子。我明白为什么它似乎不起作用。我曾尝试将我的代码放在 html 下方,但这并没有解决问题。我还在头中包含了 jquery 库。仍然没有(从评论中提到)。我正在检查我的页面,我得到了这个,“Uncaught ReferenceError: Kinetic is not defined”。我该如何定义?
2021-04-25 21:57:32

在文档的头部部分包含 jQuery 库

<head>
  <script src="//ajax.googleapis.com/ajax/libs/jquery/1.11.0/jquery.min.js"></script>
</head>

然后将您的自定义脚本包装在脚本标签和文档就绪功能之间

<script>
  $(function() {

    ...your custom scripts...

  });
</script>

就在</body>标签之前

我错过了这个,出于某种原因,当我将它包含在头部时它不起作用。当我包含 Microsoft CDN: version 时,我的代码决定工作。
2021-04-17 21:57:32