当前位置:首页 > 文章列表 > 文章 > 前端 > HTML发布文章流程:表单提交与数据库存储详解

HTML发布文章流程:表单提交与数据库存储详解

2025-12-10 13:36:36 0浏览 收藏
推广推荐
免费电影APP ➜
支持 PC / 移动端,安全直达

小伙伴们有没有觉得学习文章很有意思?有意思就对了!今天就给大家带来《HTML如何发布文章_表单提交与数据库存储流程》,以下内容将会涉及到,若是在学习中对其中部分知识点有疑问,或许看了本文就能帮到你!

答案:文章发布需前端表单收集数据,后端处理并存储至数据库,通过安全验证、富文本处理、图片上传及SEO优化实现完整流程。

html 如何发布文章_HTML文章发布(表单提交/数据库存储)流程方法

发布HTML文章,从前端的表单提交到后端的数据存储,本质上是一个客户端-服务器交互并持久化数据的过程。它通常涉及一个用户友好的输入界面(HTML表单),一个服务器端程序来处理这些输入,以及一个数据库来存储最终的文章内容。这个流程确保了内容可以被创建、保存,并最终动态地展示给读者。

解决方案

要实现HTML文章的发布,你需要构建一个前端表单来收集文章数据,并编写一个后端服务来接收、验证、处理这些数据,最终将其存储到数据库中。当用户访问网站时,后端再从数据库中读取数据并动态生成HTML页面展示文章。

前端(HTML表单)

首先,你需要一个HTML页面,其中包含一个表单,允许用户输入文章的标题、作者和内容。

<form action="/publish-article" method="post">
    <label for="articleTitle">文章标题:</label>
    &lt;input type=&quot;text&quot; id=&quot;articleTitle&quot; name=&quot;title&quot; required&gt;<br><br>

    <label for="articleAuthor">作者:</label>
    &lt;input type=&quot;text&quot; id=&quot;articleAuthor&quot; name=&quot;author&quot; required&gt;<br><br>

    <label for="articleContent">文章内容:</label>
    &lt;textarea id=&quot;articleContent&quot; name=&quot;content&quot; rows=&quot;15&quot; cols=&quot;80&quot;&gt;&lt;/textarea&gt;<br><br>

    <button type="submit">发布文章</button>
</form>

这里,action="/publish-article" 指定了表单数据将被发送到的服务器端URL,method="post" 表示数据将以POST请求发送。textarea 元素是用来输入文章主体内容的关键。

后端(服务器端处理与数据库交互)

服务器端脚本(例如,使用Node.js的Express、PHP、Python的Flask/Django等)负责接收这个POST请求,提取表单数据,进行必要的验证和清理,然后将数据插入到数据库。

以Node.js Express为例:

// 假设你已经设置了Express应用和数据库连接
const express = require('express');
const bodyParser = require('body-parser');
const mysql = require('mysql'); // 或者PostgreSQL, MongoDB等

const app = express();
app.use(bodyParser.urlencoded({ extended: true })); // 解析表单数据

// 数据库连接配置 (请替换为你的实际配置)
const db = mysql.createConnection({
    host: 'localhost',
    user: 'your_user',
    password: 'your_password',
    database: 'your_database'
});

db.connect((err) => {
    if (err) {
        console.error('数据库连接失败:', err);
        return;
    }
    console.log('数据库连接成功!');
});

// 处理文章发布请求
app.post('/publish-article', (req, res) => {
    const { title, author, content } = req.body;

    // 简单的数据验证
    if (!title || !author || !content) {
        return res.status(400).send('标题、作者和内容都不能为空。');
    }

    // 插入数据到数据库
    const sql = 'INSERT INTO articles (title, author, content, publish_date) VALUES (?, ?, ?, NOW())';
    db.query(sql, [title, author, content], (err, result) => {
        if (err) {
            console.error('文章插入失败:', err);
            return res.status(500).send('文章发布失败,请稍后再试。');
        }
        console.log('文章发布成功,ID:', result.insertId);
        res.status(200).send('文章发布成功!');
        // 实际应用中,这里通常会重定向到文章详情页或列表页
        // res.redirect('/articles/' + result.insertId);
    });
});

