当前位置:首页 > 文章列表 > 文章 > 前端 > 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 中会失败?

考虑以下代码片段:

<script>
    var data = "shan";
    // 尝试在Jinja的url_for中使用JavaScript变量 'data'
    window.location.href='{{ url_for( "move_forward" , title=data) }}';
</script>

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

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

而以下方式之所以成功:

<script>
    // 在Jinja的url_for中直接使用字符串字面量
    window.location.href='{{ url_for( "move_forward" , title="shan") }}';
</script>

是因为 "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代码示例:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>动态URL参数传递</title>
</head>
<body>
    <h1>点击按钮发送动态数据</h1>
    <button onclick="sendDynamicData()">发送数据</button>

    <script>
        function sendDynamicData() {
            // 这是一个需要动态传递的JavaScript变量
            var dynamicValue = "HelloFromJS"; // 可以是任何动态获取的值,例如用户输入

            // 1. 使用Jinja生成基础URL。
            //    这里url_for("move_forward")会生成类似于 "/move_forward" 的路径。
            var baseUrl = '{{ url_for("move_forward") }}';

            // 2. 在JavaScript中拼接完整的URL。
            //    注意:Flask路由通常期望路径参数在斜杠后。
            window.location.href = baseUrl + "/" + dynamicValue;

            // 如果需要URL编码,以防dynamicValue包含特殊字符:
            // window.location.href = baseUrl + "/" + encodeURIComponent(dynamicValue);
        }
    </script>
</body>
</html>

后端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路由,它接受一个名为 <title> 的路径参数
@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) # 开启调试模式,方便开发

