当前位置:首页 > 文章列表 > 文章 > 前端 > Flask动态传参:JS实现URL参数传递教程

Flask动态传参:JS实现URL参数传递教程

2025-09-01 21:48:43 0浏览 收藏

本文详细介绍了在Flask Web应用中,如何利用JavaScript动态地向后端传递URL参数,以实现灵活的前后端数据交互。针对Jinja模板在服务器端渲染以及JavaScript在客户端执行的特性,提出了一种结合Jinja生成基础URL和JavaScript拼接动态参数的有效策略。通过代码示例,演示了如何使用Jinja的`url_for`生成静态URL部分,再利用JavaScript获取动态数据并拼接成完整的URL,从而避免了直接在Jinja中使用JavaScript变量导致的错误。同时,强调了URL编码的重要性,并对GET与POST请求的选择、数据敏感性以及错误处理等方面提供了建议,助力开发者构建更健壮的Flask应用。

Flask应用中通过JavaScript动态传递URL参数的教程

本教程详细阐述了在Flask应用中,如何通过JavaScript动态地将变量数据作为URL参数传递给后端路由。针对Jinja模板在服务器端渲染与JavaScript在客户端执行的差异,本文提供了一种结合Jinja生成基础URL和JavaScript拼接动态参数的有效方法,并附带代码示例,帮助开发者实现前后端数据的无缝交互。

1. 理解Jinja与JavaScript的执行上下文

在Web开发中,理解服务器端渲染(如Jinja)与客户端脚本(如JavaScript)的执行时机和上下文至关重要。这是许多开发者在尝试将两者结合时遇到的常见困惑的根源。

  • Jinja模板(服务器端渲染):Jinja是Flask框架中用于渲染HTML页面的模板引擎。它在服务器上执行,将动态数据填充到HTML模板中,然后将最终生成的静态HTML、CSS和JavaScript代码发送到客户端浏览器。这意味着,当Jinja处理 {{ ... }} 这样的表达式时,它只能访问服务器端的变量和函数(例如Python变量、Flask的url_for函数),而无法感知或操作客户端的JavaScript变量。

  • JavaScript(客户端脚本):JavaScript在用户的浏览器中执行。它可以在页面加载后动态地修改DOM、响应用户交互、发送异步请求等。JavaScript可以访问和操作HTML中的元素、CSS样式以及自身的变量。

为什么直接使用JavaScript变量在Jinja url_for 中会失败?

考虑以下代码片段:

当Flask服务器处理这个HTML模板时,它会尝试解析 {{ url_for("move_forward", title=data) }}。此时,data 是一个JavaScript变量,对服务器端的Jinja来说是未知的。Jinja不会执行JavaScript代码,因此它无法获取 data 的值,导致渲染错误或生成一个不正确的URL。

为什么硬编码值可以成功?

而以下方式之所以成功:

是因为 "shan" 是一个字符串字面量,Jinja可以直接处理。在服务器端渲染时,{{ url_for("move_forward", title="shan") }} 会被替换成一个具体的URL路径,例如 /move_forward/shan。浏览器接收到的是一个已经完全解析好的URL,JavaScript只是将其赋值给 window.location.href。

2. 动态传递URL参数的解决方案

要解决在JavaScript中动态构造URL并将其传递给Flask路由的问题,我们需要结合两者的优势:让Jinja负责生成URL的静态部分(基础路径),然后由JavaScript负责拼接动态变量

核心思路:

  1. 使用Jinja的url_for函数生成不包含动态参数的基础URL路径
  2. 在JavaScript中,获取这个基础URL,然后将JavaScript变量的值拼接到该URL的末尾。

前端HTML/JavaScript代码示例:




    
    动态URL参数传递


    

点击按钮发送动态数据

后端Flask路由代码示例:

from flask import Flask, render_template, redirect, url_for, request

app = Flask(__name__)

