html中script的位置导致的js不能正常执行问题

news/2024/7/19 15:07:19 标签: js, javascript, html

前言

今天写网页,犯了一个刚学h5时容易犯的低级错误,记录一下。

情景

问题代码:
不用看代码的内容,看html" title=js>js的引入位置即可。这两个文件在同一目录下html" title=js>js文件名为1.html" title=js>js。
html代码:

html"><!DOCTYPE html>
<html lang="zh-CN">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <!--html" title=js>js文件在此引入-->
    <script src="1.html" title=js>js"></script>
    <title>五角星</title>
</head>
<body>
    <canvas id="mycanvas" width="300" height="200" style="border: 1px solid;">
        您的浏览器不支持H5画布!
    </canvas>
</body>
</html>

html" title=js>js代码:

html" title=javascript>javascript">var mycanvas = document.getElementById("mycanvas");
var ctx = mycanvas.getContext("2d");
var pas = Math.PI*2/5;
var i=0;
ctx.beginPath();
ctx.moveTo(150, 10);//绘制的起点

var id = setInterval(function(){//圆心位置(150,110)
    i += 2;
    if(i > 10){
        clearInterval(id);
    }
    ctx.lineTo(150 + 100 * Math.cos(i*pas-Math.PI/2), 110 + 100 * Math.sin(i*pas-Math.PI/2));
    ctx.strokeStyle = "red";
    ctx.stroke();
},200)

这段代码的html" title=js>js可以执行吗?答案是不能。运行结果及报错截图如下。
在这里插入图片描述
那么改变一下html" title=js>js的位置呢。
html代码:

html" title=javascript>javascript"><!DOCTYPE html>
<html lang="zh-CN">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    
    <title>五角星</title>
</head>
<body>
    <canvas id="mycanvas" width="300" height="200" style="border: 1px solid;">
        您的浏览器不支持H5画布!
    </canvas>
    <!--html" title=js>js文件在此引入-->
    <script src="1.html" title=js>js"></script>
</body>
</html>

运行结果截图
在这里插入图片描述
丝滑运行。

原因分析

为什么会出现这种状况呢?
我们知道html文件是从上到下执行的。如果在head中引入html" title=js>js文件,那么html" title=js>js的执行会提前于body标签内容执行,导致html" title=js>js不能找到要操作获取的标签id。最终导致html" title=js>js文件执行出错。
而将html" title=js>js在body底部或外面引入则可以运行,理论上讲只要你引入html" title=js>js文件的位置在你要获取id的标签后面执行就没有问题。

问题解决

可以向上面那样将html" title=js>js的引入放到后面。但一些有强迫症的朋友可能就想将它放在head里,当然这也不是不可以实现的。
第一种方法: 需要在你的html" title=js>js文件中使用window.onload = function(){}来等待html加载完成再解析html" title=js>js了。示例如下。
html" title=js>js代码:

html" title=javascript>javascript">window.onload = function(){//html加载完成后执行
    var mycanvas = document.getElementById("mycanvas");
    var ctx = mycanvas.getContext("2d");
    var pas = Math.PI*2/5;
    var i=0;
    ctx.beginPath();
    ctx.moveTo(150, 10);//绘制的起点

    var id = setInterval(function(){//圆心位置(150,110)
        i += 2;
        if(i > 10){
            clearInterval(id);
        }
        ctx.lineTo(150 + 100 * Math.cos(i*pas-Math.PI/2), 110 + 100 * Math.sin(i*pas-Math.PI/2));
        ctx.strokeStyle = "red";
        ctx.stroke();
    },200)
}