// 启动服务器
const PORT = process.env.PORT || 3000;
app.listen(PORT, () => {
    console.log(`服务器运行在 http://localhost:${PORT}`);
});

这个后端代码接收表单数据,并使用SQL的INSERT语句将其存入名为articles的数据库表。?是占位符,用于防止SQL注入攻击,这比直接拼接字符串安全得多。NOW()函数(MySQL)用于自动记录发布时间。

数据库结构

你需要一个数据库表来存储文章信息。以MySQL为例:

CREATE TABLE articles (
    id INT AUTO_INCREMENT PRIMARY KEY,
    title VARCHAR(255) NOT NULL,
    author VARCHAR(100) NOT NULL,
    content TEXT NOT NULL,
    publish_date DATETIME DEFAULT CURRENT_TIMESTAMP
);

content字段通常使用TEXT类型,因为它能存储较长的字符串,适合文章内容。

发布HTML文章时,如何确保数据安全和防止恶意注入?

数据安全在任何用户输入场景中都是重中之重,尤其是涉及到文章内容这种可能包含各种标签和脚本的数据。我的经验是,永远不要相信用户输入,必须在服务器端进行严格的验证、清理和转义。

首先,SQL注入是最大的威胁之一。如果直接将用户输入拼接到SQL查询字符串中,攻击者可以构造恶意输入来修改、删除甚至窃取你的数据库数据。避免这种风险的黄金法则就是使用预处理语句(Prepared Statements)参数化查询。在上面的Node.js示例中,db.query(sql, [title, author, content], ...)就是这种机制的体现。数据库驱动会负责正确地转义特殊字符,确保用户输入只被当作数据,而不是SQL代码。

