当前位置:首页 > 文章列表 > 文章 > python教程 > Django模板继承写法与复用技巧

Django模板继承写法与复用技巧

2026-04-26 19:36:52 0浏览 收藏
Django模板继承看似简单,实则暗藏三大关键陷阱:block名称必须严格一致(区分大小写)、模板路径始终相对于项目templates根目录而非文件位置、{{ block.super }}必须置于同名block内且符合HTML语义结构——任一疏忽都会导致内容静默失效、渲染错乱或资源重复加载,而Django往往不报错,只让页面“看起来不太对”,掌握这三处精准控制,才能真正实现高复用、易维护、无隐患的模板架构。

Python Django模板继承怎么写_提高前端代码复用与维护性

base.html 必须定义 block,否则子模板继承无效

子模板里用 {% extends "base.html" %} 只是声明继承关系,真正能填内容的位置,得靠 base.html 里提前写好 {% block content %}{% endblock %} 这类占位。没定义 block,子模板里的 {% block content %}... 就完全不生效,页面空白或内容错位都可能发生。

常见错误现象:base.html 里只写了 HTML 结构,但漏掉 {% block %};或者子模板写了 {% block main %},而 base.html 里对应的是 {% block content %},名字不一致导致内容被忽略。

  • base.html 至少要包含一个 {% block %},推荐拆成 titlehead_extracontentfooter 等语义化名称
  • 子模板中 {% block xxx %} 的名称必须和 base.html 中完全一致(区分大小写)
  • 如果想让子模板“追加”而非“替换”内容,用 {{ block.super }},比如在子模板的 {% block head_extra %} 里加 JS,同时保留父模板已有的 CSS 引入

Django 模板继承不支持多级嵌套?其实是支持的,但路径容易写错

可以 base.htmllayout.htmlarticle_detail.html 三级继承,关键在于每层 {% extends %} 的路径都是相对于 TEMPLATES['DIRS']app/templates/ 的根目录,不是相对当前文件位置。

使用场景:大型项目常把通用结构抽成 base.html,再按模块建 dashboard/base.htmladmin/base.html 等中间层,避免所有页面直连顶层。

  • 路径写成 {% extends "dashboard/base.html" %},而不是 {% extends "../dashboard/base.html" %} —— Django 不认点号路径
  • 如果 layout.html 放在 myapp/templates/myapp/layout.html,那它引用父模板得写 {% extends "base.html" %}(假设 base.htmltemplates/base.html),而不是 {% extends "myapp/base.html" %}
  • 调试时可打开 DEBUG=True,Django 报错会明确提示 TemplateDoesNotExist: xxx.html,说明路径不对

block.super 用错位置会导致渲染顺序混乱

{{ block.super }} 是把父模板同名 block 的内容插入当前位置,但它不是“自动拼接”,而是严格按子模板中写的顺序执行。放错位置,比如放在 HTML 标签中间或闭合标签之后,会直接破坏 DOM 结构。