# 假设你的HTML文件名为 index.html
@app.route('/')
def index():
    return render_template('index.html')

# 定义一个Flask路由,它接受一个名为  的路径参数
@app.route("/move_forward/<title>", methods=['GET'])
def move_forward(title):
    """
    接收来自前端的动态title参数。
    """
    print(f"Flask后端接收到的动态参数是: {title}")
    # 在这里可以根据接收到的title进行相应的业务逻辑处理
    # 例如,查询数据库、渲染特定页面等
    return f"成功接收到参数: <b>{title}</b>"

if __name__ == '__main__':
    app.run(debug=True) # 开启调试模式,方便开发</pre><p><strong>工作原理详解:</strong></p><ol><li>当服务器渲染 index.html 时,{{ url_for("move_forward") }} 会被Flask解析并替换为 /move_forward。所以,浏览器接收到的HTML代码中的JavaScript部分会是:<pre class="brush:php;toolbar:false">var baseUrl = '/move_forward';</pre></li><li>当用户点击按钮,sendDynamicData() 函数执行时,JavaScript变量 dynamicValue 的值为 "HelloFromJS"。</li><li>JavaScript代码执行 window.location.href = baseUrl + "/" + dynamicValue;,这会拼接成 /move_forward/HelloFromJS。</li><li>浏览器导航到这个新的URL,即向 /move_forward/HelloFromJS 发送一个GET请求。</li><li>Flask后端匹配到 @app.route("/move_forward/<title>") 这个路由,并将URL中的 HelloFromJS 提取为 title 参数的值,然后传递给 move_forward 函数。</li></ol><h3>3. 注意事项与最佳实践</h3><ul><li><p><strong>URL编码 (encodeURIComponent)</strong>:如果你的JavaScript变量 dynamicValue 可能包含特殊字符(如空格、&、?、/ 等),这些字符在URL中具有特殊含义。为了确保数据能够正确传递和解析,强烈建议在拼接URL之前使用 encodeURIComponent() 函数对动态数据进行编码。</p><pre class="brush:php;toolbar:false">window.location.href = baseUrl + "/" + encodeURIComponent(dynamicValue);</pre><p>Flask会自动对URL路径参数进行解码。</p></li><li><p><strong>数据敏感性</strong>:URL参数(GET请求)通常不适合传递敏感信息,因为它们会显示在浏览器地址栏、服务器日志和浏览器历史记录中。对于敏感或大量数据,应考虑使用POST请求,通过表单提交或AJAX(XMLHttpRequest或Fetch API)将数据放在请求体中发送。</p></li><li><p><strong>GET与POST的选择</strong>:</p><ul><li><strong>GET请求</strong>:适用于获取资源、查询数据,参数通过URL传递,具有幂等性(重复请求不会改变服务器状态)和可缓存性。</li><li><strong>POST请求</strong>:适用于创建、更新资源,参数通过请求体传递,更安全,可发送大量数据。</li></ul></li><li><p><strong>错误处理</strong>:在实际应用中,后端路由应该对接收到的参数进行验证和错误处理,以应对前端可能发送无效或预期之外的数据。</p></li><li><p><strong>前端路由(SPA)</strong>:对于单页应用(SPA),通常会使用前端路由库(如Vue Router、React Router)来管理URL,并结合AJAX与后端API进行数据交互,而非直接通过 window.location.href 改变页面。</p></li></ul><h3>4. 总结</h3><p>通过本教程,我们理解了Flask Jinja模板与JavaScript在执行上下文上的根本区别,并掌握了在Flask应用中通过JavaScript动态传递URL参数的正确方法。关键在于利用Jinja生成URL的静态部分,再由JavaScript在客户端动态拼接变量值。结合URL编码、合理选择请求方法以及必要的错误处理,可以构建出健壮且高效的前后端交互功能。</p><p>到这里,我们也就讲完了《Flask动态传参:JS实现URL参数传递教程》的内容了。个人认为,基础知识的学习和巩固,是为了更好的将其运用到项目中,欢迎关注golang学习网公众号,带你了解更多关于的知识点!</p>                </div>
                <div class="labsList">
                                    </div>
                                <div class="cateBox">
                                        <div class="cateItem">
                        <a href="/article/304087.html" title="Golang指针返回陷阱:变量逃逸与生命周期解析" class="img_box">
                            <img src="/uploads/20250901/175673451968b5a43778a3a.jpg" onerror="this.onerror='',this.src='/assets/images/moren/morentu.png'" alt="Golang指针返回陷阱:变量逃逸与生命周期解析">Golang指针返回陷阱:变量逃逸与生命周期解析                        </a>
                        <dl>
                            <dt class="lineOverflow"><a href="/article/304087.html"  title="Golang指针返回陷阱:变量逃逸与生命周期解析" class="aBlack">上一篇<i></i></a></dt>
                            <dd class="lineTwoOverflow">Golang指针返回陷阱:变量逃逸与生命周期解析</dd>
                        </dl>
                    </div>
                                        <div class="cateItem">
                        <a href="/article/304089.html"  title="FlexClipAI视频制作技巧全解析" class="img_box">
                            <img src="/uploads/20250901/175673456268b5a462d21fa.png" onerror="this.onerror='',this.src='/assets/images/moren/morentu.png'" alt="FlexClipAI视频制作技巧全解析">
                        </a>
                        <dl>
                            <dt class="lineOverflow"><a href="/article/304089.html"  class="aBlack" title="FlexClipAI视频制作技巧全解析">下一篇<i></i></a></dt>
                            <dd class="lineTwoOverflow">FlexClipAI视频制作技巧全解析</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/619691.html" class="img_box" title="CSS数字显示统一技巧,OpenType特性应用方法">
                            <img src="/uploads/20260601/17802914206a1d175ca6b74.jpg" onerror="this.src='/assets/images/moren/morentu.png'" alt="CSS数字显示统一技巧,OpenType特性应用方法">
                        </a>
                        <dl>
                            <dd class="cont1">
                  <span>
                                                                <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> ·
                                                                            <a href="/articlelist/88_new_0_1.html" class="aLightGray" title="前端">前端</a>
                                                       |  5天前  |  

                                                  </span>
                            </dd>
                            <dt class="lineOverflow">
                                <a href="/article/619691.html" class="aBlack" target="_blank" title="CSS数字显示统一技巧,OpenType特性应用方法">CSS数字显示统一技巧,OpenType特性应用方法</a>
                            </dt>
                            <dd class="cont2">
                                <span><i class="view"></i>209浏览</span>
                                <span class="collectBtn user_collection" data-id="619691" data-type="article" title="收藏"><i class="collect"></i>收藏</span>
                            </dd>
                        </dl>
                    </div>
                </li>
                                <li>
                    <div class="contBox">
                        <a href="/article/619689.html" class="img_box" title="PerformanceAPI全生命周期预警指南">
                            <img src="/uploads/20260601/17802913226a1d16faa9805.png" onerror="this.src='/assets/images/moren/morentu.png'" alt="PerformanceAPI全生命周期预警指南">
                        </a>
                        <dl>
                            <dd class="cont1">
                  <span>
                                                                <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> ·
                                                                            <a href="/articlelist/88_new_0_1.html" class="aLightGray" title="前端">前端</a>
                                                       |  5天前  |  

                                                  </span>
                            </dd>
                            <dt class="lineOverflow">
                                <a href="/article/619689.html" class="aBlack" target="_blank" title="PerformanceAPI全生命周期预警指南">PerformanceAPI全生命周期预警指南</a>
                            </dt>
                            <dd class="cont2">
                                <span><i class="view"></i>147浏览</span>
                                <span class="collectBtn user_collection" data-id="619689" data-type="article" title="收藏"><i class="collect"></i>收藏</span>
                            </dd>
                        </dl>
                    </div>
                </li>
                                <li>
                    <div class="contBox">
                        <a href="/article/619683.html" class="img_box" title="一个按钮控制多个状态的实现方式">
                            <img src="/uploads/20260601/17802911266a1d16367332e.jpg" onerror="this.src='/assets/images/moren/morentu.png'" alt="一个按钮控制多个状态的实现方式">
                        </a>
                        <dl>
                            <dd class="cont1">
                  <span>
                                                                <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> ·
                                                                            <a href="/articlelist/88_new_0_1.html" class="aLightGray" title="前端">前端</a>
                                                       |  5天前  |  

                                                  </span>
                            </dd>
                            <dt class="lineOverflow">
                                <a href="/article/619683.html" class="aBlack" target="_blank" title="一个按钮控制多个状态的实现方式">一个按钮控制多个状态的实现方式</a>
                            </dt>
                            <dd class="cont2">
                                <span><i class="view"></i>360浏览</span>
                                <span class="collectBtn user_collection" data-id="619683" data-type="article" title="收藏"><i class="collect"></i>收藏</span>
                            </dd>
                        </dl>
                    </div>
                </li>
                                <li>
                    <div class="contBox">
                        <a href="/article/619679.html" class="img_box" title="CSSGrid子元素排序技巧分享">
                            <img src="/uploads/20260601/17802910156a1d15c7e530b.jpg" onerror="this.src='/assets/images/moren/morentu.png'" alt="CSSGrid子元素排序技巧分享">
                        </a>
                        <dl>
                            <dd class="cont1">
                  <span>
                                                                <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> ·
                                                                            <a href="/articlelist/88_new_0_1.html" class="aLightGray" title="前端">前端</a>
                                                       |  5天前  |  

                                                  </span>
                            </dd>
                            <dt class="lineOverflow">
                                <a href="/article/619679.html" class="aBlack" target="_blank" title="CSSGrid子元素排序技巧分享">CSSGrid子元素排序技巧分享</a>
                            </dt>
                            <dd class="cont2">
                                <span><i class="view"></i>155浏览</span>
                                <span class="collectBtn user_collection" data-id="619679" data-type="article" title="收藏"><i class="collect"></i>收藏</span>
                            </dd>
                        </dl>
                    </div>
                </li>
                                <li>
                    <div class="contBox">
                        <a href="/article/619677.html" class="img_box" title="FIMO支持透明度设置吗?">
                            <img src="/uploads/20260601/17802909496a1d158569b8e.jpg" onerror="this.src='/assets/images/moren/morentu.png'" alt="FIMO支持透明度设置吗?">
                        </a>
                        <dl>
                            <dd class="cont1">
                  <span>
                                                                <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> ·
                                                                            <a href="/articlelist/88_new_0_1.html" class="aLightGray" title="前端">前端</a>
                                                       |  5天前  |  

                                                  </span>
                            </dd>
                            <dt class="lineOverflow">
                                <a href="/article/619677.html" class="aBlack" target="_blank" title="FIMO支持透明度设置吗?">FIMO支持透明度设置吗?</a>
                            </dt>
                            <dd class="cont2">
                                <span><i class="view"></i>393浏览</span>
                                <span class="collectBtn user_collection" data-id="619677" data-type="article" title="收藏"><i class="collect"></i>收藏</span>
                            </dd>
                        </dl>
                    </div>
                </li>
                                <li>
                    <div class="contBox">
                        <a href="/article/619653.html" class="img_box" title="Web组件开发:CustomElements实战教程">
                            <img src="/uploads/20260601/17802898596a1d11436d93f.jpg" onerror="this.src='/assets/images/moren/morentu.png'" alt="Web组件开发:CustomElements实战教程">
                        </a>
                        <dl>
                            <dd class="cont1">
                  <span>
                                                                <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> ·
                                                                            <a href="/articlelist/88_new_0_1.html" class="aLightGray" title="前端">前端</a>
                                                       |  5天前  |  

                                                  </span>
                            </dd>
                            <dt class="lineOverflow">
                                <a href="/article/619653.html" class="aBlack" target="_blank" title="Web组件开发:CustomElements实战教程">Web组件开发:CustomElements实战教程</a>
                            </dt>
                            <dd class="cont2">
                                <span><i class="view"></i>243浏览</span>
                                <span class="collectBtn user_collection" data-id="619653" data-type="article" title="收藏"><i class="collect"></i>收藏</span>
                            </dd>
                        </dl>
                    </div>
                </li>
                                <li>
                    <div class="contBox">
                        <a href="/article/619650.html" class="img_box" title="CSS无限循环背景动画技巧">
                            <img src="/uploads/20260601/17802897036a1d10a7bcfb8.jpg" onerror="this.src='/assets/images/moren/morentu.png'" alt="CSS无限循环背景动画技巧">
                        </a>
                        <dl>
                            <dd class="cont1">
                  <span>
                                                                <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> ·
                                                                            <a href="/articlelist/88_new_0_1.html" class="aLightGray" title="前端">前端</a>
                                                       |  5天前  |  

                                                  </span>
                            </dd>
                            <dt class="lineOverflow">
                                <a href="/article/619650.html" class="aBlack" target="_blank" title="CSS无限循环背景动画技巧">CSS无限循环背景动画技巧</a>
                            </dt>
                            <dd class="cont2">
                                <span><i class="view"></i>116浏览</span>
                                <span class="collectBtn user_collection" data-id="619650" data-type="article" title="收藏"><i class="collect"></i>收藏</span>
                            </dd>
                        </dl>
                    </div>
                </li>
                                <li>
                    <div class="contBox">
                        <a href="/article/619644.html" class="img_box" title="CSS文字大小动画不自然怎么优化?">
                            <img src="/uploads/20260601/17802894386a1d0f9e5c88c.jpg" onerror="this.src='/assets/images/moren/morentu.png'" alt="CSS文字大小动画不自然怎么优化?">
                        </a>
                        <dl>
                            <dd class="cont1">
                  <span>
                                                                <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> ·
                                                                            <a href="/articlelist/88_new_0_1.html" class="aLightGray" title="前端">前端</a>
                                                       |  5天前  |  

                                                                                 <a href="javascript:;" class="aLightGray" title="CSS">CSS</a>
                                                                                             <a href="javascript:;" class="aLightGray" title="动画">动画</a>
                                                              </span>
                            </dd>
                            <dt class="lineOverflow">
                                <a href="/article/619644.html" class="aBlack" target="_blank" title="CSS文字大小动画不自然怎么优化?">CSS文字大小动画不自然怎么优化?</a>
                            </dt>
                            <dd class="cont2">
                                <span><i class="view"></i>126浏览</span>
                                <span class="collectBtn user_collection" data-id="619644" data-type="article" title="收藏"><i class="collect"></i>收藏</span>
                            </dd>
                        </dl>
                    </div>
                </li>
                                <li>
                    <div class="contBox">
                        <a href="/article/619634.html" class="img_box" title="清除浮动空白间距的实用技巧">
                            <img src="/uploads/20260601/17802890356a1d0e0bc8117.jpg" onerror="this.src='/assets/images/moren/morentu.png'" alt="清除浮动空白间距的实用技巧">
                        </a>
                        <dl>
                            <dd class="cont1">
                  <span>
                                                                <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> ·
                                                                            <a href="/articlelist/88_new_0_1.html" class="aLightGray" title="前端">前端</a>
                                                       |  5天前  |  

                                                  </span>
                            </dd>
                            <dt class="lineOverflow">
                                <a href="/article/619634.html" class="aBlack" target="_blank" title="清除浮动空白间距的实用技巧">清除浮动空白间距的实用技巧</a>
                            </dt>
                            <dd class="cont2">
                                <span><i class="view"></i>430浏览</span>
                                <span class="collectBtn user_collection" data-id="619634" data-type="article" title="收藏"><i class="collect"></i>收藏</span>
                            </dd>
                        </dl>
                    </div>
                </li>
                                <li>
                    <div class="contBox">
                        <a href="/article/619632.html" class="img_box" title="JavaScript前端安全核心问题有哪些?">
                            <img src="/uploads/20260601/17802889596a1d0dbf97f68.jpg" onerror="this.src='/assets/images/moren/morentu.png'" alt="JavaScript前端安全核心问题有哪些?">
                        </a>
                        <dl>
                            <dd class="cont1">
                  <span>
                                                                <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> ·
                                                                            <a href="/articlelist/88_new_0_1.html" class="aLightGray" title="前端">前端</a>
                                                       |  5天前  |  

                                                  </span>
                            </dd>
                            <dt class="lineOverflow">
                                <a href="/article/619632.html" class="aBlack" target="_blank" title="JavaScript前端安全核心问题有哪些?">JavaScript前端安全核心问题有哪些?</a>
                            </dt>
                            <dd class="cont2">
                                <span><i class="view"></i>109浏览</span>
                                <span class="collectBtn user_collection" data-id="619632" data-type="article" title="收藏"><i class="collect"></i>收藏</span>
                            </dd>
                        </dl>
                    </div>
                </li>
                                <li>
                    <div class="contBox">
                        <a href="/article/619631.html" class="img_box" title="自定义图片提交按钮,INPUTTYPE设为IMAGE">
                            <img src="/uploads/20260601/17802888896a1d0d793af4e.png" onerror="this.src='/assets/images/moren/morentu.png'" alt="自定义图片提交按钮,INPUTTYPE设为IMAGE">
                        </a>
                        <dl>
                            <dd class="cont1">
                  <span>
                                                                <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> ·
                                                                            <a href="/articlelist/88_new_0_1.html" class="aLightGray" title="前端">前端</a>
                                                       |  5天前  |  

                                                                                 <a href="javascript:;" class="aLightGray" title="html">html</a>
                                                              </span>
                            </dd>
                            <dt class="lineOverflow">
                                <a href="/article/619631.html" class="aBlack" target="_blank" title="自定义图片提交按钮,INPUTTYPE设为IMAGE">自定义图片提交按钮,INPUTTYPE设为IMAGE</a>
                            </dt>
                            <dd class="cont2">
                                <span><i class="view"></i>179浏览</span>
                                <span class="collectBtn user_collection" data-id="619631" data-type="article" title="收藏"><i class="collect"></i>收藏</span>
                            </dd>
                        </dl>
                    </div>
                </li>
                                <li>
                    <div class="contBox">
                        <a href="/article/619622.html" class="img_box" title="CSS文字压到图片上怎么解决?z-index调整方法">
                            <img src="/uploads/20260601/17802885336a1d0c151a9a2.jpg" onerror="this.src='/assets/images/moren/morentu.png'" alt="CSS文字压到图片上怎么解决?z-index调整方法">
                        </a>
                        <dl>
                            <dd class="cont1">
                  <span>
                                                                <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> ·
                                                                            <a href="/articlelist/88_new_0_1.html" class="aLightGray" title="前端">前端</a>
                                                       |  5天前  |  

                                                  </span>
                            </dd>
                            <dt class="lineOverflow">
                                <a href="/article/619622.html" class="aBlack" target="_blank" title="CSS文字压到图片上怎么解决?z-index调整方法">CSS文字压到图片上怎么解决?z-index调整方法</a>
                            </dt>
                            <dd class="cont2">
                                <span><i class="view"></i>126浏览</span>
                                <span class="collectBtn user_collection" data-id="619622" 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/13100.html"  target="_blank" title="ChatExcel酷表:告别Excel难题,北大团队AI助手助您轻松处理数据" class="img_box">
                    <img src="/uploads/20251027/176155320368ff2b3345c06.jpg" onerror="this.onerror='',this.src='/assets/images/moren/morentu.png'" alt="ChatExcel酷表:告别Excel难题,北大团队AI助手助您轻松处理数据" style="object-fit:cover;width:100%;height:100%;">
                </a>
                <dl>
                    <dt class="lineTwoOverflow"><a href="/ai/13100.html" class="aBlack" target="_blank" title="ChatExcel酷表">ChatExcel酷表</a></dt>
                    <dd class="cont1 lineTwoOverflow">
                        ChatExcel酷表是由北京大学团队打造的Excel聊天机器人,用自然语言操控表格,简化数据处理,告别繁琐操作,提升工作效率!适用于学生、上班族及政府人员。                    </dd>
                    <dd class="cont2">6424次使用</dd>
                </dl>
            </li>
                        <li>
                <a href="/ai/13099.html"  target="_blank" title="Any绘本:开源免费AI绘本创作工具深度解析" class="img_box">
                    <img src="/uploads/20251023/176120760368f9e5333da5f.jpg" onerror="this.onerror='',this.src='/assets/images/moren/morentu.png'" alt="Any绘本:开源免费AI绘本创作工具深度解析" style="object-fit:cover;width:100%;height:100%;">
                </a>
                <dl>
                    <dt class="lineTwoOverflow"><a href="/ai/13099.html" class="aBlack" target="_blank" title="Any绘本">Any绘本</a></dt>
                    <dd class="cont1 lineTwoOverflow">
                        探索Any绘本(anypicturebook.com/zh),一款开源免费的AI绘本创作工具,基于Google Gemini与Flux AI模型,让您轻松创作个性化绘本。适用于家庭、教育、创作等多种场景,零门槛,高自由度,技术透明,本地可控。                    </dd>
                    <dd class="cont2">6842次使用</dd>
                </dl>
            </li>
                        <li>
                <a href="/ai/13098.html"  target="_blank" title="可赞AI:AI驱动办公可视化智能工具,一键高效生成文档图表脑图" class="img_box">
                    <img src="/uploads/20251021/176103600268f746e238bb8.jpg" onerror="this.onerror='',this.src='/assets/images/moren/morentu.png'" alt="可赞AI:AI驱动办公可视化智能工具,一键高效生成文档图表脑图" style="object-fit:cover;width:100%;height:100%;">
                </a>
                <dl>
                    <dt class="lineTwoOverflow"><a href="/ai/13098.html" class="aBlack" target="_blank" title="可赞AI">可赞AI</a></dt>
                    <dd class="cont1 lineTwoOverflow">
                        可赞AI,AI驱动的办公可视化智能工具,助您轻松实现文本与可视化元素高效转化。无论是智能文档生成、多格式文本解析,还是一键生成专业图表、脑图、知识卡片,可赞AI都能让信息处理更清晰高效。覆盖数据汇报、会议纪要、内容营销等全场景,大幅提升办公效率,降低专业门槛,是您提升工作效率的得力助手。                    </dd>
                    <dd class="cont2">6633次使用</dd>
                </dl>
            </li>
                        <li>
                <a href="/ai/13097.html"  target="_blank" title="星月写作:AI网文创作神器,助力爆款小说速成" class="img_box">
                    <img src="/uploads/20251014/176043000368ee07b3159d6.jpg" 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/13097.html" class="aBlack" target="_blank" title="星月写作">星月写作</a></dt>
                    <dd class="cont1 lineTwoOverflow">
                        星月写作是国内首款聚焦中文网络小说创作的AI辅助工具,解决网文作者从构思到变现的全流程痛点。AI扫榜、专属模板、全链路适配,助力新人快速上手,资深作者效率倍增。                    </dd>
                    <dd class="cont2">8583次使用</dd>
                </dl>
            </li>
                        <li>
                <a href="/ai/13096.html"  target="_blank" title="MagicLight.ai:叙事驱动AI动画视频创作平台 | 高效生成专业级故事动画" class="img_box">
                    <img src="/uploads/20251014/176040000268ed9282edf80.jpg" onerror="this.onerror='',this.src='/assets/images/moren/morentu.png'" alt="MagicLight.ai:叙事驱动AI动画视频创作平台 | 高效生成专业级故事动画" style="object-fit:cover;width:100%;height:100%;">
                </a>
                <dl>
                    <dt class="lineTwoOverflow"><a href="/ai/13096.html" class="aBlack" target="_blank" title="MagicLight">MagicLight</a></dt>
                    <dd class="cont1 lineTwoOverflow">
                        MagicLight.ai是全球首款叙事驱动型AI动画视频创作平台,专注于解决从故事想法到完整动画的全流程痛点。它通过自研AI模型,保障角色、风格、场景高度一致性,让零动画经验者也能高效产出专业级叙事内容。广泛适用于独立创作者、动画工作室、教育机构及企业营销,助您轻松实现创意落地与商业化。                    </dd>
                    <dd class="cont2">7270次使用</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/207000.html"  class="aBlack" title="JavaScript函数定义及示例详解">JavaScript函数定义及示例详解</a></dt>
                        <dd>
                            <span class="left">2025-05-11</span>
                            <span class="right">502浏览</span>
                        </dd>
                    </dl>
                </li>
                                <li>
                    <dl>
                        <dt class="lineTwoOverflow"><a href="/article/72840.html"  class="aBlack" title="优化用户界面体验的秘密武器:CSS开发项目经验大揭秘">优化用户界面体验的秘密武器:CSS开发项目经验大揭秘</a></dt>
                        <dd>
                            <span class="left">2023-11-03</span>
                            <span class="right">501浏览</span>
                        </dd>
                    </dl>
                </li>
                                <li>
                    <dl>
                        <dt class="lineTwoOverflow"><a href="/article/76259.html"  class="aBlack" title="使用微信小程序实现图片轮播特效">使用微信小程序实现图片轮播特效</a></dt>
                        <dd>
                            <span class="left">2023-11-21</span>
                            <span class="right">501浏览</span>
                        </dd>
                    </dl>
                </li>
                                <li>
                    <dl>
                        <dt class="lineTwoOverflow"><a href="/article/83771.html"  class="aBlack" title="解析sessionStorage的存储能力与限制">解析sessionStorage的存储能力与限制</a></dt>
                        <dd>
                            <span class="left">2024-01-11</span>
                            <span class="right">501浏览</span>
                        </dd>
                    </dl>
                </li>
                                <li>
                    <dl>
                        <dt class="lineTwoOverflow"><a href="/article/85057.html"  class="aBlack" title="探索冒泡活动对于团队合作的推动力">探索冒泡活动对于团队合作的推动力</a></dt>
                        <dd>
                            <span class="left">2024-01-13</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>
            </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/304088.html"/>
                <input type="hidden" name="__token__" value="b7a416a9835dc31d95abbda35c91fd0d" />                <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/304088.html"/>
                <input type="hidden" name="__token__" value="b7a416a9835dc31d95abbda35c91fd0d" />                <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>
    var _hmt = _hmt || [];
    (function() {
        var hm = document.createElement("script");
        hm.src = "https://hm.baidu.com/hm.js?3dc5666f6478c7bf39cd5c91e597423d";
        var s = document.getElementsByTagName("script")[0];
        s.parentNode.insertBefore(hm, s);
    })();
</script>

<script src="/assets/js/require.js" data-main="/assets/js/require-frontend.js?v=1671101972"></script>
</body>
</html>