其次,跨站脚本攻击(XSS)是另一个常见且危险的问题。如果用户在文章内容中插入 这样的代码,并且你直接将其展示在其他用户的浏览器上,那么这些脚本就会在其他用户的浏览器中执行,可能导致会话劫持、数据窃取等问题。为了防止XSS:

  1. HTML实体转义: 在将用户输入的HTML内容输出到浏览器之前,将所有可能被解释为HTML标签的字符(如<>&"')转换为对应的HTML实体(如<>)。这样浏览器就不会将其作为可执行的HTML代码来解析。
  2. 内容白名单过滤: 对于富文本编辑器生成的内容,你可能希望允许一部分HTML标签(如),但必须严格限制。这时,你需要使用一个强大的HTML净化库(如Node.js的DOMPurify,PHP的HTML Purifier)来过滤掉所有不安全或不允许的标签和属性。这比黑名单机制更安全,因为黑名单容易遗漏。

最后,输入验证是基础防线。在服务器端,你至少要检查:

如何处理HTML文章中的富文本编辑和图片上传?

单纯的<textarea>对于编写复杂格式的文章来说体验很差。真实世界的文章发布系统几乎都会集成富文本编辑器(Rich Text Editor, RTE)和图片上传功能。

富文本编辑器(RTE)

RTE,如TinyMCE、CKEditor、Quill.js等,能将普通的<textarea>转换成一个功能丰富的所见即所得(WYSIWYG)编辑界面。它们允许用户通过工具栏按钮轻松地添加粗体、斜体、链接、列表、图片等格式。

当用户使用RTE编辑完内容并提交时,RTE通常会将内容输出为一段HTML字符串。这段HTML字符串就是你需要存储到数据库content字段中的数据。

处理RTE输出的HTML时,XSS防护尤其重要。RTE虽然提供了方便的编辑功能,但也可能成为XSS的入口。例如,用户可以通过RTE的“插入HTML”功能,或者直接粘贴恶意HTML代码。因此,即便内容来自RTE,在存储到数据库之前和显示到页面之前,仍然需要进行严格的HTML净化。使用DOMPurify这类库来过滤掉所有不安全的标签和属性,只保留你允许的格式,是必不可少的步骤。

图片上传

图片上传通常是一个独立于文本内容的处理流程。

  1. 前端界面: 在RTE中通常会有一个图片上传按钮,或者表单中有一个独立的<input type="file" name="articleImage">
  2. 客户端预处理: JavaScript可以用于在图片上传前进行预览、压缩或裁剪。
  3. 服务器端接收: 当用户提交表单或通过AJAX上传图片时,服务器端脚本会接收到文件数据。
    • 文件验证: 检查文件类型(MIME Type,而不是仅仅文件名后缀),确保是图片(如image/jpeg, image/png),而不是可执行文件。
    • 文件大小: 限制文件大小,防止恶意攻击或服务器存储压力过大。
    • 重命名: 为上传的图片生成一个唯一的文件名(例如,使用UUID或时间戳),避免文件名冲突和路径遍历攻击。
    • 存储: 将图片保存到服务器上的一个指定目录(例如/uploads/images/)。永远不要将用户上传的文件直接存储在Web服务器的根目录下或可执行脚本的目录中。
    • 记录路径: 将图片的存储路径(URL)保存到数据库中。如果图片是文章内容的一部分,RTE会将其作为标签的src属性插入到文章HTML中。
  4. CDN集成: 对于大型应用,通常会将图片上传到对象存储服务(如AWS S3、阿里云OSS)或CDN,以提高访问速度和扩展性。

例如,一个图片上传的后端逻辑片段(Node.js Express with multer):

const multer = require('multer');
const path = require('path');

// 配置multer存储
const storage = multer.diskStorage({
    destination: function (req, file, cb) {
        cb(null, 'uploads/images/'); // 图片存储目录
    },
    filename: function (req, file, cb) {
        // 生成唯一文件名,例如:image-1678888888888.png
        cb(null, file.fieldname + '-' + Date.now() + path.extname(file.originalname));
    }
});

const upload = multer({
    storage: storage,
    limits: { fileSize: 5 * 1024 * 1024 }, // 限制文件大小5MB
    fileFilter: function (req, file, cb) {
        // 验证文件类型
        const filetypes = /jpeg|jpg|png|gif/;
        const mimetype = filetypes.test(file.mimetype);
        const extname = filetypes.test(path.extname(file.originalname).toLowerCase());

        if (mimetype && extname) {
            return cb(null, true);
        }
        cb('错误:只允许上传图片文件!');
    }
}).single('articleImage'); // 'articleImage' 是前端 input type="file" 的 name 属性

app.post('/upload-image', (req, res) => {
    upload(req, res, (err) => {
        if (err) {
            return res.status(400).send(err);
        }
        if (!req.file) {
            return res.status(400).send('没有选择文件。');
        }
        // 图片上传成功,返回图片URL
        const imageUrl = `/uploads/images/${req.file.filename}`;
        res.status(200).json({ url: imageUrl });
    });
});

前端RTE在用户上传图片成功后,会接收到这个imageUrl并将其插入到文章内容中。

文章发布后,如何实现内容的动态展示和搜索引擎优化(SEO)?

文章发布后,其价值在于被读者发现和阅读。这就涉及到内容的动态展示和如何让搜索引擎更好地理解和收录你的文章。

内容的动态展示

动态展示意味着文章不是预先写死的HTML文件,而是根据请求从数据库中读取并实时生成的。

  1. 路由配置: 你需要为文章详情页配置一个动态路由,例如 /articles/:id/articles/:slug:id代表文章ID,:slug代表一个人类可读的短链接(通常是文章标题的拼音或英文简化)。
  2. 数据库查询: 当用户访问 /articles/123 时,服务器端会根据URL中的ID(123)去数据库中查询对应的文章数据。
    // Node.js Express 示例
    app.get('/articles/:id', (req, res) => {
        const articleId = req.params.id;
        const sql = 'SELECT * FROM articles WHERE id = ?';
        db.query(sql, [articleId], (err, results) => {
            if (err || results.length === 0) {
                return res.status(404).send('文章未找到。');
            }
            const article = results[0];
            // 使用模板引擎渲染页面
            res.render('article_detail', { article: article });
            // 或者直接发送HTML
            // res.send(`<h1>${article.title}</h1><p>作者: ${article.author}</p><div>${article.content}</div>`);
        });
    });
  3. 模板渲染: 查询到数据后,通常会使用服务器端模板引擎(如EJS、Pug、Handlebars for Node.js;Jinja2 for Python;Twig for PHP)将文章数据填充到一个HTML模板中,生成完整的HTML页面,然后发送给客户端浏览器。这使得页面内容可以根据数据库中的数据灵活变化。

搜索引擎优化(SEO)

为了让你的文章更容易被搜索引擎(如Google、百度)发现和排名靠前,SEO是不可或缺的。

  1. 友好的URL结构: 使用包含关键词的、可读性强的URL,而不是像 view.php?id=123 这样的参数型URL。例如,example.com/articles/html-article-publishing-guide 远比 example.com/article.php?id=5 更利于SEO。这通常通过服务器端的URL重写(URL Rewriting)或路由配置实现。
  2. Meta标签优化:
    • </code>标签:</strong> 确保每个文章页面都有一个独特且描述性的<code><title></code>标签,包含文章的核心关键词。这是搜索引擎排名最重要的因素之一。</li><li><strong><code><meta name="description" content="..."></code>:</strong> 提供一个简洁、吸引人的页面描述,通常在搜索结果中显示。这应该动态地从文章摘要或前几段内容生成。</li><li><strong>Open Graph (OG) 标签和 Twitter Cards:</strong> 这些标签对于社交媒体分享至关重要,能控制文章在Facebook、Twitter等平台上的展示方式(标题、图片、描述)。</li></ul></li><li><strong>语义化HTML结构:</strong> 使用HTML5的语义化标签,如<code><article></code>、<code><section></code>、<code><header></code>、<code><footer></code>、<code><nav></code>、<code><aside></code>等。文章标题使用<code><h1></code>,子标题使用<code><h2></code>、<code><h3></code>等。图片务必添加<code>alt</code>属性,描述图片内容。这些都有助于搜索引擎理解页面结构和内容。</li><li><strong>内容质量和关键词:</strong> 撰写高质量、原创、有深度的内容,自然地融入相关的关键词。避免关键词堆砌。</li><li><strong>站点地图(Sitemap.xml):</strong> 生成并提交一个<code>sitemap.xml</code>文件给搜索引擎,列出你网站上所有可供抓取的URL。对于动态生成的文章,你需要一个机制来自动更新这个sitemap。</li><li><strong>结构化数据(Schema Markup):</strong> 使用JSON-LD或Microdata等格式,为文章添加结构化数据(例如<code>Article</code> Schema)。这可以帮助搜索引擎更好地理解文章的类型、作者、发布日期等信息,有时还能在搜索结果中显示富摘要(Rich Snippets)。<pre><script type="application/ld+json"> { "@context": "https://schema.org", "@type": "Article", "headline": "HTML文章发布流程详解", "image": [ "https://example.com/images/article-banner.jpg" ], "datePublished": "2023-10-27T08:00:00+08:00", "author": { "@type": "Person", "name": "你的名字" }, "publisher": { "@type": "Organization", "name": "你的网站名称", "logo": { "@type": "ImageObject", "url": "https://example.com/logo.png" } }, "description": "本文详细介绍了HTML文章从表单提交到数据库存储的整个发布流程,并探讨了数据安全与SEO策略。" } </script></pre></li><li><strong>移动友好性:</strong> 确保你的网站在各种设备(手机、平板)上都能良好显示,响应式设计是标配。Google等搜索引擎会将移动友好性作为排名因素。</li><li><strong>网站性能:</strong> 页面加载速度是SEO的重要因素。优化图片、使用缓存、减少HTTP请求、压缩代码等都能提升网站性能。</li></ol><p>通过综合运用这些技术和策略,你的HTML文章发布系统不仅能高效地管理内容,还能确保这些内容在互联网上获得更好的曝光和排名。</p><p>今天关于《HTML发布文章流程:表单提交与数据库存储详解》的内容就介绍到这里了,是不是学起来一目了然!想要了解更多关于的内容请关注golang学习网公众号!</p> </div> <div class="labsList"> </div> <div class="cateBox"> <div class="cateItem"> <a href="/article/415270.html" title="Qwen3-TTS升级:49音色10语言9方言" class="img_box"> <img src="/uploads/20251210/1765344994693906e21297a.png" onerror="this.onerror='',this.src='/assets/images/moren/morentu.png'" alt="Qwen3-TTS升级:49音色10语言9方言">Qwen3-TTS升级:49音色10语言9方言 </a> <dl> <dt class="lineOverflow"><a href="/article/415270.html" title="Qwen3-TTS升级:49音色10语言9方言" class="aBlack">上一篇<i></i></a></dt> <dd class="lineTwoOverflow">Qwen3-TTS升级:49音色10语言9方言</dd> </dl> </div> <div class="cateItem"> <a href="/article/415272.html" title="QQ邮箱官网登录入口及手机登录方法" class="img_box"> <img src="/uploads/20251210/1765344993693906e1d6167.png" onerror="this.onerror='',this.src='/assets/images/moren/morentu.png'" alt="QQ邮箱官网登录入口及手机登录方法"> </a> <dl> <dt class="lineOverflow"><a href="/article/415272.html" class="aBlack" title="QQ邮箱官网登录入口及手机登录方法">下一篇<i></i></a></dt> <dd class="lineTwoOverflow">QQ邮箱官网登录入口及手机登录方法</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/415340.html" class="img_box" title="平板运行HTML的优化技巧"> <img src="/uploads/20251210/1765347865693912193ff3a.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="html">html</a> </span> </dd> <dt class="lineOverflow"> <a href="/article/415340.html" class="aBlack" target="_blank" title="平板运行HTML的优化技巧">平板运行HTML的优化技巧</a> </dt> <dd class="cont2"> <span><i class="view"></i>420浏览</span> <span class="collectBtn user_collection" data-id="415340" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/415338.html" class="img_box" title="HTML链接怎么添加?简单教程分享"> <img src="/uploads/20251210/1765347811693911e3b8281.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>   |  6分钟前  |   <a href="javascript:;" class="aLightGray" title="html">html</a> </span> </dd> <dt class="lineOverflow"> <a href="/article/415338.html" class="aBlack" target="_blank" title="HTML链接怎么添加?简单教程分享">HTML链接怎么添加?简单教程分享</a> </dt> <dd class="cont2"> <span><i class="view"></i>359浏览</span> <span class="collectBtn user_collection" data-id="415338" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/415335.html" class="img_box" title="JS如何判断数据类型?typeof局限性详解"> <img src="/uploads/20251210/17653476926939116c09a80.jpg" onerror="this.src='/assets/images/moren/morentu.png'" alt="JS如何判断数据类型?typeof局限性详解"> </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分钟前  |   </span> </dd> <dt class="lineOverflow"> <a href="/article/415335.html" class="aBlack" target="_blank" title="JS如何判断数据类型?typeof局限性详解">JS如何判断数据类型?typeof局限性详解</a> </dt> <dd class="cont2"> <span><i class="view"></i>272浏览</span> <span class="collectBtn user_collection" data-id="415335" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/415333.html" class="img_box" title="TensorFlow.js机器学习实战教程"> <img src="/uploads/20251210/1765347575693910f7cf2bc.jpg" onerror="this.src='/assets/images/moren/morentu.png'" alt="TensorFlow.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>   |  10分钟前  |   </span> </dd> <dt class="lineOverflow"> <a href="/article/415333.html" class="aBlack" target="_blank" title="TensorFlow.js机器学习实战教程">TensorFlow.js机器学习实战教程</a> </dt> <dd class="cont2"> <span><i class="view"></i>257浏览</span> <span class="collectBtn user_collection" data-id="415333" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/415329.html" class="img_box" title="HTML模态框实现方法详解"> <img src="/uploads/20251210/17653474556939107febc44.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>   |  12分钟前  |   <a href="javascript:;" class="aLightGray" title="如何编辑网页html">如何编辑网页html</a> </span> </dd> <dt class="lineOverflow"> <a href="/article/415329.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="415329" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/415323.html" class="img_box" title="HTML加载CSS样式全解析"> <img src="/uploads/20251210/176534715969390f57ad03e.png" onerror="this.src='/assets/images/moren/morentu.png'" alt="HTML加载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>   |  17分钟前  |   <a href="javascript:;" class="aLightGray" title="html">html</a> </span> </dd> <dt class="lineOverflow"> <a href="/article/415323.html" class="aBlack" target="_blank" title="HTML加载CSS样式全解析">HTML加载CSS样式全解析</a> </dt> <dd class="cont2"> <span><i class="view"></i>112浏览</span> <span class="collectBtn user_collection" data-id="415323" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/415318.html" class="img_box" title="CSSpadding优化图标文字间距技巧"> <img src="/uploads/20251210/176534697369390e9d27155.jpg" onerror="this.src='/assets/images/moren/morentu.png'" alt="CSSpadding优化图标文字间距技巧"> </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>   |  20分钟前  |   </span> </dd> <dt class="lineOverflow"> <a href="/article/415318.html" class="aBlack" target="_blank" title="CSSpadding优化图标文字间距技巧">CSSpadding优化图标文字间距技巧</a> </dt> <dd class="cont2"> <span><i class="view"></i>181浏览</span> <span class="collectBtn user_collection" data-id="415318" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/415316.html" class="img_box" title="标签模板字符串怎么用?详解JS语法"> <img src="/uploads/20251210/176534690669390e5af263d.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>   |  21分钟前  |   </span> </dd> <dt class="lineOverflow"> <a href="/article/415316.html" class="aBlack" target="_blank" title="标签模板字符串怎么用?详解JS语法">标签模板字符串怎么用?详解JS语法</a> </dt> <dd class="cont2"> <span><i class="view"></i>170浏览</span> <span class="collectBtn user_collection" data-id="415316" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/415304.html" class="img_box" title="CSSflex主轴对齐设置方法"> <img src="/uploads/20251210/176534643269390c80952f4.jpg" onerror="this.src='/assets/images/moren/morentu.png'" alt="CSSflex主轴对齐设置方法"> </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>   |  29分钟前  |   </span> </dd> <dt class="lineOverflow"> <a href="/article/415304.html" class="aBlack" target="_blank" title="CSSflex主轴对齐设置方法">CSSflex主轴对齐设置方法</a> </dt> <dd class="cont2"> <span><i class="view"></i>367浏览</span> <span class="collectBtn user_collection" data-id="415304" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/415297.html" class="img_box" title="JavaScript对象合并技巧:Object.assign使用方法"> <img src="/uploads/20251210/176534610969390b3dd0b6a.png" onerror="this.src='/assets/images/moren/morentu.png'" alt="JavaScript对象合并技巧:Object.assign使用方法"> </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分钟前  |   <a href="javascript:;" class="aLightGray" title="对象合并">对象合并</a> </span> </dd> <dt class="lineOverflow"> <a href="/article/415297.html" class="aBlack" target="_blank" title="JavaScript对象合并技巧:Object.assign使用方法">JavaScript对象合并技巧:Object.assign使用方法</a> </dt> <dd class="cont2"> <span><i class="view"></i>328浏览</span> <span class="collectBtn user_collection" data-id="415297" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/415289.html" class="img_box" title="CSS多主题切换优化技巧详解"> <img src="/uploads/20251210/1765345770693909ea130c3.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>   |  40分钟前  |   </span> </dd> <dt class="lineOverflow"> <a href="/article/415289.html" class="aBlack" target="_blank" title="CSS多主题切换优化技巧详解">CSS多主题切换优化技巧详解</a> </dt> <dd class="cont2"> <span><i class="view"></i>300浏览</span> <span class="collectBtn user_collection" data-id="415289" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/415264.html" class="img_box" title="CSS实现选中对勾效果教程"> <img src="/uploads/20251210/1765344694693905b6e7c0e.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>   |  58分钟前  |   </span> </dd> <dt class="lineOverflow"> <a href="/article/415264.html" class="aBlack" target="_blank" title="CSS实现选中对勾效果教程">CSS实现选中对勾效果教程</a> </dt> <dd class="cont2"> <span><i class="view"></i>354浏览</span> <span class="collectBtn user_collection" data-id="415264" 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">3251次使用</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">3463次使用</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">3495次使用</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">4607次使用</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">3872次使用</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/415271.html"/> <input type="hidden" name="__token__" value="0cb8f9ca174a54603eb72f2834d7331f" /> <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/415271.html"/> <input type="hidden" name="__token__" value="0cb8f9ca174a54603eb72f2834d7331f" /> <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>