性能影响很小,但逻辑错乱很隐蔽:比如父模板 block title 输出 Site,子模板写成 {{ block.super }} | Article 是对的;但如果写成 {{ block.super }} | Article,就会变成 Site | Article,浏览器只认第一个 </code>。</p> <ul><li><code>{{ block.super }}</code> 必须出现在 <code>{% block %}...{% endblock %}</code> 内部,且位置符合 HTML 语义</li> <li>不要在 <code>{% block %}</code> 外使用 <code>{{ block.super }}</code>,Django 会静默忽略或报错</li> <li>如果父模板该 <code>block</code> 为空,<code>{{ block.super }}</code> 渲染结果就是空字符串,不会报错,容易误以为“没生效”</li> </ul><h3>static 和 url 在继承模板里怎么写才不重复加载资源</h3> <p>静态资源路径(CSS/JS)和 URL 反查(<code>{% url 'xxx' %}</code>)本身不因继承变复杂,但容易在多层 <code>block</code> 中重复引入——比如 <code>base.html</code> 已载 jQuery,子模板又在自己的 <code>block head_extra</code> 里再载一次,造成冗余请求或版本冲突。</p> <p>兼容性注意:Django 4.2+ 对 <code>{% static %}</code> 的缓存行为更严格,重复调用同一路径不会额外开销,但逻辑重复仍可能引发样式覆盖或脚本执行两次。</p> <ul><li>把全局必需的静态资源(重置 CSS、核心 JS)全放在 <code>base.html</code> 的 <code>{% block head %}</code> 或独立 <code>{% block vendor_css %}</code> 里</li> <li>子模板只在对应 <code>block</code> 中加自己特有的资源,比如 <code>article_detail.html</code> 加 Prism.js 代码高亮</li> <li><code>{% url %}</code> 没继承风险,但别在 <code>base.html</code> 的 <code>block</code> 里硬编码路径,应由子模板传参或用上下文变量控制链接可见性</li> </ul> Django 模板继承真正难的不是语法,而是 block 命名是否一致、路径是否从 templates 根目录算起、以及 <code>{{ block.super }}</code> 插入点是否在合法 HTML 位置——这三个地方出错,页面往往不报错,只是“看起来不太对”。<p>理论要掌握,实操不能落!以上关于《Django模板继承写法与复用技巧》的详细介绍,大家都掌握了吧!如果想要继续提升自己的能力,那么就来关注golang学习网公众号吧!</p> </div> <div class="labsList"> </div> <div class="cateBox"> <div class="cateItem"> <a href="/article/579445.html" title="Golangmap并发问题与锁机制解析" class="img_box"> <img src="/uploads/20260426/177720340269edf8ca9db84.jpg" onerror="this.onerror='',this.src='/assets/images/moren/morentu.png'" alt="Golangmap并发问题与锁机制解析">Golangmap并发问题与锁机制解析 </a> <dl> <dt class="lineOverflow"><a href="/article/579445.html" title="Golangmap并发问题与锁机制解析" class="aBlack">上一篇<i></i></a></dt> <dd class="lineTwoOverflow">Golangmap并发问题与锁机制解析</dd> </dl> </div> <div class="cateItem"> <a href="/article/579447.html" title="nonce属性如何配合CSP脚本白名单使用" class="img_box"> <img src="/uploads/20260426/177720341269edf8d4db96f.png" onerror="this.onerror='',this.src='/assets/images/moren/morentu.png'" alt="nonce属性如何配合CSP脚本白名单使用"> </a> <dl> <dt class="lineOverflow"><a href="/article/579447.html" class="aBlack" title="nonce属性如何配合CSP脚本白名单使用">下一篇<i></i></a></dt> <dd class="lineTwoOverflow">nonce属性如何配合CSP脚本白名单使用</dd> </dl> </div> </div> </div> </div> <div class="leftContBox pt0"> <div class="pdl20"> <div class="contTit"> <a href="/articlelist.html" class="more" title="查看更多">查看更多<i class="iconfont"></i></a> <div class="tit">最新文章</div> </div> </div> <ul class="newArticleList"> <li> <div class="contBox"> <a href="/article/620084.html" class="img_box" title="Python contextlib 资源清理配方:把 try/finally 收进上下文管理器"> <img src="/uploads/20260629/1782708516-python-contextlib-exitstack-flow.webp" onerror="this.src='/assets/images/moren/morentu.png'" alt="Python contextlib 资源清理配方:把 try/finally 收进上下文管理器"> </a> <dl> <dd class="cont1"> <span> <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> · <a href="/articlelist/86_new_0_1.html" class="aLightGray" title="python教程">python教程</a>   |  16小时前  |   <a href="/articletag/172_new_0_1.html" class="aLightGray" title="标准库">标准库</a> · <a href="/articletag/1678_new_0_1.html" class="aLightGray" title="资源管理">资源管理</a> · <a href="/articletag/39719_new_0_1.html" class="aLightGray" title="Python教程">Python教程</a> · <a href="/articletag/40032_new_0_1.html" class="aLightGray" title="上下文管理器">上下文管理器</a> · <a href="javascript:;" class="aLightGray" title="Python">Python</a> <a href="javascript:;" class="aLightGray" title="上下文管理器">上下文管理器</a> <a href="javascript:;" class="aLightGray" title="标准库">标准库</a> <a href="javascript:;" class="aLightGray" title="资源清理">资源清理</a> <a href="javascript:;" class="aLightGray" title="contextlib">contextlib</a> <a href="javascript:;" class="aLightGray" title="ExitStack">ExitStack</a> </span> </dd> <dt class="lineOverflow"> <a href="/article/620084.html" class="aBlack" target="_blank" title="Python contextlib 资源清理配方:把 try/finally 收进上下文管理器">Python contextlib 资源清理配方:把 try/finally 收进上下文管理器</a> </dt> <dd class="cont2"> <span><i class="view"></i>429浏览</span> <span class="collectBtn user_collection" data-id="620084" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/620077.html" class="img_box" title="Python sched 定时任务小实验:注册任务、轮询运行和失败重试"> <img src="/uploads/20260629/1782699574-python-sched-register-flow.webp" onerror="this.src='/assets/images/moren/morentu.png'" alt="Python sched 定时任务小实验:注册任务、轮询运行和失败重试"> </a> <dl> <dd class="cont1"> <span> <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> · <a href="/articlelist/86_new_0_1.html" class="aLightGray" title="python教程">python教程</a>   |  18小时前  |   <a href="/articletag/172_new_0_1.html" class="aLightGray" title="标准库">标准库</a> · <a href="/articletag/214_new_0_1.html" class="aLightGray" title="定时任务">定时任务</a> · <a href="/articletag/39719_new_0_1.html" class="aLightGray" title="Python教程">Python教程</a> · <a href="/articletag/39792_new_0_1.html" class="aLightGray" title="自动化脚本">自动化脚本</a> · <a href="javascript:;" class="aLightGray" title="Python">Python</a> <a href="javascript:;" class="aLightGray" title="定时任务">定时任务</a> <a href="javascript:;" class="aLightGray" title="失败重试">失败重试</a> <a href="javascript:;" class="aLightGray" title="标准库">标准库</a> <a href="javascript:;" class="aLightGray" title="sched">sched</a> <a href="javascript:;" class="aLightGray" title="本地调度器">本地调度器</a> </span> </dd> <dt class="lineOverflow"> <a href="/article/620077.html" class="aBlack" target="_blank" title="Python sched 定时任务小实验:注册任务、轮询运行和失败重试">Python sched 定时任务小实验:注册任务、轮询运行和失败重试</a> </dt> <dd class="cont2"> <span><i class="view"></i>432浏览</span> <span class="collectBtn user_collection" data-id="620077" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/620072.html" class="img_box" title="Python 读取大文件内存飙升复盘:从 read() 一次读入到分块迭代修复"> <img src="/uploads/20260627/1782575816-python-large-file-memory-timeline.webp" onerror="this.src='/assets/images/moren/morentu.png'" alt="Python 读取大文件内存飙升复盘:从 read() 一次读入到分块迭代修复"> </a> <dl> <dd class="cont1"> <span> <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> · <a href="/articlelist/86_new_0_1.html" class="aLightGray" title="python教程">python教程</a>   |  2天前  |   <a href="/articletag/16_new_0_1.html" class="aLightGray" title="文件处理">文件处理</a> · <a href="/articletag/39694_new_0_1.html" class="aLightGray" title="内存优化">内存优化</a> · <a href="/articletag/39719_new_0_1.html" class="aLightGray" title="Python教程">Python教程</a> · <a href="/articletag/40016_new_0_1.html" class="aLightGray" title="故障复盘">故障复盘</a> · <a href="javascript:;" class="aLightGray" title="Python">Python</a> <a href="javascript:;" class="aLightGray" title="内存优化">内存优化</a> <a href="javascript:;" class="aLightGray" title="文件处理">文件处理</a> <a href="javascript:;" class="aLightGray" title="read">read</a> <a href="javascript:;" class="aLightGray" title="大文件读取">大文件读取</a> <a href="javascript:;" class="aLightGray" title="分块读取">分块读取</a> </span> </dd> <dt class="lineOverflow"> <a href="/article/620072.html" class="aBlack" target="_blank" title="Python 读取大文件内存飙升复盘:从 read() 一次读入到分块迭代修复">Python 读取大文件内存飙升复盘:从 read() 一次读入到分块迭代修复</a> </dt> <dd class="cont2"> <span><i class="view"></i>196浏览</span> <span class="collectBtn user_collection" data-id="620072" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/620070.html" class="img_box" title="Python logging 日志重复打印排查:为什么一条记录输出了两遍"> <img src="/uploads/20260627/1782573431-python-logging-duplicate-trace.webp" onerror="this.src='/assets/images/moren/morentu.png'" alt="Python logging 日志重复打印排查:为什么一条记录输出了两遍"> </a> <dl> <dd class="cont1"> <span> <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> · <a href="/articlelist/86_new_0_1.html" class="aLightGray" title="python教程">python教程</a>   |  2天前  |   <a href="/articletag/5619_new_0_1.html" class="aLightGray" title="logging">logging</a> · <a href="/articletag/39719_new_0_1.html" class="aLightGray" title="Python教程">Python教程</a> · <a href="/articletag/39745_new_0_1.html" class="aLightGray" title="后端开发">后端开发</a> · <a href="/articletag/40012_new_0_1.html" class="aLightGray" title="日志排查">日志排查</a> · <a href="javascript:;" class="aLightGray" title="Python">Python</a> <a href="javascript:;" class="aLightGray" title="logging">logging</a> <a href="javascript:;" class="aLightGray" title="日志重复">日志重复</a> <a href="javascript:;" class="aLightGray" title="propagate">propagate</a> <a href="javascript:;" class="aLightGray" title="addHandler">addHandler</a> <a href="javascript:;" class="aLightGray" title="basicConfig">basicConfig</a> </span> </dd> <dt class="lineOverflow"> <a href="/article/620070.html" class="aBlack" target="_blank" title="Python logging 日志重复打印排查:为什么一条记录输出了两遍">Python logging 日志重复打印排查:为什么一条记录输出了两遍</a> </dt> <dd class="cont2"> <span><i class="view"></i>324浏览</span> <span class="collectBtn user_collection" data-id="620070" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/620068.html" class="img_box" title="Python 定时任务上云选型:从单机脚本到队列 Worker 的架构决策"> <img src="/uploads/20260627/1782570229-python-task-load-decision.webp" onerror="this.src='/assets/images/moren/morentu.png'" alt="Python 定时任务上云选型:从单机脚本到队列 Worker 的架构决策"> </a> <dl> <dd class="cont1"> <span> <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> · <a href="/articlelist/86_new_0_1.html" class="aLightGray" title="python教程">python教程</a>   |  2天前  |   <a href="/articletag/982_new_0_1.html" class="aLightGray" title="任务调度">任务调度</a> · <a href="/articletag/39719_new_0_1.html" class="aLightGray" title="Python教程">Python教程</a> · <a href="/articletag/39745_new_0_1.html" class="aLightGray" title="后端开发">后端开发</a> · <a href="/articletag/40010_new_0_1.html" class="aLightGray" title="云架构">云架构</a> · <a href="javascript:;" class="aLightGray" title="Python">Python</a> <a href="javascript:;" class="aLightGray" title="任务调度">任务调度</a> <a href="javascript:;" class="aLightGray" title="定时任务">定时任务</a> <a href="javascript:;" class="aLightGray" title="云架构">云架构</a> <a href="javascript:;" class="aLightGray" title="队列">队列</a> <a href="javascript:;" class="aLightGray" title="Worker">Worker</a> </span> </dd> <dt class="lineOverflow"> <a href="/article/620068.html" class="aBlack" target="_blank" title="Python 定时任务上云选型:从单机脚本到队列 Worker 的架构决策">Python 定时任务上云选型:从单机脚本到队列 Worker 的架构决策</a> </dt> <dd class="cont2"> <span><i class="view"></i>435浏览</span> <span class="collectBtn user_collection" data-id="620068" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/620057.html" class="img_box" title="Python requests 请求总是卡住?timeout、重试和错误处理配方"> <img src="/uploads/20260627/1782554260-python-requests-retry-wrapper.webp" onerror="this.src='/assets/images/moren/morentu.png'" alt="Python requests 请求总是卡住?timeout、重试和错误处理配方"> </a> <dl> <dd class="cont1"> <span> <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> · <a href="/articlelist/86_new_0_1.html" class="aLightGray" title="python教程">python教程</a>   |  2天前  |   <a href="/articletag/2337_new_0_1.html" class="aLightGray" title="python">python</a> · <a href="/articletag/14185_new_0_1.html" class="aLightGray" title="requests">requests</a> · <a href="/articletag/39789_new_0_1.html" class="aLightGray" title="接口调试">接口调试</a> · <a href="/articletag/40005_new_0_1.html" class="aLightGray" title="网络请求">网络请求</a> · <a href="javascript:;" class="aLightGray" title="Python">Python</a> <a href="javascript:;" class="aLightGray" title="重试">重试</a> <a href="javascript:;" class="aLightGray" title="Requests">Requests</a> <a href="javascript:;" class="aLightGray" title="timeout">timeout</a> <a href="javascript:;" class="aLightGray" title="HTTP接口">HTTP接口</a> </span> </dd> <dt class="lineOverflow"> <a href="/article/620057.html" class="aBlack" target="_blank" title="Python requests 请求总是卡住?timeout、重试和错误处理配方">Python requests 请求总是卡住?timeout、重试和错误处理配方</a> </dt> <dd class="cont2"> <span><i class="view"></i>478浏览</span> <span class="collectBtn user_collection" data-id="620057" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/620041.html" class="img_box" title="Python asyncio 超时后任务还在跑排查:从 wait_for 到取消清理"> <img src="/uploads/20260620/1781943945-python-asyncio-cancel-fix.webp" onerror="this.src='/assets/images/moren/morentu.png'" alt="Python asyncio 超时后任务还在跑排查:从 wait_for 到取消清理"> </a> <dl> <dd class="cont1"> <span> <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> · <a href="/articlelist/86_new_0_1.html" class="aLightGray" title="python教程">python教程</a>   |  1星期前  |   <a href="/articletag/5173_new_0_1.html" class="aLightGray" title="异步编程">异步编程</a> · <a href="/articletag/39699_new_0_1.html" class="aLightGray" title="后端工程">后端工程</a> · <a href="/articletag/39719_new_0_1.html" class="aLightGray" title="Python教程">Python教程</a> · <a href="/articletag/39720_new_0_1.html" class="aLightGray" title="asyncio">asyncio</a> · <a href="/articletag/39984_new_0_1.html" class="aLightGray" title="超时排查">超时排查</a> · <a href="javascript:;" class="aLightGray" title="Python">Python</a> <a href="javascript:;" class="aLightGray" title="超时控制">超时控制</a> <a href="javascript:;" class="aLightGray" title="asyncio">asyncio</a> <a href="javascript:;" class="aLightGray" title="任务取消">任务取消</a> <a href="javascript:;" class="aLightGray" title="wait_for">wait_for</a> <a href="javascript:;" class="aLightGray" title="异步清理">异步清理</a> </span> </dd> <dt class="lineOverflow"> <a href="/article/620041.html" class="aBlack" target="_blank" title="Python asyncio 超时后任务还在跑排查:从 wait_for 到取消清理">Python asyncio 超时后任务还在跑排查:从 wait_for 到取消清理</a> </dt> <dd class="cont2"> <span><i class="view"></i>320浏览</span> <span class="collectBtn user_collection" data-id="620041" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/620033.html" class="img_box" title="Python 配置加载工作流:从环境变量到 JSON 合并和启动前检查"> <img src="/uploads/20260618/1781758995-python-config-check-flow.webp" onerror="this.src='/assets/images/moren/morentu.png'" alt="Python 配置加载工作流:从环境变量到 JSON 合并和启动前检查"> </a> <dl> <dd class="cont1"> <span> <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> · <a href="/articlelist/86_new_0_1.html" class="aLightGray" title="python教程">python教程</a>   |  1星期前  |   <a href="/articletag/307_new_0_1.html" class="aLightGray" title="JSON">JSON</a> · <a href="/articletag/377_new_0_1.html" class="aLightGray" title="配置管理">配置管理</a> · <a href="/articletag/1809_new_0_1.html" class="aLightGray" title="环境变量">环境变量</a> · <a href="/articletag/39699_new_0_1.html" class="aLightGray" title="后端工程">后端工程</a> · <a href="/articletag/39719_new_0_1.html" class="aLightGray" title="Python教程">Python教程</a> · <a href="javascript:;" class="aLightGray" title="Python">Python</a> <a href="javascript:;" class="aLightGray" title="环境变量">环境变量</a> <a href="javascript:;" class="aLightGray" title="JSON">JSON</a> <a href="javascript:;" class="aLightGray" title="配置加载">配置加载</a> <a href="javascript:;" class="aLightGray" title="默认值合并">默认值合并</a> <a href="javascript:;" class="aLightGray" title="启动检查">启动检查</a> </span> </dd> <dt class="lineOverflow"> <a href="/article/620033.html" class="aBlack" target="_blank" title="Python 配置加载工作流:从环境变量到 JSON 合并和启动前检查">Python 配置加载工作流:从环境变量到 JSON 合并和启动前检查</a> </dt> <dd class="cont2"> <span><i class="view"></i>321浏览</span> <span class="collectBtn user_collection" data-id="620033" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/620004.html" class="img_box" title="Python JSONL 大文件分批处理:从流式读取到失败样本报告"> <img src="/uploads/20260617/1781660378-python-jsonl-check.webp" onerror="this.src='/assets/images/moren/morentu.png'" alt="Python JSONL 大文件分批处理:从流式读取到失败样本报告"> </a> <dl> <dd class="cont1"> <span> <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> · <a href="/articlelist/86_new_0_1.html" class="aLightGray" title="python教程">python教程</a>   |  1星期前  |   <a href="/articletag/3145_new_0_1.html" class="aLightGray" title="数据处理">数据处理</a> · <a href="/articletag/11574_new_0_1.html" class="aLightGray" title="jsonl">jsonl</a> · <a href="/articletag/39719_new_0_1.html" class="aLightGray" title="Python教程">Python教程</a> · <a href="javascript:;" class="aLightGray" title="Python">Python</a> <a href="javascript:;" class="aLightGray" title="数据清洗">数据清洗</a> <a href="javascript:;" class="aLightGray" title="流式读取">流式读取</a> <a href="javascript:;" class="aLightGray" title="大文件处理">大文件处理</a> <a href="javascript:;" class="aLightGray" title="JSONL">JSONL</a> </span> </dd> <dt class="lineOverflow"> <a href="/article/620004.html" class="aBlack" target="_blank" title="Python JSONL 大文件分批处理:从流式读取到失败样本报告">Python JSONL 大文件分批处理:从流式读取到失败样本报告</a> </dt> <dd class="cont2"> <span><i class="view"></i>365浏览</span> <span class="collectBtn user_collection" data-id="620004" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/620000.html" class="img_box" title="Python dataclass 默认值完整工作流:从可变默认值到 default_factory"> <img src="/uploads/20260616/1781600807-python-dataclass-checklist.webp" onerror="this.src='/assets/images/moren/morentu.png'" alt="Python dataclass 默认值完整工作流:从可变默认值到 default_factory"> </a> <dl> <dd class="cont1"> <span> <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> · <a href="/articlelist/86_new_0_1.html" class="aLightGray" title="python教程">python教程</a>   |  1星期前  |   <a href="/articletag/1974_new_0_1.html" class="aLightGray" title="默认值">默认值</a> · <a href="/articletag/2337_new_0_1.html" class="aLightGray" title="python">python</a> · <a href="/articletag/4829_new_0_1.html" class="aLightGray" title="数据建模">数据建模</a> · <a href="/articletag/39795_new_0_1.html" class="aLightGray" title="dataclass">dataclass</a> · <a href="/articletag/39936_new_0_1.html" class="aLightGray" title="default_factory">default_factory</a> · <a href="/articletag/39937_new_0_1.html" class="aLightGray" title="field">field</a> · <a href="javascript:;" class="aLightGray" title="Python">Python</a> <a href="javascript:;" class="aLightGray" title="数据类">数据类</a> <a href="javascript:;" class="aLightGray" title="Field">Field</a> <a href="javascript:;" class="aLightGray" title="可变默认值">可变默认值</a> <a href="javascript:;" class="aLightGray" title="dataclass">dataclass</a> <a href="javascript:;" class="aLightGray" title="default_factory">default_factory</a> </span> </dd> <dt class="lineOverflow"> <a href="/article/620000.html" class="aBlack" target="_blank" title="Python dataclass 默认值完整工作流:从可变默认值到 default_factory">Python dataclass 默认值完整工作流:从可变默认值到 default_factory</a> </dt> <dd class="cont2"> <span><i class="view"></i>228浏览</span> <span class="collectBtn user_collection" data-id="620000" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/619997.html" class="img_box" title="Python requests 请求一直卡住怎么办:timeout、状态码和重试一步步排查"> <img src="/uploads/20260616/1781597840-python-requests-retry-solution.webp" onerror="this.src='/assets/images/moren/morentu.png'" alt="Python requests 请求一直卡住怎么办:timeout、状态码和重试一步步排查"> </a> <dl> <dd class="cont1"> <span> <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> · <a href="/articlelist/86_new_0_1.html" class="aLightGray" title="python教程">python教程</a>   |  1星期前  |   <a href="/articletag/457_new_0_1.html" class="aLightGray" title="重试机制">重试机制</a> · <a href="/articletag/8485_new_0_1.html" class="aLightGray" title="timeout">timeout</a> · <a href="/articletag/14185_new_0_1.html" class="aLightGray" title="requests">requests</a> · <a href="/articletag/39719_new_0_1.html" class="aLightGray" title="Python教程">Python教程</a> · <a href="/articletag/39789_new_0_1.html" class="aLightGray" title="接口调试">接口调试</a> · <a href="javascript:;" class="aLightGray" title="Python">Python</a> <a href="javascript:;" class="aLightGray" title="Http请求">Http请求</a> <a href="javascript:;" class="aLightGray" title="Requests">Requests</a> <a href="javascript:;" class="aLightGray" title="timeout">timeout</a> <a href="javascript:;" class="aLightGray" title="retry">retry</a> <a href="javascript:;" class="aLightGray" title="接口排查">接口排查</a> </span> </dd> <dt class="lineOverflow"> <a href="/article/619997.html" class="aBlack" target="_blank" title="Python requests 请求一直卡住怎么办:timeout、状态码和重试一步步排查">Python requests 请求一直卡住怎么办:timeout、状态码和重试一步步排查</a> </dt> <dd class="cont2"> <span><i class="view"></i>330浏览</span> <span class="collectBtn user_collection" data-id="619997" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/619959.html" class="img_box" title="Python logging 日志重复打印怎么办:从 Handler 叠加到 propagate 一步步排查"> <img src="/uploads/20260615/1781501759-log-duplicate-scene.webp" onerror="this.src='/assets/images/moren/morentu.png'" alt="Python logging 日志重复打印怎么办:从 Handler 叠加到 propagate 一步步排查"> </a> <dl> <dd class="cont1"> <span> <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> · <a href="/articlelist/86_new_0_1.html" class="aLightGray" title="python教程">python教程</a>   |  2星期前  |   <a href="/articletag/51_new_0_1.html" class="aLightGray" title="日志">日志</a> · <a href="/articletag/858_new_0_1.html" class="aLightGray" title="排查">排查</a> · <a href="/articletag/2337_new_0_1.html" class="aLightGray" title="python">python</a> · <a href="/articletag/5619_new_0_1.html" class="aLightGray" title="logging">logging</a> · <a href="javascript:;" class="aLightGray" title="Python">Python</a> <a href="javascript:;" class="aLightGray" title="logging">logging</a> <a href="javascript:;" class="aLightGray" title="handler">handler</a> <a href="javascript:;" class="aLightGray" title="日志排查">日志排查</a> <a href="javascript:;" class="aLightGray" title="日志重复">日志重复</a> <a href="javascript:;" class="aLightGray" title="propagate">propagate</a> </span> </dd> <dt class="lineOverflow"> <a href="/article/619959.html" class="aBlack" target="_blank" title="Python logging 日志重复打印怎么办:从 Handler 叠加到 propagate 一步步排查">Python logging 日志重复打印怎么办:从 Handler 叠加到 propagate 一步步排查</a> </dt> <dd class="cont2"> <span><i class="view"></i>299浏览</span> <span class="collectBtn user_collection" data-id="619959" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> </ul> </div> </div> <div class="mainRight"> <!-- 右侧广告位banner --> <div class="rightContBox" style="margin-top: 0px;"> <div class="rightTit"> <a href="/courselist.html" class="more" title="查看更多">查看更多<i class="iconfont"></i></a> <div class="tit lineOverflow">课程推荐</div> </div> <ul class="lessonRecomRList"> <li> <a href="/course/9.html" class="img_box" target="_blank" title="前端进阶之JavaScript设计模式"> <img src="/uploads/20221222/52fd0f23a454c71029c2c72d206ed815.jpg" onerror="this.onerror='',this.src='/assets/images/moren/morentu.png'" alt="前端进阶之JavaScript设计模式"> </a> <dl> <dt class="lineTwoOverflow"><a href="/course/9.html" target="_blank" class="aBlack" title="前端进阶之JavaScript设计模式">前端进阶之JavaScript设计模式</a></dt> <dd class="cont1 lineTwoOverflow"> 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。 </dd> <dd class="cont2">543次学习</dd> </dl> </li> <li> <a href="/course/2.html" class="img_box" target="_blank" title="GO语言核心编程课程"> <img src="/uploads/20221221/634ad7404159bfefc6a54a564d437b5f.png" onerror="this.onerror='',this.src='/assets/images/moren/morentu.png'" alt="GO语言核心编程课程"> </a> <dl> <dt class="lineTwoOverflow"><a href="/course/2.html" target="_blank" class="aBlack" title="GO语言核心编程课程">GO语言核心编程课程</a></dt> <dd class="cont1 lineTwoOverflow"> 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。 </dd> <dd class="cont2">516次学习</dd> </dl> </li> <li> <a href="/course/74.html" class="img_box" target="_blank" title="简单聊聊mysql8与网络通信"> <img src="/uploads/20240103/bad35fe14edbd214bee16f88343ac57c.png" onerror="this.onerror='',this.src='/assets/images/moren/morentu.png'" alt="简单聊聊mysql8与网络通信"> </a> <dl> <dt class="lineTwoOverflow"><a href="/course/74.html" target="_blank" class="aBlack" title="简单聊聊mysql8与网络通信">简单聊聊mysql8与网络通信</a></dt> <dd class="cont1 lineTwoOverflow"> 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让 </dd> <dd class="cont2">500次学习</dd> </dl> </li> <li> <a href="/course/57.html" class="img_box" target="_blank" title="JavaScript正则表达式基础与实战"> <img src="/uploads/20221226/bbe4083bb3cb0dd135fb02c31c3785fb.jpg" onerror="this.onerror='',this.src='/assets/images/moren/morentu.png'" alt="JavaScript正则表达式基础与实战"> </a> <dl> <dt class="lineTwoOverflow"><a href="/course/57.html" target="_blank" class="aBlack" title="JavaScript正则表达式基础与实战">JavaScript正则表达式基础与实战</a></dt> <dd class="cont1 lineTwoOverflow"> 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。 </dd> <dd class="cont2">487次学习</dd> </dl> </li> <li> <a href="/course/28.html" class="img_box" target="_blank" title="从零制作响应式网站—Grid布局"> <img src="/uploads/20221223/ac110f88206daeab6c0cf38ebf5fe9ed.jpg" onerror="this.onerror='',this.src='/assets/images/moren/morentu.png'" alt="从零制作响应式网站—Grid布局"> </a> <dl> <dt class="lineTwoOverflow"><a href="/course/28.html" target="_blank" class="aBlack" title="从零制作响应式网站—Grid布局">从零制作响应式网站—Grid布局</a></dt> <dd class="cont1 lineTwoOverflow"> 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。 </dd> <dd class="cont2">485次学习</dd> </dl> </li> </ul> </div> <div class="rightContBox"> <div class="rightTit"> <a href="/ai.html" class="more" title="查看更多">查看更多<i class="iconfont"></i></a> <div class="tit lineOverflow">AI推荐</div> </div> <ul class="lessonRecomRList"> <li> <a href="/ai/13109.html" target="_blank" title="ljg-skills - "Prompt之神"李继刚开源的 AI 技能集" class="img_box"> <img src="/uploads/ai/20260616/ljg-skills-icon-8bbe1468e5.png" onerror="this.onerror='',this.src='/assets/images/moren/morentu.png'" alt="ljg-skills - "Prompt之神"李继刚开源的 AI 技能集" style="object-fit:cover;width:100%;height:100%;"> </a> <dl> <dt class="lineTwoOverflow"><a href="/ai/13109.html" class="aBlack" target="_blank" title="ljg-skills">ljg-skills</a></dt> <dd class="cont1 lineTwoOverflow"> ljg-skills 是李继刚开源的 AI 技能与提示词集合,面向大模型使用者整理了一批可复用的 prompt、角色设定和任务技能模板,适合用于学习提示词设计、搭建个人 AI 工作流和沉淀团队常用智能体能力。 </dd> <dd class="cont2">2879次使用</dd> </dl> </li> <li> <a href="/ai/13108.html" target="_blank" title="MELO音乐 - AI 音乐生成平台,支持多模态创作能力" class="img_box"> <img src="/uploads/ai/20260616/melo-icon-10bf590762.png" onerror="this.onerror='',this.src='/assets/images/moren/morentu.png'" alt="MELO音乐 - AI 音乐生成平台,支持多模态创作能力" style="object-fit:cover;width:100%;height:100%;"> </a> <dl> <dt class="lineTwoOverflow"><a href="/ai/13108.html" class="aBlack" target="_blank" title="MELO音乐">MELO音乐</a></dt> <dd class="cont1 lineTwoOverflow"> MELO音乐是一站式AI视频与音乐制作助手,对标suno, udio的高品质体验。提供伴奏生成、原创写词、无损导出、哼唱识曲、混音变声等全套音频与短视频编辑工具。无论是流行Kpop、电音说唱、民谣古风、摇滚儿歌还是商用轻音乐,MELO为你免费谱曲,轻松做同款! </dd> <dd class="cont2">2657次使用</dd> </dl> </li> <li> <a href="/ai/13107.html" target="_blank" title="UniScribe - AI 免费在线音视频转文字平台" class="img_box"> <img src="/uploads/ai/20260616/uniscribe-icon-3c88366a15.png" onerror="this.onerror='',this.src='/assets/images/moren/morentu.png'" alt="UniScribe - AI 免费在线音视频转文字平台" style="object-fit:cover;width:100%;height:100%;"> </a> <dl> <dt class="lineTwoOverflow"><a href="/ai/13107.html" class="aBlack" target="_blank" title="UniScribe">UniScribe</a></dt> <dd class="cont1 lineTwoOverflow"> UniScribe 是一款 AI 音视频转文字与内容整理工具,支持上传音频、视频文件或粘贴 YouTube 链接,自动生成转写文本、摘要、思维导图和关键问题,并支持多格式导出,适合会议记录、课程学习、访谈整理和内容创作复盘。 </dd> <dd class="cont2">2601次使用</dd> </dl> </li> <li> <a href="/ai/13106.html" target="_blank" title="剧云 - 免费 AI 智能中文剧本创作平台" class="img_box"> <img src="/uploads/ai/20260615/d36c7176-icon-2b0cd581ce.png" onerror="this.onerror='',this.src='/assets/images/moren/morentu.png'" alt="剧云 - 免费 AI 智能中文剧本创作平台" style="object-fit:cover;width:100%;height:100%;"> </a> <dl> <dt class="lineTwoOverflow"><a href="/ai/13106.html" class="aBlack" target="_blank" title="剧云">剧云</a></dt> <dd class="cont1 lineTwoOverflow"> 剧云是专业中文剧本创作平台,安全稳定运行十余年,集成AI编剧、剧本医生审核、人物小传、剧情关系图、大纲编写、多人协作、Word导入导出、版权管控功能,数据安全防护,轻松高效创作剧本。 </dd> <dd class="cont2">2833次使用</dd> </dl> </li> <li> <a href="/ai/13105.html" target="_blank" title="万象有声 - AI 一站式有声内容创作平台" class="img_box"> <img src="/uploads/ai/20260615/50267bac-icon-c146b001b5.png" onerror="this.onerror='',this.src='/assets/images/moren/morentu.png'" alt="万象有声 - AI 一站式有声内容创作平台" style="object-fit:cover;width:100%;height:100%;"> </a> <dl> <dt class="lineTwoOverflow"><a href="/ai/13105.html" class="aBlack" target="_blank" title="万象有声">万象有声</a></dt> <dd class="cont1 lineTwoOverflow"> 万象有声,一个专为有声创作者打造的新一代智能有声内容创作平台。平台提供专业的智能拆章、智能画本编辑、AI配音、AI生成音效、后期制作、智能对轨、智能审听等有声创作全流程工具,可以帮助创作者高效、低成本创作出引人入胜的有声作品。立即体验,让有声书制作更简单! </dd> <dd class="cont2">2776次使用</dd> </dl> </li> </ul> </div> <!-- 相关文章 --> <div class="rightContBox"> <div class="rightTit"> <a href="/articlelist.html" class="more" title="查看更多">查看更多<i class="iconfont"></i></a> <div class="tit lineOverflow">相关文章</div> </div> <ul class="aboutArticleRList"> <li> <dl> <dt class="lineTwoOverflow"><a href="/article/616032.html" class="aBlack" title="Python监控网页状态:requests异常处理实战">Python监控网页状态:requests异常处理实战</a></dt> <dd> <span class="left">2026-05-29</span> <span class="right">501浏览</span> </dd> </dl> </li> <li> <dl> <dt class="lineTwoOverflow"><a href="/article/612350.html" class="aBlack" title="TensorFlow模型部署为API的TF Serving方法">TensorFlow模型部署为API的TF Serving方法</a></dt> <dd> <span class="left">2026-05-26</span> <span class="right">501浏览</span> </dd> </dl> </li> <li> <dl> <dt class="lineTwoOverflow"><a href="/article/602477.html" class="aBlack" title="Python字符串编码转换:encode与decode详解">Python字符串编码转换:encode与decode详解</a></dt> <dd> <span class="left">2026-05-16</span> <span class="right">501浏览</span> </dd> </dl> </li> <li> <dl> <dt class="lineTwoOverflow"><a href="/article/602019.html" class="aBlack" title="TensorFlow裁剪无用算子方法详解">TensorFlow裁剪无用算子方法详解</a></dt> <dd> <span class="left">2026-05-15</span> <span class="right">501浏览</span> </dd> </dl> </li> <li> <dl> <dt class="lineTwoOverflow"><a href="/article/588986.html" class="aBlack" title="httpx 如何设置代理认证(Proxy-Authorization)">httpx 如何设置代理认证(Proxy-Authorization)</a></dt> <dd> <span class="left">2026-05-05</span> <span class="right">501浏览</span> </dd> </dl> </li> </ul> </div> </div> </div> <div class="footer"> <div class="footerIn"> <div class="footLeft"> <div class="linkBox"> <a href="/about/1.html" target="_blank" class="aBlack" title="关于我们">关于我们</a> <a href="/about/5.html" target="_blank" class="aBlack" title="免责声明">免责声明</a> <a href="#" class="aBlack" title="意见反馈">意见反馈</a> <a href="/about/2.html" class="aBlack" target="_blank" title="联系我们">联系我们</a> <a href="/send.html" class="aBlack" title="广告合作">内容提交</a> <a href="/manual/go/" target="_blank" class="aBlack" title="手册">手册</a> </div> <div class="footTip">Golang学习网:公益在线Go学习平台,帮助Go学习者快速成长!</div> <div class="shareBox"> <span><i class="qq"></i>技术交流群</span> </div> <div class="copyRight"> Copyright 2023 http://www.17golang.com/ All Rights Reserved | <a href="https://beian.miit.gov.cn/" target="_blank" title="备案">苏ICP备2023003363号-1</a> </div> </div> <div class="footRight"> <ul class="encodeList"> <li> <div class="encodeImg"> <img src="/assets/examples/qrcode_for_gh.jpg" alt="Golang学习网"> </div> <div class="tit">关注公众号</div> <div class="tip">Golang学习网</div> </li> <div class="clear"></div> </ul> </div> <div class="clear"></div> </div> </div> <!-- 微信登录弹窗 --> <style> .popupBg .n-error{ color: red; } </style> <div class="popupBg"> <div class="loginBoxBox"> <div class="imgbg"> <img src="/assets/images/leftlogo.jpg" alt=""> </div> <!-- 微信登录 --> <div class="loginInfo encodeLogin" style="display: none;"> <div class="closeIcon" onclick="$('.popupBg').hide();"></div> <div class="changeLoginType cursorPointer create_wxqrcode" onclick="$('.loginInfo').hide();$('.passwordLogin').show();"> <div class="tip">密码登录在这里</div> </div> <div class="encodeInfo"> <div class="tit"><i></i> 微信扫码登录或注册</div> <div class="encodeImg"> <span id="wx_login_qrcode"><img src="/assets/examples/code.png" alt="二维码"></span> <!-- <div class="refreshBox"> <p>二维码失效</p> <button type="button" class="create_wxqrcode">刷新1111</button> </div> --> </div> <div class="tip">打开微信扫一扫,快速登录/注册</div> </div> <div class="beforeLoginTip">登录即同意 <a href="#" class="aBlue" title="用户协议">用户协议</a> 和 <a href="#" class="aBlue" title="隐私政策">隐私政策</a></div> </div> <!-- 密码登录 --> <div class="loginInfo passwordLogin"> <div class="closeIcon" onclick="$('.popupBg').hide();"></div> <div class="changeLoginType cursorPointer create_wxqrcode" onclick="$('.loginInfo').hide();$('.encodeLogin').show();"> <div class="tip">微信登录更方便</div> </div> <div class="passwordInfo"> <ul class="logintabs selfTabMenu"> <li class="selfTabItem loginFormLi curr">密码登录</li> <li class="selfTabItem registerFormBox ">注册账号</li> </ul> <div class="selfTabContBox"> <div class="selfTabCont loginFormBox" style="display: block;"> <form name="form" id="login-form" class="form-vertical form" method="POST" action="/index/user/login"> <input type="hidden" name="url" value="//17golang.com/article/579446.html"/> <input type="hidden" name="__token__" value="05ae609140d2105265b0aba3495ea70d" /> <div class="form-group" style="height:70px;"> <input class="form-control" id="account" type="text" name="account" value="" data-rule="required" placeholder="邮箱/用户名" autocomplete="off"> </div> <div class="form-group" style="height:70px;"> <input class="form-control" id="password" type="password" name="password" data-rule="required;password" placeholder="密码" autocomplete="off"> </div> <div class="codeBox" style="height:70px;"> <div class="form-group" style="height:70px; width:205px; float: left;"> <input type="text" name="captcha" class="form-control" placeholder="验证码" data-rule="required;length(4)" /> </div> <span class="input-group-btn" style="padding:0;border:none;"> <img src="/captcha.html" width="100" height="45" onclick="this.src = '/captcha.html?r=' + Math.random();"/> </span> </div> <div class="other"> <a href="#" class="forgetPwd aGray" onclick="$('.loginInfo').hide();$('.passwordForget').show();" title="忘记密码">忘记密码</a> </div> <div class="loginBtn mt25"> <button type="submit">登录</button> </div> </form> </div> <div class="selfTabCont registerFormBox" style="display: none;"> <form name="form1" id="register-form" class="form-vertical form" method="POST" action="/index/user/register"> <input type="hidden" name="invite_user_id" value="0"/> <input type="hidden" name="url" value="//17golang.com/article/579446.html"/> <input type="hidden" name="__token__" value="05ae609140d2105265b0aba3495ea70d" /> <div class="form-group" style="height:70px;"> <input type="text" name="email" id="email2" data-rule="required;email" class="form-control" placeholder="邮箱"> </div> <div class="form-group" style="height:70px;"> <input type="text" id="username" name="username" data-rule="required;username" class="form-control" placeholder="用户名必须3-30个字符"> </div> <div class="form-group" style="height:70px;"> <input type="password" id="password2" name="password" data-rule="required;password" class="form-control" placeholder="密码必须6-30个字符"> </div> <div class="codeBox" style="height:70px;"> <div class="form-group" style="height:70px; width:205px; float: left;"> <input type="text" name="captcha" class="form-control" placeholder="验证码" data-rule="required;length(4)" /> </div> <span class="input-group-btn" style="padding:0;border:none;"> <img src="/captcha.html" width="100" height="45" onclick="this.src = '/captcha.html?r=' + Math.random();"/> </span> </div> <div class="loginBtn"> <button type="submit">注册</button> </div> </form> </div> </div> </div> <div class="beforeLoginTip">登录即同意 <a href="https://www.17golang.com/about/3.html" target="_blank" class="aBlue" title="用户协议">用户协议</a> 和 <a href="https://www.17golang.com/about/4.html" target="_blank" class="aBlue" title="隐私政策">隐私政策</a></div> </div> <!-- 重置密码 --> <div class="loginInfo passwordForget"> <div class="closeIcon" onclick="$('.popupBg').hide();"></div> <div class="returnLogin cursorPointer" onclick="$('.passwordForget').hide();$('.passwordLogin').show();">返回登录</div> <div class="passwordInfo"> <ul class="logintabs selfTabMenu"> <li class="selfTabItem">重置密码</li> </ul> <div class="selfTabContBox"> <div class="selfTabCont"> <form id="resetpwd-form" class="form-horizontal form-layer nice-validator n-default n-bootstrap form" method="POST" action="/api/user/resetpwd.html" novalidate="novalidate"> <div style="height:70px;"> <input type="text" class="form-control" id="email" name="email" value="" placeholder="输入邮箱" aria-invalid="true"> </div> <div class="codeBox" style="height:70px;"> <div class="form-group" style="height:70px; width:205px; float: left;"> <input type="text" name="captcha" class="form-control" placeholder="验证码" /> </div> <span class="input-group-btn" style="padding:0;border:none;"> <a href="javascript:;" class="btn btn-primary btn-captcha cursorPointer" style="background: #2080F8; border-radius: 4px; color: #fff; padding: 12px; position: absolute;" data-url="/api/ems/send.html" data-type="email" data-event="resetpwd">发送验证码</a> </span> </div> <input type="password" class="form-control" id="newpassword" name="newpassword" value="" placeholder="请输入6-18位密码"> <div class="loginBtn mt25"> <button type="submit">重置密码</button> </div> </form> </div> </div> </div> </div> </div> </div> <script src="/assets/js/juejin-theme.js?v=20260613b" defer></script> <script> var _hmt = _hmt || []; (function() { var hm = document.createElement("script"); hm.src = "https://hm.baidu.com/hm.js?3dc5666f6478c7bf39cd5c91e597423d"; hm.async = true; var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(hm, s); })(); </script> <script src="/assets/js/frontend/common.js"></script> </body> </html>