第二种方法: 使用script标签的defer属性,此属性会延迟html" title=js>js代码的执行。只有当html文件加载完成后才会执行html" title=js>js。(注意只有html" title=js>js为外部引入时才有效)

html" title=js>js"><!DOCTYPE html>
<html lang="zh-CN">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <!--html" title=js>js文件在此引入-->
    <script src="1.html" title=js>js" defer></script>
    <title>五角星</title>
</head>
<body>
    <canvas id="mycanvas" width="300" height="200" style="border: 1px solid;">
        您的浏览器不支持H5画布!
    </canvas>
</body>
</html>

第三种方法: 使用script标签的async属性,此属性会异步加载html" title=js>js代码,不会因为执行html" title=js>js而使HTML渲染进入阻塞。(注意只有html" title=js>js为外部引入时才有效)

html" title=js>js"><!DOCTYPE html>
<html lang="zh-CN">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <!--html" title=js>js文件在此引入-->
    <script src="1.html" title=js>js" async></script>
    <title>五角星</title>
</head>
<body>
    <canvas id="mycanvas" width="300" height="200" style="border: 1px solid;">
        您的浏览器不支持H5画布!
    </canvas>
</body>
</html>

http://www.niftyadmin.cn/n/489841.html

相关文章

微信小程序怎样用setData修改字典和在数组中添加

setData函数在小程序中具有同时修改前端和后端的功能&#xff0c;应该是进行数据修改中最常用的一个功能了。 修改data中的变量 wxml <view>{{information}} </view> <view><button type"primary" bindtap"click">修改信息<…

win10系统安装face_recognition

介绍 face_recognition是一个人脸识别库&#xff0c;号称识别准确率可达 99.38%。 因为写毕业设计要用到这个库&#xff0c;开始在Ubuntu上使用这个库&#xff0c;安装没有出现任何问题。今天在win10系统上想要安装这个库时却出现了问题&#xff0c;记录一下。 问题 face_re…

wxpython制作桌面悬浮球

介绍 使用wxpython制作一个类似于电脑管家一样的悬浮球。 功能 圆形窗口自动鼠标离开悬浮球自动贴边鼠标在悬浮球上自动弹出整个悬浮球 效果 代码 import wxclass myframe(wx.Frame):def __init__(self):super().__init__(parentNone,poswx.DefaultPosition,stylewx.FRAME…

OpenCV-python的imshow方法无法弹出窗口问题

问题 今天使用OpenCV的imshow方法预览摄像头捕捉的图像时&#xff0c;出现了显示窗口不弹出的问题&#xff0c;最后通过安装matplotlib库解决的。 使用的代码 import cv2 import os # 调用笔记本内置摄像头&#xff0c;所以参数为0&#xff0c;如果有其他的摄像头可以调整参…

PyAutoGUI使用

PyAutoGUI使用 ### 鼠标事件 获取屏幕大小&#xff0c;返回的为元组&#xff1a;width, height pyautogui.size() 检查坐标是否在屏幕内&#xff0c;返回bool值&#xff1a;pyautogui.onScreen(x, y) 获取鼠标位置&#xff0c;返回的为元组&#xff1a;currentMouseX, cur…

wxFormBuilder使用介绍

wxFormBuilder介绍 wxFormBuilder是一个开源&#xff0c;跨平台的所见即所得的图形用户界面生成器&#xff0c;可以翻译wxWidget GUI设计成C&#xff0c;Python&#xff0c;PHP&#xff0c;XRC格式。github项目地址 这个工具将wxPython设计用户图形界面的过程可视化。通过简单…

BFC(Block Formatting Context) 块级格式化上下文

BFC(Block Formatting Context) 块级格式化上下文 BFC就好像标签的一个属性&#xff0c;可以使一个区域具有独立渲染不影响其他区域的特性。 BFC常用的几个方式 float属性不为noneoverflow属性不为visibleposition属性为absolute或fixeddisplay属性为inline-blockcontain值为…

Vue的v-if与v-show的区别

Vue的v-if与v-show的区别 v-show和v-if都可以通过判断条件来决定页面的某个组件的是否在页面上显示&#xff0c;但它们在原理上却并不相同。了解它们的原理可以是我们写出更高质量的页面。 v-if v-if是条件渲染语句&#xff0c;它是真正的条件渲染。根据if后面的条件来决定某…