gpt4 book ai didi

javascript - JQuery 在 Django 自定义模板标签的模板中不起作用

转载 作者:行者123 更新时间:2023-11-29 22:01:21 24 4
gpt4 key购买 nike

我正在创建一个简单的自定义模板标签,它在调用时呈现自己的模板。问题是这个 templatetag 模板上的 JQuery 不工作,我不知道为什么。

父模板

<head>
<script type="text/javascript" src="{{ STATIC_URL }}js/jquery.js"></script>
<script src="//code.jquery.com/jquery-1.9.1.js"></script>
<script src="//code.jquery.com/ui/1.10.4/jquery-ui.js"></script>
</head>
<body>
{% render_style %}
</body>

render_style 模板标签

@register.inclusion_tag('TEST.html')
def render_style():
return

TEST.html

<head>
<script type="text/javascript">
$(document).ready(function(){
$("#name").css("text-decoration","underline");
});
</script>
</head>
<body>
<h2 id="name">FULL NAME</h2>
</body>

templatetag 的模板确实正在加载,因为文本 FULL NAME 显示在屏幕上但没有下划线。如果我将相同的 JQuery 放在父模板中,那么 FULL NAME 将带有下划线。

这是怎么回事?当脚本位于父类中时,它喜欢 JQuery,但当脚本驻留在 render_style 的模板中时,它不喜欢它。

最佳答案

我猜测模板代码正在事件处理程序中执行。

所以你的代码给已经执行过一次的ready事件添加了一个事件监听器,不会再执行了。

所以尝试移动$("#name").css("text-decoration","underline");#name 标签下删除 ready 事件,看看它是否有效。

例子:

<h2 id="name">FULL NAME</h2>
<script type="text/javascript">
$("#name").css("text-decoration","underline");
</script>

关于javascript - JQuery 在 Django 自定义模板标签的模板中不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23577080/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com