工作原理详解:

  1. 当服务器渲染 index.html 时,{{ url_for("move_forward") }} 会被Flask解析并替换为 /move_forward。所以,浏览器接收到的HTML代码中的JavaScript部分会是:
    var baseUrl = '/move_forward';
  2. 当用户点击按钮,sendDynamicData() 函数执行时,JavaScript变量 dynamicValue 的值为 "HelloFromJS"。
  3. JavaScript代码执行 window.location.href = baseUrl + "/" + dynamicValue;,这会拼接成 /move_forward/HelloFromJS。
  4. 浏览器导航到这个新的URL,即向 /move_forward/HelloFromJS 发送一个GET请求。
  5. Flask后端匹配到 @app.route("/move_forward/") 这个路由,并将URL中的 HelloFromJS 提取为 title 参数的值,然后传递给 move_forward 函数。</li></ol><h3>3. 注意事项与最佳实践</h3><ul><li><p><strong>URL编码 (encodeURIComponent)</strong>:如果你的JavaScript变量 dynamicValue 可能包含特殊字符(如空格、&、?、/ 等),这些字符在URL中具有特殊含义。为了确保数据能够正确传递和解析,强烈建议在拼接URL之前使用 encodeURIComponent() 函数对动态数据进行编码。</p><pre>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/407159.html" class="img_box" title="JSDoc定义固定加扩展属性对象类型的方法是使用@typedef或@interface结合&运算符来组合固定属性和可扩展属性。以下是详细步骤:1.定义固定属性对象类型首先,使用@typedef或@interface定义一个具有固定属性的对象类型。/***@typedef{Object}FixedProps*@property{string}name-用户名称*@property{numbe"> <img src="/uploads/20251203/176477728169305d41de3bb.jpg" onerror="this.src='/assets/images/moren/morentu.png'" alt="JSDoc定义固定加扩展属性对象类型的方法是使用@typedef或@interface结合&运算符来组合固定属性和可扩展属性。以下是详细步骤:1.定义固定属性对象类型首先,使用@typedef或@interface定义一个具有固定属性的对象类型。/***@typedef{Object}FixedProps*@property{string}name-用户名称*@property{numbe"> </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>   |  4小时前  |   </span> </dd> <dt class="lineOverflow"> <a href="/article/407159.html" class="aBlack" target="_blank" title="JSDoc定义固定加扩展属性对象类型的方法是使用@typedef或@interface结合&运算符来组合固定属性和可扩展属性。以下是详细步骤:1.定义固定属性对象类型首先,使用@typedef或@interface定义一个具有固定属性的对象类型。/***@typedef{Object}FixedProps*@property{string}name-用户名称*@property{numbe">JSDoc定义固定加扩展属性对象类型的方法是使用@typedef或@interface结合&运算符来组合固定属性和可扩展属性。以下是详细步骤:1.定义固定属性对象类型首先,使用@typedef或@interface定义一个具有固定属性的对象类型。/***@typedef{Object}FixedProps*@property{string}name-用户名称*@property{numbe</a> </dt> <dd class="cont2"> <span><i class="view"></i>319浏览</span> <span class="collectBtn user_collection" data-id="407159" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/407156.html" class="img_box" title="CSSz-index层级控制全攻略"> <img src="/uploads/20251203/176477721369305cfda9c41.jpg" onerror="this.src='/assets/images/moren/morentu.png'" alt="CSSz-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>   |  4小时前  |   </span> </dd> <dt class="lineOverflow"> <a href="/article/407156.html" class="aBlack" target="_blank" title="CSSz-index层级控制全攻略">CSSz-index层级控制全攻略</a> </dt> <dd class="cont2"> <span><i class="view"></i>394浏览</span> <span class="collectBtn user_collection" data-id="407156" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/407143.html" class="img_box" title="PostCSS插件配置全攻略"> <img src="/uploads/20251203/176477666969305add4daeb.jpg" onerror="this.src='/assets/images/moren/morentu.png'" alt="PostCSS插件配置全攻略"> </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>   |  4小时前  |   </span> </dd> <dt class="lineOverflow"> <a href="/article/407143.html" class="aBlack" target="_blank" title="PostCSS插件配置全攻略">PostCSS插件配置全攻略</a> </dt> <dd class="cont2"> <span><i class="view"></i>258浏览</span> <span class="collectBtn user_collection" data-id="407143" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/407140.html" class="img_box" title="跨域问题与CORS解决方法详解"> <img src="/uploads/20251203/176477650369305a3742cf8.jpg" onerror="this.src='/assets/images/moren/morentu.png'" alt="跨域问题与CORS解决方法详解"> </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>   |  4小时前  |   <a href="javascript:;" class="aLightGray" title="cors">cors</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> </span> </dd> <dt class="lineOverflow"> <a href="/article/407140.html" class="aBlack" target="_blank" title="跨域问题与CORS解决方法详解">跨域问题与CORS解决方法详解</a> </dt> <dd class="cont2"> <span><i class="view"></i>484浏览</span> <span class="collectBtn user_collection" data-id="407140" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/407135.html" class="img_box" title="CSS渐变色详解:linear-gradient与radial-gradient用法"> <img src="/uploads/20251203/176477622469305920794cb.jpg" onerror="this.src='/assets/images/moren/morentu.png'" alt="CSS渐变色详解:linear-gradient与radial-gradient用法"> </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>   |  4小时前  |   <a href="javascript:;" class="aLightGray" title="背景">背景</a> <a href="javascript:;" class="aLightGray" title="CSS渐变">CSS渐变</a> <a href="javascript:;" class="aLightGray" title="linear-gradient">linear-gradient</a> <a href="javascript:;" class="aLightGray" title="radial-gradient">radial-gradient</a> <a href="javascript:;" class="aLightGray" title="颜色停点">颜色停点</a> </span> </dd> <dt class="lineOverflow"> <a href="/article/407135.html" class="aBlack" target="_blank" title="CSS渐变色详解:linear-gradient与radial-gradient用法">CSS渐变色详解:linear-gradient与radial-gradient用法</a> </dt> <dd class="cont2"> <span><i class="view"></i>402浏览</span> <span class="collectBtn user_collection" data-id="407135" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/407107.html" class="img_box" title="padding-top和padding-bottom的区别在于,前者控制元素顶部的内边距,后者控制底部的内边距。简单来说,padding-top会让元素内容与上方边界之间留出空间,而padding-bottom则会让内容与下方边界之间留出空间。两者共同作用于元素的垂直方向,但分别影响不同的区域。"> <img src="/uploads/20251203/1764774903693053f7df3d1.jpg" onerror="this.src='/assets/images/moren/morentu.png'" alt="padding-top和padding-bottom的区别在于,前者控制元素顶部的内边距,后者控制底部的内边距。简单来说,padding-top会让元素内容与上方边界之间留出空间,而padding-bottom则会让内容与下方边界之间留出空间。两者共同作用于元素的垂直方向,但分别影响不同的区域。"> </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>   |  4小时前  |   </span> </dd> <dt class="lineOverflow"> <a href="/article/407107.html" class="aBlack" target="_blank" title="padding-top和padding-bottom的区别在于,前者控制元素顶部的内边距,后者控制底部的内边距。简单来说,padding-top会让元素内容与上方边界之间留出空间,而padding-bottom则会让内容与下方边界之间留出空间。两者共同作用于元素的垂直方向,但分别影响不同的区域。">padding-top和padding-bottom的区别在于,前者控制元素顶部的内边距,后者控制底部的内边距。简单来说,padding-top会让元素内容与上方边界之间留出空间,而padding-bottom则会让内容与下方边界之间留出空间。两者共同作用于元素的垂直方向,但分别影响不同的区域。</a> </dt> <dd class="cont2"> <span><i class="view"></i>334浏览</span> <span class="collectBtn user_collection" data-id="407107" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/407100.html" class="img_box" title="CSS浮动布局详解与清除方法"> <img src="/uploads/20251203/1764774517693052757809b.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="FLEXBOX">FLEXBOX</a> <a href="javascript:;" class="aLightGray" title="清除浮动">清除浮动</a> <a href="javascript:;" class="aLightGray" title="float属性">float属性</a> <a href="javascript:;" class="aLightGray" title="CSSGrid">CSSGrid</a> <a href="javascript:;" class="aLightGray" title="CSS浮动布局">CSS浮动布局</a> </span> </dd> <dt class="lineOverflow"> <a href="/article/407100.html" class="aBlack" target="_blank" title="CSS浮动布局详解与清除方法">CSS浮动布局详解与清除方法</a> </dt> <dd class="cont2"> <span><i class="view"></i>460浏览</span> <span class="collectBtn user_collection" data-id="407100" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/407098.html" class="img_box" title="CSScurrentColor统一颜色管理技巧"> <img src="/uploads/20251203/1764774395693051fb6cba8.jpg" onerror="this.src='/assets/images/moren/morentu.png'" alt="CSScurrentColor统一颜色管理技巧"> </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="主题切换">主题切换</a> <a href="javascript:;" class="aLightGray" title="color属性">color属性</a> <a href="javascript:;" class="aLightGray" title="currentColor">currentColor</a> <a href="javascript:;" class="aLightGray" title="颜色统一管理">颜色统一管理</a> <a href="javascript:;" class="aLightGray" title="减少重复代码">减少重复代码</a> </span> </dd> <dt class="lineOverflow"> <a href="/article/407098.html" class="aBlack" target="_blank" title="CSScurrentColor统一颜色管理技巧">CSScurrentColor统一颜色管理技巧</a> </dt> <dd class="cont2"> <span><i class="view"></i>160浏览</span> <span class="collectBtn user_collection" data-id="407098" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/407096.html" class="img_box" title="CSS导入外部样式表方法详解"> <img src="/uploads/20251203/1764774336693051c08563f.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/407096.html" class="aBlack" target="_blank" title="CSS导入外部样式表方法详解">CSS导入外部样式表方法详解</a> </dt> <dd class="cont2"> <span><i class="view"></i>189浏览</span> <span class="collectBtn user_collection" data-id="407096" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/407085.html" class="img_box" title="WebCryptoAPI:JavaScript密码学实战教程"> <img src="/uploads/20251203/176477385469304fde1bc98.jpg" onerror="this.src='/assets/images/moren/morentu.png'" alt="WebCryptoAPI: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/407085.html" class="aBlack" target="_blank" title="WebCryptoAPI:JavaScript密码学实战教程">WebCryptoAPI:JavaScript密码学实战教程</a> </dt> <dd class="cont2"> <span><i class="view"></i>140浏览</span> <span class="collectBtn user_collection" data-id="407085" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/407083.html" class="img_box" title="JS对象属性变化监听全解析"> <img src="/uploads/20251203/176477373369304f65c803a.png" onerror="this.src='/assets/images/moren/morentu.png'" alt="JS对象属性变化监听全解析"> </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/407083.html" class="aBlack" target="_blank" title="JS对象属性变化监听全解析">JS对象属性变化监听全解析</a> </dt> <dd class="cont2"> <span><i class="view"></i>310浏览</span> <span class="collectBtn user_collection" data-id="407083" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/407082.html" class="img_box" title="浏览器扩展快速编辑HTML方法"> <img src="/uploads/20251203/176477367769304f2d7cfca.png" onerror="this.src='/assets/images/moren/morentu.png'" alt="浏览器扩展快速编辑HTML方法"> </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="开发效率">开发效率</a> <a href="javascript:;" class="aLightGray" title="浏览器扩展">浏览器扩展</a> <a href="javascript:;" class="aLightGray" title="HTML代码编辑">HTML代码编辑</a> <a href="javascript:;" class="aLightGray" title="快速编辑">快速编辑</a> <a href="javascript:;" class="aLightGray" title="页面内编辑">页面内编辑</a> </span> </dd> <dt class="lineOverflow"> <a href="/article/407082.html" class="aBlack" target="_blank" title="浏览器扩展快速编辑HTML方法">浏览器扩展快速编辑HTML方法</a> </dt> <dd class="cont2"> <span><i class="view"></i>275浏览</span> <span class="collectBtn user_collection" data-id="407082" 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">3193次使用</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">3405次使用</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">3436次使用</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">4543次使用</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">3814次使用</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="//www.17golang.com/article/304088.html"/> <input type="hidden" name="__token__" value="79dcd6dec9811f23d2dd27901c1aa4ea" /> <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="//www.17golang.com/article/304088.html"/> <input type="hidden" name="__token__" value="79dcd6dec9811f23d2dd27901c1aa4ea" /> <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>