当前位置:首页 > 文章列表 > 文章 > 前端 > 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/465319.html" class="img_box" title="HTML5与Node.js数据同步方法解析"> <img src="/uploads/20260120/1768898873696f4139f3d0b.png" onerror="this.src='/assets/images/moren/morentu.png'" alt="HTML5与Node.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>   |  2分钟前  |   </span> </dd> <dt class="lineOverflow"> <a href="/article/465319.html" class="aBlack" target="_blank" title="HTML5与Node.js数据同步方法解析">HTML5与Node.js数据同步方法解析</a> </dt> <dd class="cont2"> <span><i class="view"></i>407浏览</span> <span class="collectBtn user_collection" data-id="465319" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/465311.html" class="img_box" title="HTML5行距调整方法,CSSline-height设置技巧"> <img src="/uploads/20260120/1768898462696f3f9eecfe6.png" onerror="this.src='/assets/images/moren/morentu.png'" alt="HTML5行距调整方法,CSSline-height设置技巧"> </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>   |  8分钟前  |   <a href="javascript:;" class="aLightGray" title="HTML5">HTML5</a> </span> </dd> <dt class="lineOverflow"> <a href="/article/465311.html" class="aBlack" target="_blank" title="HTML5行距调整方法,CSSline-height设置技巧">HTML5行距调整方法,CSSline-height设置技巧</a> </dt> <dd class="cont2"> <span><i class="view"></i>211浏览</span> <span class="collectBtn user_collection" data-id="465311" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/465306.html" class="img_box" title="HSLA颜色与透明背景使用技巧"> <img src="/uploads/20260120/1768898195696f3e93946e5.jpg" onerror="this.src='/assets/images/moren/morentu.png'" alt="HSLA颜色与透明背景使用技巧"> </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>   |  13分钟前  |   </span> </dd> <dt class="lineOverflow"> <a href="/article/465306.html" class="aBlack" target="_blank" title="HSLA颜色与透明背景使用技巧">HSLA颜色与透明背景使用技巧</a> </dt> <dd class="cont2"> <span><i class="view"></i>256浏览</span> <span class="collectBtn user_collection" data-id="465306" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/465305.html" class="img_box" title="CSS导航栏渐变色实现教程"> <img src="/uploads/20260120/1768898135696f3e57d61c9.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>   |  14分钟前  |   </span> </dd> <dt class="lineOverflow"> <a href="/article/465305.html" class="aBlack" target="_blank" title="CSS导航栏渐变色实现教程">CSS导航栏渐变色实现教程</a> </dt> <dd class="cont2"> <span><i class="view"></i>430浏览</span> <span class="collectBtn user_collection" data-id="465305" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/465301.html" class="img_box" title="HTML5canvas画矩形方法详解"> <img src="/uploads/20260120/1768897957696f3da592f16.jpg" onerror="this.src='/assets/images/moren/morentu.png'" alt="HTML5canvas画矩形方法详解"> </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>   |  17分钟前  |   </span> </dd> <dt class="lineOverflow"> <a href="/article/465301.html" class="aBlack" target="_blank" title="HTML5canvas画矩形方法详解">HTML5canvas画矩形方法详解</a> </dt> <dd class="cont2"> <span><i class="view"></i>453浏览</span> <span class="collectBtn user_collection" data-id="465301" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/465299.html" class="img_box" title="CSS多关键帧动画设置技巧解析"> <img src="/uploads/20260120/1768897842696f3d324bd47.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>   |  19分钟前  |   </span> </dd> <dt class="lineOverflow"> <a href="/article/465299.html" class="aBlack" target="_blank" title="CSS多关键帧动画设置技巧解析">CSS多关键帧动画设置技巧解析</a> </dt> <dd class="cont2"> <span><i class="view"></i>339浏览</span> <span class="collectBtn user_collection" data-id="465299" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/465295.html" class="img_box" title="JavaScript原型链解析与实战教程"> <img src="/uploads/20260120/1768897654696f3c76f3cce.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>   |  22分钟前  |   </span> </dd> <dt class="lineOverflow"> <a href="/article/465295.html" class="aBlack" target="_blank" title="JavaScript原型链解析与实战教程">JavaScript原型链解析与实战教程</a> </dt> <dd class="cont2"> <span><i class="view"></i>125浏览</span> <span class="collectBtn user_collection" data-id="465295" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/465291.html" class="img_box" title="微博昵称怎么改?修改方法及限制全解析"> <img src="/uploads/20260120/1768897481696f3bc907483.png" 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>   |  25分钟前  |   </span> </dd> <dt class="lineOverflow"> <a href="/article/465291.html" class="aBlack" target="_blank" title="微博昵称怎么改?修改方法及限制全解析">微博昵称怎么改?修改方法及限制全解析</a> </dt> <dd class="cont2"> <span><i class="view"></i>305浏览</span> <span class="collectBtn user_collection" data-id="465291" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/465286.html" class="img_box" title="CSSGrid等高等宽卡片实现技巧"> <img src="/uploads/20260120/1768897139696f3a738ee5e.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>   |  31分钟前  |   </span> </dd> <dt class="lineOverflow"> <a href="/article/465286.html" class="aBlack" target="_blank" title="CSSGrid等高等宽卡片实现技巧">CSSGrid等高等宽卡片实现技巧</a> </dt> <dd class="cont2"> <span><i class="view"></i>421浏览</span> <span class="collectBtn user_collection" data-id="465286" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/465282.html" class="img_box" title="Node.js安全防护技巧与实战方法"> <img src="/uploads/20260120/1768897017696f39f992565.png" onerror="this.src='/assets/images/moren/morentu.png'" alt="Node.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>   |  33分钟前  |   </span> </dd> <dt class="lineOverflow"> <a href="/article/465282.html" class="aBlack" target="_blank" title="Node.js安全防护技巧与实战方法">Node.js安全防护技巧与实战方法</a> </dt> <dd class="cont2"> <span><i class="view"></i>185浏览</span> <span class="collectBtn user_collection" data-id="465282" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/465280.html" class="img_box" title="阻止事件冒泡的几种方法"> <img src="/uploads/20260120/1768896942696f39ae400e0.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>   |  34分钟前  |   </span> </dd> <dt class="lineOverflow"> <a href="/article/465280.html" class="aBlack" target="_blank" title="阻止事件冒泡的几种方法">阻止事件冒泡的几种方法</a> </dt> <dd class="cont2"> <span><i class="view"></i>244浏览</span> <span class="collectBtn user_collection" data-id="465280" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/465278.html" class="img_box" title="HTML5建模添加环境光方法详解"> <img src="/uploads/20260120/1768896765696f38fda7419.png" onerror="this.src='/assets/images/moren/morentu.png'" alt="HTML5建模添加环境光方法详解"> </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>   |  36分钟前  |   <a href="javascript:;" class="aLightGray" title="HTML5建模">HTML5建模</a> </span> </dd> <dt class="lineOverflow"> <a href="/article/465278.html" class="aBlack" target="_blank" title="HTML5建模添加环境光方法详解">HTML5建模添加环境光方法详解</a> </dt> <dd class="cont2"> <span><i class="view"></i>239浏览</span> <span class="collectBtn user_collection" data-id="465278" 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">3701次使用</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">3969次使用</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">3910次使用</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">5082次使用</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">4282次使用</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="1eae1efaf413dac893ec1c79e43bebad" /> <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="1eae1efaf413dac893ec1c79e43bebad" /> <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>