django MTV 静态文件js的添加方式,以及怎么优化js的加载

django MTV 静态文件js的添加方式,以及怎么优化js的加载

1:怎么添加js

2:怎么优化js的加载

django MTV 需要用到的js时,使用以下方式

html 复制代码
<!DOCTYPE html>  
<html lang="en">  
<head>  
    <meta charset="UTF-8">  
    <title>Title</title>  
    <script defer src="a.js"></script>  
	<script async src="{% static 'a.js' %}"></script>
	<script defer src="{ %static 'a.js' %}"></script>
</head>  
<body>  
{{ context }}  
</body>  
</html>

上面代码 不继承任何模板,也不继承 base.hmtl

js使用方式

插入js的方式1:

c 复制代码
直接写 <script defer src="a.js"></script>
相当于访问后端 http://127.0.0.1:8000/a.js
c 复制代码
因为这个[html]文件是在这个项目的[templates]文件夹中,如我把[a.js]文件也放在这个目录中,idea编辑器 会提示 允许写这个目录中的[a.js]文件。
但是,django不会把项目中的templates文件夹中的a.js文件进行映射

插入js的方式2:

c 复制代码
直接写<script defer src="/static/a.js"></script>
相当于访问后端 http://127.0.0.1:8000/static/a.js
c 复制代码
这时会出现2个状态
DEBUG=True  时,静态文件夹[static/a.js] 会被正常的获取
DEBUG=False 时,静态文件夹[static/a.js] 禁止获取      ---django不建议直接映射静态文件

插入js的方式3:

html 复制代码
{% load static %}
<script defer src="{ %static 'a.js' %}"></script>
相当于访问后端 http://127.0.0.1:8000/static/a.js
python 复制代码
DEBUG=True  时,django能够进行向浏览器发送 a.js
并且,
1:当a.js文件是在static文件夹中时,是能够被浏览器获取到的
2:当a.js文件不存在static文件夹中时,那么前端无法获取到该文件,并且返回404,就算把a.js文件放到[templates]文件夹中也不行
当然,
DEBUG=True  时,静态文件夹[static/a.js] 会被正常的获取
DEBUG=False 时,静态文件夹[static/a.js] 禁止获取      ---django不建议直接映射静态文件


这里加了 {% static 'a.js'%} 表示
Django使用静态模板标记,通过配置STATICFILES STORAGE为给定的相对路径构建URL。静态模板标签用于引用Django模板中的静态文件,如图像、JavaScript或CSS

一般都指向与manage.py相同等级路径中的static文件夹中

关于script中对js的设定执行时间节点

c 复制代码
后端会按照html中的顺序,从第一行开始发送html文件中的代码给浏览器,直至最后一行

在浏览器接收到head 部分时, 
当浏览器接收到 <script src="a.js"></script>  这行后,会即刻去下载a.js,
1:普通的情况下: 浏览器会先去下载完a.js之后才去继续接收head的后面body部分,并且当下载完a.js后会即刻执行a.js的逻辑,再继续下载body部分。
2:异步情况:a.js 与body 部分同时下载


那么这个异步下载中会出现以下状况:

2.1:a.js 与body 部分同时下载,浏览器先接收到的body部分的一些,或许是前10行,后面还有50行未接收,
这时:浏览器会马上渲染这个10行body部分
当接收到20行body部分时,这时a.js也接收完了,即刻执行a.js中的逻辑

2.2:a.js 与body 部分同时下载,body部分边接收,边渲染,直到body的接收完成,才允许a.js对body进行操作



1  :<script src="a.js"></script>
2.1:<script ansyc src="a.js"></script>
2.2:<script defer src="a.js"></script>
  
相关推荐
swipe29 分钟前
正则表达式入门到进阶:从表单校验到手写模板引擎
前端·javascript·面试
kyriewen1 小时前
前端错误监控最全指南:捕获 JS 异常、Promise 拒绝、资源加载失败,附上报代码
前端·javascript·监控
用户8356290780511 小时前
用 Python 自动化 PowerPoint 演讲者备注添加
后端·python
大家的林语冰1 小时前
ESLint 近期动态大全,新版本正式发布,antfu 大佬推荐的插件也更新了!
前端·javascript·前端工程化
胡志辉2 小时前
深入浅出 call、apply、bind
前端·javascript·后端
十九画生5 小时前
parentID ``` JavaScript 是区分大小写的,所以这两个不是同一个字段。 第二,`parent` 没有声明。 应该先写: `
javascript
怕浪猫6 小时前
Electron 开发实战(十六):总结与展望|生态现状、框架对比、行业趋势与学习指南
前端·javascript·electron
ZengLiangYi7 小时前
批量导入 1000 条对话的性能优化实战
javascript·后端·架构
黄忠7 小时前
01-系统架构设计-LangGraph状态机与多源异构RAG
python
竹林8187 小时前
用 wagmi v2 + viem 监听合约事件时踩的坑,我花了两天才把"遗漏事件"修好
javascript