当前位置:首页 > 文章列表 > 文章 > 前端 > HTML与CSS基础结构及样式教程

HTML与CSS基础结构及样式教程

2025-11-05 16:39:53 0浏览 收藏

网页开发入门必读:本文深入浅出地讲解了HTML与CSS的基础结构与样式,助你快速掌握构建网页的核心技能。HTML负责搭建网页的骨架,通过语义化标签定义内容结构,而CSS则负责美化页面,利用选择器精准控制样式。文章详细介绍了HTML常用标签、语义化布局,以及CSS选择器的使用方法,并深入剖析了CSS盒模型,助你理解页面布局的基石。此外,还分享了高效组织和管理HTML与CSS文件的技巧,提升开发效率,是前端开发初学者的必备教程。掌握HTML和CSS,你就能轻松创建出结构清晰、美观大方的网页。

HTML和CSS是网页开发的基础,HTML负责结构,CSS负责样式,二者结合通过语义化标签和选择器实现内容与表现分离,利用盒模型进行布局,并通过模块化文件管理提升开发效率。

怎么HTML和CSS_HTML与CSS基础结构与样式编写入门教程

要开始构建任何网页,HTML和CSS是你的左膀右臂。简单来说,HTML负责搭建页面的骨架和内容,就像你盖房子先搭框架、砌墙一样;而CSS则负责给这个骨架穿上衣服、涂上颜色、摆放家具,让它看起来美观、有风格,并能根据需要灵活调整布局。它们俩缺一不可,共同决定了用户最终看到的网页是什么样子。

解决方案

理解HTML和CSS的基础,首先要明白它们各自的职责边界,以及如何协同工作。HTML(超文本标记语言)是用来定义网页内容的结构和语义的,比如哪些是标题,哪些是段落,哪里是图片,哪里是链接。它通过一系列预定义的“标签”(tags)来标记这些内容。而CSS(层叠样式表)则专门用于描述HTML文档的呈现样式,比如字体大小、颜色、背景、边距,甚至是复杂的布局。

它们结合起来,最常见的做法就是将CSS代码独立存储在一个.css文件中,然后通过HTML的标签将其引入到HTML文档中。这样,内容和样式就能有效分离,便于管理和维护。举个例子,一个最简单的HTML文件可能长这样:




    
    
    我的第一个网页
     


    

欢迎来到我的世界

这是一段关于HTML和CSS的介绍。

© 2023 我的网站

而对应的style.css文件可能包含:

body {
    font-family: 'Arial', sans-serif;
    margin: 0;
    padding: 0;
    background-color: #f4f4f4;
    color: #333;
}

header {
    background-color: #333;
    color: #fff;
    padding: 20px;
    text-align: center;
}

h1 {
    font-size: 2.5em;
    margin-bottom: 10px;
}

main {
    padding: 20px;
    max-width: 800px;
    margin: 20px auto;
    background-color: #fff;
    box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
}

p {
    line-height: 1.6;
}

button {
    background-color: #007bff;
    color: white;
    padding: 10px 15px;
    border: none;
    border-radius: 5px;
    cursor: pointer;
    transition: background-color 0.3s ease;
}

button:hover {
    background-color: #0056b3;
}

footer {
    text-align: center;
    padding: 20px;
    background-color: #333;
    color: #fff;
    margin-top: 30px;
}

通过这种方式,我们既定义了页面的结构,又赋予了它独特的外观。

HTML网页骨架:常用标签与语义化布局实践

构建一个网页,就像搭建一座房子,首先得有框架和不同的功能区域。HTML的核心就是这些“框架”——各种标签。从最基础的声明开始,它告诉浏览器这是一个HTML5文档。接着是根元素,所有内容都在它里面。又分为两大部分。里放的是页面的元信息,比如字符集()、视口设置(),还有最重要的页面标题(</code>),以及引入外部CSS文件(<code><link rel="stylesheet" href="style.css"></code>)。这些内容用户通常看不到,但对浏览器解析和搜索引擎优化至关重要。</p><p>而所有用户可见的内容,都放在<code><body></code>标签里。这里面才是我们真正“写”页面的地方。我们用各种标签来组织内容,比如:</p><ul><li><strong>标题:</strong> <code><h1></code>到<code><h6></code>,数字越小,标题级别越高,字体越大。这不仅仅是视觉上的大小,更是语义上的重要性。</li><li><strong>段落:</strong> <code><p></code>用于包裹普通文本段落。</li><li><strong>链接:</strong> <code><a></code>(anchor)标签,通过<code>href</code>属性指定跳转目标。</li><li><strong>图片:</strong> <code><img></code>标签,通过<code>src</code>属性指定图片路径,<code>alt</code>属性提供图片描述,对SEO和无障碍访问非常重要。</li><li><strong>列表:</strong> 无序列表<code><ul></code>和有序列表<code><ol></code>,每个列表项用<code><li></code>表示。</li><li><strong>容器:</strong> <code><div></code>是一个通用的块级容器,常用于布局。<code><span></code>是一个通用的行内容器。它们本身没有语义,但通过CSS可以赋予它们任何样式。</li></ul><p>随着HTML5的出现,我们有了更多语义化的标签,这让我们的代码更具可读性,也对搜索引擎更友好。比如:</p><ul><li><code><header></code>:通常用于页面的顶部,包含网站Logo、导航等。</li><li><code><nav></code>:包含导航链接。</li><li><code><main></code>:页面的主要内容,一个页面通常只有一个<code><main></code>。</li><li><code><article></code>:独立的、可分发的内容,比如一篇文章或博客帖子。</li><li><code><section></code>:页面中一个独立的通用内容区块。</li><li><code><footer></code>:页面的底部,通常包含版权信息、联系方式等。</li></ul><p>使用这些语义化标签,不仅让我们的代码结构更清晰,也帮助辅助阅读设备更好地理解页面内容。这不仅仅是写给浏览器看的,更是写给未来维护者和搜索引擎看的。比如,一个博客文章的结构可能会是这样:</p><pre class="brush:language-html;toolbar:false;"><article> <header> <h1>我的第一篇博客文章</h1> <p>作者:张三,发布日期:2023年10月27日</p> </header> <section> <h2>引言</h2> <p>这是文章的引言部分,介绍文章的主题。</p> </section> <section> <h2>正文</h2> <p>这里是文章的主要内容。</p> <ul> <li>要点一</li> <li>要点二</li> </ul> </section> <footer> <p>标签:HTML, CSS, 入门</p> </footer> </article></pre><p>这样的结构,即使没有CSS样式,也能清晰地表达出内容的层级和关系。</p><h3>CSS选择器:精准定位与样式应用之道</h3><p>CSS之所以强大,很大程度上在于其选择器机制。选择器就像是CSS的“瞄准镜”,它能让我们精确地找到HTML文档中的特定元素,然后把样式应用上去。如果不理解选择器,你的样式可能会作用到不该作用的地方,或者根本不生效。</p><p>最基础的选择器有几种:</p><ul><li><strong>元素选择器 (Type Selector):</strong> 直接用HTML标签名来选择。比如<code>p { color: blue; }</code>会把所有<code><p></code>标签的文字变成蓝色。</li><li><strong>类选择器 (Class Selector):</strong> 通过元素的<code>class</code>属性来选择。HTML元素可以有多个类。在CSS中使用<code>.</code>前缀。比如<code><p class="highlight"></code>对应的CSS是<code>.highlight { background-color: yellow; }</code>。这种方式非常灵活,可以复用。</li><li><strong>ID选择器 (ID Selector):</strong> 通过元素的<code>id</code>属性来选择。<code>id</code>在一个HTML文档中必须是唯一的。在CSS中使用<code>#</code>前缀。比如<code><div id="main-header"></code>对应的CSS是<code>#main-header { font-size: 3em; }</code>。ID选择器的优先级很高,但因为它唯一性,通常用于JavaScript操作或特定布局区域。</li></ul><p>除了这些,还有更高级、更复杂的组合:</p><ul><li><strong>后代选择器 (Descendant Selector):</strong> 选中某个元素内部的所有特定后代元素。例如<code>div p { margin-bottom: 10px; }</code>会选中所有<code><div></code>内部的<code><p></code>标签。</li><li><strong>子选择器 (Child Selector):</strong> 只选中某个元素的直接子元素。例如<code>ul > li { list-style-type: square; }</code>只会选中<code><ul></code>的直接子<code><li></code>。</li><li><strong>相邻兄弟选择器 (Adjacent Sibling Selector):</strong> 选中紧接在某个元素后面的兄弟元素。例如<code>h1 + p { text-indent: 2em; }</code>会选中紧跟在<code><h1></code>后面的第一个<code><p></code>。</li><li><strong>通用兄弟选择器 (General Sibling Selector):</strong> 选中某个元素之后的所有兄弟元素。例如<code>h1 ~ p { color: gray; }</code>会选中<code><h1></code>之后的所有<code><p></code>。</li><li><strong>属性选择器 (Attribute Selector):</strong> 根据元素的属性和属性值来选择。例如<code>a[target="_blank"] { color: red; }</code>会选中所有<code>target</code>属性值为<code>_blank</code>的<code><a></code>标签。</li><li><strong>伪类 (Pseudo-classes):</strong> 选中处于特定状态的元素。例如<code>a:hover { text-decoration: underline; }</code>会在鼠标悬停在链接上时添加下划线。其他常见的有<code>:focus</code>, <code>:active</code>, <code>:nth-child()</code>, <code>:first-child</code>, <code>:last-child</code>等。</li><li><strong>伪元素 (Pseudo-elements):</strong> 选中元素的特定部分。例如<code>p::first-letter { font-size: 2em; }</code>会选中段落的第一个字母。其他有<code>::before</code>, <code>::after</code>,常用于创建装饰性内容。</li></ul><p>理解这些选择器,特别是它们的优先级(specificity),是写好CSS的关键。简单来说,ID选择器优先级高于类选择器,类选择器高于元素选择器。当多个规则作用于同一个元素时,优先级高的规则会生效。如果优先级相同,则后定义的规则会覆盖先定义的。有时候,你可能会看到<code>!important</code>,它能强制提升某个声明的优先级,但通常建议避免滥用,因为它会破坏CSS的层叠机制,让调试变得困难。</p><p>来看个例子:</p><pre class="brush:language-css;toolbar:false;">/* 元素选择器 */ p { font-size: 16px; } /* 类选择器 */ .intro-text { color: #444; } /* ID选择器 */ #main-title { text-align: center; font-weight: bold; } /* 后代选择器 */ .card h2 { color: #0056b3; border-bottom: 1px solid #eee; } /* 伪类 */ button:hover { opacity: 0.9; } /* 伪元素 */ .quote::before { content: "“"; font-size: 2em; vertical-align: middle; margin-right: 5px; }</pre><p>通过这些选择器,我们能精确地控制页面上每一个元素的样式,实现复杂的视觉效果。</p><h3>CSS盒模型:布局的基石与尺寸计算逻辑</h3><p>CSS盒模型,这是前端布局里一个绕不开的核心概念,也是很多新手容易感到困惑的地方。但一旦你真正理解了它,你就会发现,所有元素的布局、尺寸计算都围绕着它展开。你可以把HTML页面上的每个元素都想象成一个矩形的“盒子”,这个盒子由四个部分组成:内容区(Content)、内边距(Padding)、边框(Border)、外边距(Margin)。</p><ol><li><strong>内容区 (Content):</strong> 这是盒子最核心的部分,比如文本、图片等实际内容占据的空间。它的尺寸由<code>width</code>和<code>height</code>属性决定。</li><li><strong>内边距 (Padding):</strong> 内容区和边框之间的空间。它用于增加内容与边框之间的距离,让内容不至于“贴”在边框上。<code>padding</code>会增加元素的总尺寸。</li><li><strong>边框 (Border):</strong> 围绕在内边距外面的线。你可以设置它的宽度、样式和颜色。<code>border</code>同样会增加元素的总尺寸。</li><li><strong>外边距 (Margin):</strong> 边框外面的空间,用于控制元素与其他元素之间的距离。<code>margin</code>不会增加元素的实际尺寸,但会影响它在页面上的位置和与其他元素的间距。</li></ol><p>默认情况下,CSS盒模型是<code>content-box</code>。这意味着当你设置一个元素的<code>width</code>和<code>height</code>时,它们只应用于内容区。如果你再添加<code>padding</code>和<code>border</code>,元素的总宽度和总高度就会是:</p><ul><li><strong>总宽度 = <code>width</code> + <code>padding-left</code> + <code>padding-right</code> + <code>border-left-width</code> + <code>border-right-width</code></strong></li><li><strong>总高度 = <code>height</code> + <code>padding-top</code> + <code>padding-bottom</code> + <code>border-top-width</code> + <code>border-bottom-width</code></strong></li></ul><p>这在进行精确布局时,常常会让人感到头疼,因为每次计算元素总尺寸都要考虑这些额外的部分。</p><p>为了解决这个问题,CSS3引入了<code>box-sizing</code>属性,其中最常用的值是<code>border-box</code>。当你设置<code>box-sizing: border-box;</code>时,<code>width</code>和<code>height</code>属性将包括内容区、内边距和边框。也就是说:</p><ul><li><strong>总宽度 = <code>width</code></strong></li><li><strong>总高度 = <code>height</code></strong></li></ul><p>在这种模式下,你设置的<code>width</code>和<code>height</code>就是元素在页面上占据的实际可见空间,<code>padding</code>和<code>border</code>会“挤压”内容区的空间,而不是向外扩展。这使得布局计算变得直观得多,特别是在响应式设计和网格布局中,<code>border-box</code>几乎成了标准实践。通常,我们会在CSS的开头加上:</p><pre class="brush:language-css;toolbar:false;">/* 让所有元素的盒模型都采用 border-box */ html { box-sizing: border-box; } *, *::before, *::after { box-sizing: inherit; }</pre><p>这段代码会确保所有元素都继承<code>border-box</code>的盒模型行为,极大简化了布局计算。</p><p>理解盒模型对于处理元素之间的间距、对齐以及响应式设计至关重要。比如,当两个垂直方向的元素都有<code>margin</code>时,它们的<code>margin</code>可能会发生“外边距合并”(margin collapsing),即取两者中较大的那个值作为最终的间距,而不是简单相加。这些都是你在实践中会遇到的细节,掌握盒模型能让你更好地预测和控制元素的行为。</p><pre class="brush:language-html;toolbar:false;"><div class="box content-box-example"> 内容区 </div> <div class="box border-box-example"> 内容区 (border-box) </div></pre><pre class="brush:language-css;toolbar:false;">.box { width: 100px; height: 100px; padding: 20px; border: 5px solid black; margin: 10px; background-color: lightblue; text-align: center; line-height: 100px; /* 垂直居中文本 */ } .content-box-example { /* 默认行为,总宽度 = 100 + 2*20 + 2*5 = 150px */ box-sizing: content-box; } .border-box-example { /* 总宽度 = 100px,内容区会被压缩 */ box-sizing: border-box; background-color: lightcoral; }</pre><p>通过这个例子,你可以直观地看到两种盒模型下,即使<code>width</code>和<code>height</code>设置相同,元素最终占据的空间却是不同的。</p><h3>高效组织与管理HTML和CSS文件,提升开发效率</h3><p>在小型项目甚至是一些个人页面中,我们可能习惯于把所有CSS都写在一个<code>style.css</code>文件里,或者干脆直接写在HTML的<code><style></code>标签中。但这在稍大一点的项目中,很快就会变得难以管理和维护。想象一下,一个上千行的CSS文件,你要找一个特定按钮的样式,那简直是噩梦。因此,一套清晰的文件组织和管理策略是提升开发效率的关键。</p><ol><li><p><strong>外部样式表优先:</strong> 始终优先使用外部CSS文件(通过<code><link rel="stylesheet" href="path/to/style.css"></code>引入)。这不仅实现了内容与样式的分离,让HTML文件更干净,也让CSS文件可以被多个HTML页面复用,减少了代码冗余。浏览器还会缓存外部CSS文件,提升页面加载速度。</p></li><li><p><strong>模块化CSS:</strong> 不要把所有CSS都堆在一个文件里。根据功能、组件或页面区域进行拆分。例如:</p><ul><li><code>base.css</code>:定义全局样式,如字体、颜色变量、重置样式(reset.css 或 normalize.css)。</li><li><code>layout.css</code>:定义页面整体布局,如header、footer、main、sidebar等。</li><li><code>components/button.css</code>:针对特定组件的样式,如按钮、卡片、表单。</li><li><code>pages/home.css</code>:针对特定页面的特殊样式。</li><li><code>utilities.css</code>:一些常用的工具类,如清除浮动、隐藏元素等。 然后,你可以在主CSS文件(比如<code>style.css</code>)中,使用<code>@import</code>规则将这些模块化的文件导入进来,或者在HTML中引入多个<code><link></code>标签。</li></ul><pre class="brush:language-css;toolbar:false;">/* style.css */ @import 'base.css'; @import 'layout.css'; @import 'components/button.css'; /* ... 更多模块 */</pre></li><li><p><strong>文件夹结构:</strong> 一个清晰的项目文件夹结构,能让你一眼就知道什么文件放在哪里。一个常见的结构是:</p><pre class="brush:php;toolbar:false;">my-project/ ├── index.html ├── about.html ├── css/ │ ├── base.css │ ├── layout.css │ ├── components/ │ │ ├── button.css │ │ └── card.css │ └── pages/ │ └── home.css ├── js/ │ ├── main.js │ └── modules/ │ └── carousel.js └── img/ ├── logo.png └── background.jpg</pre><p>这种结构让文件各司其职,查找和修改都非常方便。</p></li><li><p><strong>命名规范:</strong> 遵循一致的命名规范,如BEM(Block Element Modifier)、SMACSS或OOCSS等,能让CSS类名更具语义化,减少冲突,提高可读性。例如,BEM会将一个按钮命名为<code>.button</code>,它的变体是<code>.button--primary</code>,按钮内的文本是<code>.button__text</code>。</p></li><li><p><strong>注释:</strong> 在复杂的CSS文件中,添加清晰的注释说明代码块的功能、目的或任何特殊注意事项,对于团队协作和未来维护至关重要。</p></li><li><p><strong>预处理器(Preprocessors):</strong> 对于大型项目,Sass、Less或Stylus等CSS预处理器能极大地提升开发效率。它们引入了变量、嵌套、混合(mixins)、函数等编程特性,让CSS更具动态性和可维护性。例如,你可以定义颜色变量,在多处复用,一旦需要修改,只需改一个地方。</p><pre class="brush:language-scss;toolbar:false;">/* _variables.scss (Sass示例) */ $primary-color: #007bff; $font-stack: 'Arial', sans-serif; /* button.scss */ .button { background-color: $primary-color; font-family: $font-stack; /* ... */ }</pre><p>预处理器代码最终会被编译成标准的CSS文件。</p></li></ol><p>通过这些策略,我们不仅能写出功能正常的代码,更能写出</p><p>今天带大家了解了的相关知识,希望对你有所帮助;关于文章的技术知识我们会一点点深入介绍,欢迎大家关注golang学习网公众号,一起学习编程~</p> </div> <div class="labsList"> <a href="javascript:;" title="html">html</a> <a href="javascript:;" title="CSS">CSS</a> <a href="javascript:;" title="网页开发">网页开发</a> <a href="javascript:;" title="CSS选择器">CSS选择器</a> <a href="javascript:;" title="CSS盒模型">CSS盒模型</a> </div> <div class="cateBox"> <div class="cateItem"> <a href="/article/373204.html" title="CSS子元素伸缩比例设置技巧" class="img_box"> <img src="/uploads/20251105/1762331976690b0d481c186.jpg" onerror="this.onerror='',this.src='/assets/images/moren/morentu.png'" alt="CSS子元素伸缩比例设置技巧">CSS子元素伸缩比例设置技巧 </a> <dl> <dt class="lineOverflow"><a href="/article/373204.html" title="CSS子元素伸缩比例设置技巧" class="aBlack">上一篇<i></i></a></dt> <dd class="lineTwoOverflow">CSS子元素伸缩比例设置技巧</dd> </dl> </div> <div class="cateItem"> <a href="/article/373206.html" title="WebSocket协议详解与应用解析" class="img_box"> <img src="/uploads/20251105/1762332032690b0d80c1b97.png" onerror="this.onerror='',this.src='/assets/images/moren/morentu.png'" alt="WebSocket协议详解与应用解析"> </a> <dl> <dt class="lineOverflow"><a href="/article/373206.html" class="aBlack" title="WebSocket协议详解与应用解析">下一篇<i></i></a></dt> <dd class="lineTwoOverflow">WebSocket协议详解与应用解析</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/620135.html" class="img_box" title="前端长列表卡顿怎么优化:从全量 DOM 到虚拟列表架构"> <img src="/uploads/20260701/1782888878-frontend-dom-waiting-chain.webp" onerror="this.src='/assets/images/moren/morentu.png'" alt="前端长列表卡顿怎么优化:从全量 DOM 到虚拟列表架构"> </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="/articletag/243_new_0_1.html" class="aLightGray" title="前端">前端</a> · <a href="/articletag/729_new_0_1.html" class="aLightGray" title="性能优化">性能优化</a> · <a href="/articletag/2774_new_0_1.html" class="aLightGray" title="dom">dom</a> · <a href="/articletag/39783_new_0_1.html" class="aLightGray" title="虚拟列表">虚拟列表</a> · <a href="javascript:;" class="aLightGray" title="JavaScript">JavaScript</a> <a href="javascript:;" class="aLightGray" title="前端">前端</a> <a href="javascript:;" class="aLightGray" title="滚动性能">滚动性能</a> <a href="javascript:;" class="aLightGray" title="虚拟列表">虚拟列表</a> <a href="javascript:;" class="aLightGray" title="长列表优化">长列表优化</a> <a href="javascript:;" class="aLightGray" title="DOM性能">DOM性能</a> </span> </dd> <dt class="lineOverflow"> <a href="/article/620135.html" class="aBlack" target="_blank" title="前端长列表卡顿怎么优化:从全量 DOM 到虚拟列表架构">前端长列表卡顿怎么优化:从全量 DOM 到虚拟列表架构</a> </dt> <dd class="cont2"> <span><i class="view"></i>260浏览</span> <span class="collectBtn user_collection" data-id="620135" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/620123.html" class="img_box" title="前端按钮重复提交怎么办:loading 锁和 AbortController 最小配方"> <img src="/uploads/20260701/1782875790-double-submit-fix-recipe.webp" onerror="this.src='/assets/images/moren/morentu.png'" alt="前端按钮重复提交怎么办:loading 锁和 AbortController 最小配方"> </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>   |  9小时前  |   <a href="/articletag/243_new_0_1.html" class="aLightGray" title="前端">前端</a> · <a href="/articletag/4701_new_0_1.html" class="aLightGray" title="javascript">javascript</a> · <a href="/articletag/39917_new_0_1.html" class="aLightGray" title="AbortController">AbortController</a> · <a href="/articletag/39920_new_0_1.html" class="aLightGray" title="表单提交">表单提交</a> · <a href="javascript:;" class="aLightGray" title="AbortController">AbortController</a> <a href="javascript:;" class="aLightGray" title="旧响应覆盖">旧响应覆盖</a> <a href="javascript:;" class="aLightGray" title="前端重复提交">前端重复提交</a> <a href="javascript:;" class="aLightGray" title="loading锁">loading锁</a> <a href="javascript:;" class="aLightGray" title="fetch取消">fetch取消</a> <a href="javascript:;" class="aLightGray" title="按钮防抖">按钮防抖</a> </span> </dd> <dt class="lineOverflow"> <a href="/article/620123.html" class="aBlack" target="_blank" title="前端按钮重复提交怎么办:loading 锁和 AbortController 最小配方">前端按钮重复提交怎么办:loading 锁和 AbortController 最小配方</a> </dt> <dd class="cont2"> <span><i class="view"></i>442浏览</span> <span class="collectBtn user_collection" data-id="620123" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/620112.html" class="img_box" title="前端发布后白屏复盘:Service Worker 缓存旧入口导致 JS 资源 404"> <img src="/uploads/20260630/1782799139-sw-old-entry-404-path.webp" onerror="this.src='/assets/images/moren/morentu.png'" alt="前端发布后白屏复盘:Service Worker 缓存旧入口导致 JS 资源 404"> </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>   |  1天前  |   <a href="/articletag/243_new_0_1.html" class="aLightGray" title="前端">前端</a> · <a href="/articletag/322_new_0_1.html" class="aLightGray" title="缓存">缓存</a> · <a href="/articletag/14884_new_0_1.html" class="aLightGray" title="Service Worker">Service Worker</a> · <a href="/articletag/40077_new_0_1.html" class="aLightGray" title="白屏">白屏</a> · <a href="/articletag/40078_new_0_1.html" class="aLightGray" title="发布故障">发布故障</a> · <a href="javascript:;" class="aLightGray" title="缓存策略">缓存策略</a> <a href="javascript:;" class="aLightGray" title="前端白屏">前端白屏</a> <a href="javascript:;" class="aLightGray" title="Service Worker">Service Worker</a> <a href="javascript:;" class="aLightGray" title="CacheStorage">CacheStorage</a> <a href="javascript:;" class="aLightGray" title="资源404">资源404</a> <a href="javascript:;" class="aLightGray" title="发布回滚">发布回滚</a> </span> </dd> <dt class="lineOverflow"> <a href="/article/620112.html" class="aBlack" target="_blank" title="前端发布后白屏复盘:Service Worker 缓存旧入口导致 JS 资源 404">前端发布后白屏复盘:Service Worker 缓存旧入口导致 JS 资源 404</a> </dt> <dd class="cont2"> <span><i class="view"></i>469浏览</span> <span class="collectBtn user_collection" data-id="620112" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/620092.html" class="img_box" title="前端批量导出接口怎么设计:异步任务、状态查询和下载链接"> <img src="/uploads/20260629/1782718967-export-api-error-panel.webp" 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>   |  2天前  |   <a href="/articletag/2436_new_0_1.html" class="aLightGray" title="异步任务">异步任务</a> · <a href="/articletag/5401_new_0_1.html" class="aLightGray" title="前端开发">前端开发</a> · <a href="/articletag/39770_new_0_1.html" class="aLightGray" title="接口设计">接口设计</a> · <a href="/articletag/40045_new_0_1.html" class="aLightGray" title="后台系统">后台系统</a> · <a href="/articletag/40046_new_0_1.html" class="aLightGray" title="批量导出">批量导出</a> · <a href="javascript:;" class="aLightGray" title="异步任务">异步任务</a> <a href="javascript:;" class="aLightGray" title="文件下载">文件下载</a> <a href="javascript:;" class="aLightGray" title="接口设计">接口设计</a> <a href="javascript:;" class="aLightGray" title="前端导出">前端导出</a> <a href="javascript:;" class="aLightGray" title="状态查询">状态查询</a> <a href="javascript:;" class="aLightGray" title="报表导出">报表导出</a> </span> </dd> <dt class="lineOverflow"> <a href="/article/620092.html" class="aBlack" target="_blank" title="前端批量导出接口怎么设计:异步任务、状态查询和下载链接">前端批量导出接口怎么设计:异步任务、状态查询和下载链接</a> </dt> <dd class="cont2"> <span><i class="view"></i>296浏览</span> <span class="collectBtn user_collection" data-id="620092" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/620091.html" class="img_box" title="前端表格列设置刷新后丢失怎么办:可见列、列宽和顺序这样保存"> <img src="/uploads/20260629/1782717813-frontend-table-columns-lifecycle.webp" 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>   |  2天前  |   <a href="/articletag/5401_new_0_1.html" class="aLightGray" title="前端开发">前端开发</a> · <a href="/articletag/39813_new_0_1.html" class="aLightGray" title="localStorage">localStorage</a> · <a href="/articletag/40043_new_0_1.html" class="aLightGray" title="表格配置">表格配置</a> · <a href="/articletag/40044_new_0_1.html" class="aLightGray" title="用户偏好">用户偏好</a> · <a href="/articletag/40045_new_0_1.html" class="aLightGray" title="后台系统">后台系统</a> · <a href="javascript:;" class="aLightGray" title="用户偏好">用户偏好</a> <a href="javascript:;" class="aLightGray" title="localStorage">localStorage</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/620091.html" class="aBlack" target="_blank" title="前端表格列设置刷新后丢失怎么办:可见列、列宽和顺序这样保存">前端表格列设置刷新后丢失怎么办:可见列、列宽和顺序这样保存</a> </dt> <dd class="cont2"> <span><i class="view"></i>351浏览</span> <span class="collectBtn user_collection" data-id="620091" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/620087.html" class="img_box" title="前端实时通知方案选型:短轮询、SSE、WebSocket 怎么选"> <img src="/uploads/20260629/1782712475-frontend-notify-choice-timeline.webp" onerror="this.src='/assets/images/moren/morentu.png'" alt="前端实时通知方案选型:短轮询、SSE、WebSocket 怎么选"> </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天前  |   <a href="/articletag/1017_new_0_1.html" class="aLightGray" title="websocket">websocket</a> · <a href="/articletag/5401_new_0_1.html" class="aLightGray" title="前端开发">前端开发</a> · <a href="/articletag/27659_new_0_1.html" class="aLightGray" title="sse">sse</a> · <a href="/articletag/40036_new_0_1.html" class="aLightGray" title="实时通知">实时通知</a> · <a href="/articletag/40037_new_0_1.html" class="aLightGray" title="方案选型">方案选型</a> · <a href="javascript:;" class="aLightGray" title="websocket">websocket</a> <a href="javascript:;" class="aLightGray" title="消息推送">消息推送</a> <a href="javascript:;" class="aLightGray" title="EventSource">EventSource</a> <a href="javascript:;" class="aLightGray" title="SSE">SSE</a> <a href="javascript:;" class="aLightGray" title="前端实时通知">前端实时通知</a> <a href="javascript:;" class="aLightGray" title="短轮询">短轮询</a> </span> </dd> <dt class="lineOverflow"> <a href="/article/620087.html" class="aBlack" target="_blank" title="前端实时通知方案选型:短轮询、SSE、WebSocket 怎么选">前端实时通知方案选型:短轮询、SSE、WebSocket 怎么选</a> </dt> <dd class="cont2"> <span><i class="view"></i>498浏览</span> <span class="collectBtn user_collection" data-id="620087" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/620079.html" class="img_box" title="前端接口超时告警运行手册:从瀑布图到降级回滚"> <img src="/uploads/20260629/1782702426-frontend-api-timeout-alert-flow.webp" 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>   |  2天前  |   <a href="/articletag/243_new_0_1.html" class="aLightGray" title="前端">前端</a> · <a href="/articletag/40002_new_0_1.html" class="aLightGray" title="接口排查">接口排查</a> · <a href="/articletag/40021_new_0_1.html" class="aLightGray" title="运维手册">运维手册</a> · <a href="/articletag/40024_new_0_1.html" class="aLightGray" title="性能告警">性能告警</a> · <a href="javascript:;" class="aLightGray" title="前端">前端</a> <a href="javascript:;" class="aLightGray" title="AbortController">AbortController</a> <a href="javascript:;" class="aLightGray" title="接口超时">接口超时</a> <a href="javascript:;" class="aLightGray" title="Network瀑布图">Network瀑布图</a> <a href="javascript:;" class="aLightGray" title="降级回滚">降级回滚</a> <a href="javascript:;" class="aLightGray" title="线上告警">线上告警</a> </span> </dd> <dt class="lineOverflow"> <a href="/article/620079.html" class="aBlack" target="_blank" title="前端接口超时告警运行手册:从瀑布图到降级回滚">前端接口超时告警运行手册:从瀑布图到降级回滚</a> </dt> <dd class="cont2"> <span><i class="view"></i>287浏览</span> <span class="collectBtn user_collection" data-id="620079" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/620076.html" class="img_box" title="CSS sticky 不生效排查清单:从 top、overflow 到滚动容器逐层定位"> <img src="/uploads/20260629/1782698249-css-sticky-failure-check.webp" onerror="this.src='/assets/images/moren/morentu.png'" alt="CSS sticky 不生效排查清单:从 top、overflow 到滚动容器逐层定位"> </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天前  |   <a href="/articletag/243_new_0_1.html" class="aLightGray" title="前端">前端</a> · <a href="/articletag/4729_new_0_1.html" class="aLightGray" title="css">css</a> · <a href="/articletag/9935_new_0_1.html" class="aLightGray" title="sticky">sticky</a> · <a href="/articletag/40022_new_0_1.html" class="aLightGray" title="布局调试">布局调试</a> · <a href="javascript:;" class="aLightGray" title="CSS">CSS</a> <a href="javascript:;" class="aLightGray" title="Overflow">Overflow</a> <a href="javascript:;" class="aLightGray" title="position sticky">position sticky</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/620076.html" class="aBlack" target="_blank" title="CSS sticky 不生效排查清单:从 top、overflow 到滚动容器逐层定位">CSS sticky 不生效排查清单:从 top、overflow 到滚动容器逐层定位</a> </dt> <dd class="cont2"> <span><i class="view"></i>179浏览</span> <span class="collectBtn user_collection" data-id="620076" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/620069.html" class="img_box" title="前端静态资源上云部署选型:对象存储、CDN 和容器服务怎么选"> <img src="/uploads/20260627/1782572123-frontend-static-cache-architecture.webp" onerror="this.src='/assets/images/moren/morentu.png'" alt="前端静态资源上云部署选型:对象存储、CDN 和容器服务怎么选"> </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>   |  3天前  |   <a href="/articletag/243_new_0_1.html" class="aLightGray" title="前端">前端</a> · <a href="/articletag/652_new_0_1.html" class="aLightGray" title="静态资源">静态资源</a> · <a href="/articletag/5322_new_0_1.html" class="aLightGray" title="cdn">cdn</a> · <a href="/articletag/40011_new_0_1.html" class="aLightGray" title="云部署">云部署</a> · <a href="javascript:;" class="aLightGray" title="对象存储">对象存储</a> <a href="javascript:;" class="aLightGray" title="静态资源">静态资源</a> <a href="javascript:;" class="aLightGray" title="缓存策略">缓存策略</a> <a href="javascript:;" class="aLightGray" title="cdn">cdn</a> <a href="javascript:;" class="aLightGray" title="前端部署">前端部署</a> <a href="javascript:;" class="aLightGray" title="容器服务">容器服务</a> </span> </dd> <dt class="lineOverflow"> <a href="/article/620069.html" class="aBlack" target="_blank" title="前端静态资源上云部署选型:对象存储、CDN 和容器服务怎么选">前端静态资源上云部署选型:对象存储、CDN 和容器服务怎么选</a> </dt> <dd class="cont2"> <span><i class="view"></i>433浏览</span> <span class="collectBtn user_collection" data-id="620069" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/620045.html" class="img_box" title="前端表单重复提交防护工作流:从按钮状态到请求取消和幂等键"> <img src="/uploads/20260622/1782110788-frontend-idempotent-key-flow.webp" 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>   |  1星期前  |   <a href="/articletag/243_new_0_1.html" class="aLightGray" title="前端">前端</a> · <a href="/articletag/39982_new_0_1.html" class="aLightGray" title="接口联调">接口联调</a> · <a href="/articletag/39989_new_0_1.html" class="aLightGray" title="表单交互">表单交互</a> · <a href="/articletag/39990_new_0_1.html" class="aLightGray" title="重复提交">重复提交</a> · <a href="/articletag/39991_new_0_1.html" class="aLightGray" title="用户体验">用户体验</a> · <a href="javascript:;" class="aLightGray" title="前端">前端</a> <a href="javascript:;" class="aLightGray" title="表单提交">表单提交</a> <a href="javascript:;" class="aLightGray" title="重复请求">重复请求</a> <a href="javascript:;" class="aLightGray" title="AbortController">AbortController</a> <a href="javascript:;" class="aLightGray" title="幂等键">幂等键</a> <a href="javascript:;" class="aLightGray" title="按钮禁用">按钮禁用</a> </span> </dd> <dt class="lineOverflow"> <a href="/article/620045.html" class="aBlack" target="_blank" title="前端表单重复提交防护工作流:从按钮状态到请求取消和幂等键">前端表单重复提交防护工作流:从按钮状态到请求取消和幂等键</a> </dt> <dd class="cont2"> <span><i class="view"></i>374浏览</span> <span class="collectBtn user_collection" data-id="620045" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/620039.html" class="img_box" title="前端 CORS 预检失败排查流程:从请求头到网关响应"> <img src="/uploads/20260618/1781767364-frontend-cors-flow.webp" 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>   |  1星期前  |   <a href="/articletag/243_new_0_1.html" class="aLightGray" title="前端">前端</a> · <a href="/articletag/4720_new_0_1.html" class="aLightGray" title="cors">cors</a> · <a href="/articletag/39980_new_0_1.html" class="aLightGray" title="跨域排查">跨域排查</a> · <a href="/articletag/39981_new_0_1.html" class="aLightGray" title="浏览器网络">浏览器网络</a> · <a href="/articletag/39982_new_0_1.html" class="aLightGray" title="接口联调">接口联调</a> · <a href="javascript:;" class="aLightGray" title="前端">前端</a> <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="Options">Options</a> </span> </dd> <dt class="lineOverflow"> <a href="/article/620039.html" class="aBlack" target="_blank" title="前端 CORS 预检失败排查流程:从请求头到网关响应">前端 CORS 预检失败排查流程:从请求头到网关响应</a> </dt> <dd class="cont2"> <span><i class="view"></i>422浏览</span> <span class="collectBtn user_collection" data-id="620039" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/620035.html" class="img_box" title="前端 position sticky 不生效排查:从滚动容器到 overflow 限制"> <img src="/uploads/20260618/1781761300-frontend-sticky-check-flow.webp" onerror="this.src='/assets/images/moren/morentu.png'" alt="前端 position sticky 不生效排查:从滚动容器到 overflow 限制"> </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>   |  1星期前  |   <a href="/articletag/243_new_0_1.html" class="aLightGray" title="前端">前端</a> · <a href="/articletag/4729_new_0_1.html" class="aLightGray" title="css">css</a> · <a href="/articletag/9935_new_0_1.html" class="aLightGray" title="sticky">sticky</a> · <a href="/articletag/39972_new_0_1.html" class="aLightGray" title="布局排查">布局排查</a> · <a href="/articletag/39973_new_0_1.html" class="aLightGray" title="滚动容器">滚动容器</a> · <a href="javascript:;" class="aLightGray" title="CSS">CSS</a> <a href="javascript:;" class="aLightGray" title="前端">前端</a> <a href="javascript:;" class="aLightGray" title="Overflow">Overflow</a> <a href="javascript:;" class="aLightGray" title="position sticky">position sticky</a> <a href="javascript:;" class="aLightGray" title="滚动容器">滚动容器</a> <a href="javascript:;" class="aLightGray" title="吸顶失效">吸顶失效</a> </span> </dd> <dt class="lineOverflow"> <a href="/article/620035.html" class="aBlack" target="_blank" title="前端 position sticky 不生效排查:从滚动容器到 overflow 限制">前端 position sticky 不生效排查:从滚动容器到 overflow 限制</a> </dt> <dd class="cont2"> <span><i class="view"></i>449浏览</span> <span class="collectBtn user_collection" data-id="620035" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> </ul> </div> </div> <div class="mainRight"> <!-- 右侧广告位banner --> <div class="rightContBox" style="margin-top: 0px;"> <div class="rightTit"> <a href="/courselist.html" class="more" title="查看更多">查看更多<i class="iconfont"></i></a> <div class="tit lineOverflow">课程推荐</div> </div> <ul class="lessonRecomRList"> <li> <a href="/course/9.html" class="img_box" target="_blank" title="前端进阶之JavaScript设计模式"> <img src="/uploads/20221222/52fd0f23a454c71029c2c72d206ed815.jpg" onerror="this.onerror='',this.src='/assets/images/moren/morentu.png'" alt="前端进阶之JavaScript设计模式"> </a> <dl> <dt class="lineTwoOverflow"><a href="/course/9.html" target="_blank" class="aBlack" title="前端进阶之JavaScript设计模式">前端进阶之JavaScript设计模式</a></dt> <dd class="cont1 lineTwoOverflow"> 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。 </dd> <dd class="cont2">543次学习</dd> </dl> </li> <li> <a href="/course/2.html" class="img_box" target="_blank" title="GO语言核心编程课程"> <img src="/uploads/20221221/634ad7404159bfefc6a54a564d437b5f.png" onerror="this.onerror='',this.src='/assets/images/moren/morentu.png'" alt="GO语言核心编程课程"> </a> <dl> <dt class="lineTwoOverflow"><a href="/course/2.html" target="_blank" class="aBlack" title="GO语言核心编程课程">GO语言核心编程课程</a></dt> <dd class="cont1 lineTwoOverflow"> 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。 </dd> <dd class="cont2">516次学习</dd> </dl> </li> <li> <a href="/course/74.html" class="img_box" target="_blank" title="简单聊聊mysql8与网络通信"> <img src="/uploads/20240103/bad35fe14edbd214bee16f88343ac57c.png" onerror="this.onerror='',this.src='/assets/images/moren/morentu.png'" alt="简单聊聊mysql8与网络通信"> </a> <dl> <dt class="lineTwoOverflow"><a href="/course/74.html" target="_blank" class="aBlack" title="简单聊聊mysql8与网络通信">简单聊聊mysql8与网络通信</a></dt> <dd class="cont1 lineTwoOverflow"> 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让 </dd> <dd class="cont2">500次学习</dd> </dl> </li> <li> <a href="/course/57.html" class="img_box" target="_blank" title="JavaScript正则表达式基础与实战"> <img src="/uploads/20221226/bbe4083bb3cb0dd135fb02c31c3785fb.jpg" onerror="this.onerror='',this.src='/assets/images/moren/morentu.png'" alt="JavaScript正则表达式基础与实战"> </a> <dl> <dt class="lineTwoOverflow"><a href="/course/57.html" target="_blank" class="aBlack" title="JavaScript正则表达式基础与实战">JavaScript正则表达式基础与实战</a></dt> <dd class="cont1 lineTwoOverflow"> 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。 </dd> <dd class="cont2">487次学习</dd> </dl> </li> <li> <a href="/course/28.html" class="img_box" target="_blank" title="从零制作响应式网站—Grid布局"> <img src="/uploads/20221223/ac110f88206daeab6c0cf38ebf5fe9ed.jpg" onerror="this.onerror='',this.src='/assets/images/moren/morentu.png'" alt="从零制作响应式网站—Grid布局"> </a> <dl> <dt class="lineTwoOverflow"><a href="/course/28.html" target="_blank" class="aBlack" title="从零制作响应式网站—Grid布局">从零制作响应式网站—Grid布局</a></dt> <dd class="cont1 lineTwoOverflow"> 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。 </dd> <dd class="cont2">485次学习</dd> </dl> </li> </ul> </div> <div class="rightContBox"> <div class="rightTit"> <a href="/ai.html" class="more" title="查看更多">查看更多<i class="iconfont"></i></a> <div class="tit lineOverflow">AI推荐</div> </div> <ul class="lessonRecomRList"> <li> <a href="/ai/13109.html" target="_blank" title="ljg-skills - "Prompt之神"李继刚开源的 AI 技能集" class="img_box"> <img src="/uploads/ai/20260616/ljg-skills-icon-8bbe1468e5.png" onerror="this.onerror='',this.src='/assets/images/moren/morentu.png'" alt="ljg-skills - "Prompt之神"李继刚开源的 AI 技能集" style="object-fit:cover;width:100%;height:100%;"> </a> <dl> <dt class="lineTwoOverflow"><a href="/ai/13109.html" class="aBlack" target="_blank" title="ljg-skills">ljg-skills</a></dt> <dd class="cont1 lineTwoOverflow"> ljg-skills 是李继刚开源的 AI 技能与提示词集合,面向大模型使用者整理了一批可复用的 prompt、角色设定和任务技能模板,适合用于学习提示词设计、搭建个人 AI 工作流和沉淀团队常用智能体能力。 </dd> <dd class="cont2">3203次使用</dd> </dl> </li> <li> <a href="/ai/13108.html" target="_blank" title="MELO音乐 - AI 音乐生成平台,支持多模态创作能力" class="img_box"> <img src="/uploads/ai/20260616/melo-icon-10bf590762.png" onerror="this.onerror='',this.src='/assets/images/moren/morentu.png'" alt="MELO音乐 - AI 音乐生成平台,支持多模态创作能力" style="object-fit:cover;width:100%;height:100%;"> </a> <dl> <dt class="lineTwoOverflow"><a href="/ai/13108.html" class="aBlack" target="_blank" title="MELO音乐">MELO音乐</a></dt> <dd class="cont1 lineTwoOverflow"> MELO音乐是一站式AI视频与音乐制作助手,对标suno, udio的高品质体验。提供伴奏生成、原创写词、无损导出、哼唱识曲、混音变声等全套音频与短视频编辑工具。无论是流行Kpop、电音说唱、民谣古风、摇滚儿歌还是商用轻音乐,MELO为你免费谱曲,轻松做同款! </dd> <dd class="cont2">2955次使用</dd> </dl> </li> <li> <a href="/ai/13107.html" target="_blank" title="UniScribe - AI 免费在线音视频转文字平台" class="img_box"> <img src="/uploads/ai/20260616/uniscribe-icon-3c88366a15.png" onerror="this.onerror='',this.src='/assets/images/moren/morentu.png'" alt="UniScribe - AI 免费在线音视频转文字平台" style="object-fit:cover;width:100%;height:100%;"> </a> <dl> <dt class="lineTwoOverflow"><a href="/ai/13107.html" class="aBlack" target="_blank" title="UniScribe">UniScribe</a></dt> <dd class="cont1 lineTwoOverflow"> UniScribe 是一款 AI 音视频转文字与内容整理工具,支持上传音频、视频文件或粘贴 YouTube 链接,自动生成转写文本、摘要、思维导图和关键问题,并支持多格式导出,适合会议记录、课程学习、访谈整理和内容创作复盘。 </dd> <dd class="cont2">2911次使用</dd> </dl> </li> <li> <a href="/ai/13106.html" target="_blank" title="剧云 - 免费 AI 智能中文剧本创作平台" class="img_box"> <img src="/uploads/ai/20260615/d36c7176-icon-2b0cd581ce.png" onerror="this.onerror='',this.src='/assets/images/moren/morentu.png'" alt="剧云 - 免费 AI 智能中文剧本创作平台" style="object-fit:cover;width:100%;height:100%;"> </a> <dl> <dt class="lineTwoOverflow"><a href="/ai/13106.html" class="aBlack" target="_blank" title="剧云">剧云</a></dt> <dd class="cont1 lineTwoOverflow"> 剧云是专业中文剧本创作平台,安全稳定运行十余年,集成AI编剧、剧本医生审核、人物小传、剧情关系图、大纲编写、多人协作、Word导入导出、版权管控功能,数据安全防护,轻松高效创作剧本。 </dd> <dd class="cont2">3113次使用</dd> </dl> </li> <li> <a href="/ai/13105.html" target="_blank" title="万象有声 - AI 一站式有声内容创作平台" class="img_box"> <img src="/uploads/ai/20260615/50267bac-icon-c146b001b5.png" onerror="this.onerror='',this.src='/assets/images/moren/morentu.png'" alt="万象有声 - AI 一站式有声内容创作平台" style="object-fit:cover;width:100%;height:100%;"> </a> <dl> <dt class="lineTwoOverflow"><a href="/ai/13105.html" class="aBlack" target="_blank" title="万象有声">万象有声</a></dt> <dd class="cont1 lineTwoOverflow"> 万象有声,一个专为有声创作者打造的新一代智能有声内容创作平台。平台提供专业的智能拆章、智能画本编辑、AI配音、AI生成音效、后期制作、智能对轨、智能审听等有声创作全流程工具,可以帮助创作者高效、低成本创作出引人入胜的有声作品。立即体验,让有声书制作更简单! </dd> <dd class="cont2">3070次使用</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/619053.html" class="aBlack" title="CSS变量简化按钮悬停效果技巧">CSS变量简化按钮悬停效果技巧</a></dt> <dd> <span class="left">2026-05-31</span> <span class="right">501浏览</span> </dd> </dl> </li> <li> <dl> <dt class="lineTwoOverflow"><a href="/article/618916.html" class="aBlack" title="JavaScript符号类型详解与应用">JavaScript符号类型详解与应用</a></dt> <dd> <span class="left">2026-05-31</span> <span class="right">501浏览</span> </dd> </dl> </li> <li> <dl> <dt class="lineTwoOverflow"><a href="/article/612539.html" class="aBlack" title="HTML剪贴板复制粘贴怎么用">HTML剪贴板复制粘贴怎么用</a></dt> <dd> <span class="left">2026-05-26</span> <span class="right">501浏览</span> </dd> </dl> </li> <li> <dl> <dt class="lineTwoOverflow"><a href="/article/611774.html" class="aBlack" title="data-*属性详解:HTML数据存储与DOM操作技巧">data-*属性详解:HTML数据存储与DOM操作技巧</a></dt> <dd> <span class="left">2026-05-25</span> <span class="right">501浏览</span> </dd> </dl> </li> </ul> </div> </div> </div> <div class="footer"> <div class="footerIn"> <div class="footLeft"> <div class="linkBox"> <a href="/about/1.html" target="_blank" class="aBlack" title="关于我们">关于我们</a> <a href="/about/5.html" target="_blank" class="aBlack" title="免责声明">免责声明</a> <a href="#" class="aBlack" title="意见反馈">意见反馈</a> <a href="/about/2.html" class="aBlack" target="_blank" title="联系我们">联系我们</a> <a href="/send.html" class="aBlack" title="广告合作">内容提交</a> <a href="/manual/go/" target="_blank" class="aBlack" title="手册">手册</a> </div> <div class="footTip">Golang学习网:公益在线Go学习平台,帮助Go学习者快速成长!</div> <div class="shareBox"> <span><i class="qq"></i>技术交流群</span> </div> <div class="copyRight"> Copyright 2023 http://www.17golang.com/ All Rights Reserved | <a href="https://beian.miit.gov.cn/" target="_blank" title="备案">苏ICP备2023003363号-1</a> </div> </div> <div class="footRight"> <ul class="encodeList"> <li> <div class="encodeImg"> <img src="/assets/examples/qrcode_for_gh.jpg" alt="Golang学习网"> </div> <div class="tit">关注公众号</div> <div class="tip">Golang学习网</div> </li> <div class="clear"></div> </ul> </div> <div class="clear"></div> </div> </div> <!-- 微信登录弹窗 --> <style> .popupBg .n-error{ color: red; } </style> <div class="popupBg"> <div class="loginBoxBox"> <div class="imgbg"> <img src="/assets/images/leftlogo.jpg" alt=""> </div> <!-- 微信登录 --> <div class="loginInfo encodeLogin" style="display: none;"> <div class="closeIcon" onclick="$('.popupBg').hide();"></div> <div class="changeLoginType cursorPointer create_wxqrcode" onclick="$('.loginInfo').hide();$('.passwordLogin').show();"> <div class="tip">密码登录在这里</div> </div> <div class="encodeInfo"> <div class="tit"><i></i> 微信扫码登录或注册</div> <div class="encodeImg"> <span id="wx_login_qrcode"><img src="/assets/examples/code.png" alt="二维码"></span> <!-- <div class="refreshBox"> <p>二维码失效</p> <button type="button" class="create_wxqrcode">刷新1111</button> </div> --> </div> <div class="tip">打开微信扫一扫,快速登录/注册</div> </div> <div class="beforeLoginTip">登录即同意 <a href="#" class="aBlue" title="用户协议">用户协议</a> 和 <a href="#" class="aBlue" title="隐私政策">隐私政策</a></div> </div> <!-- 密码登录 --> <div class="loginInfo passwordLogin"> <div class="closeIcon" onclick="$('.popupBg').hide();"></div> <div class="changeLoginType cursorPointer create_wxqrcode" onclick="$('.loginInfo').hide();$('.encodeLogin').show();"> <div class="tip">微信登录更方便</div> </div> <div class="passwordInfo"> <ul class="logintabs selfTabMenu"> <li class="selfTabItem loginFormLi curr">密码登录</li> <li class="selfTabItem registerFormBox ">注册账号</li> </ul> <div class="selfTabContBox"> <div class="selfTabCont loginFormBox" style="display: block;"> <form name="form" id="login-form" class="form-vertical form" method="POST" action="/index/user/login"> <input type="hidden" name="url" value="//17golang.com/article/373205.html"/> <input type="hidden" name="__token__" value="17ae73b4f15d57d393ea509cc45908e9" /> <div class="form-group" style="height:70px;"> <input class="form-control" id="account" type="text" name="account" value="" data-rule="required" placeholder="邮箱/用户名" autocomplete="off"> </div> <div class="form-group" style="height:70px;"> <input class="form-control" id="password" type="password" name="password" data-rule="required;password" placeholder="密码" autocomplete="off"> </div> <div class="codeBox" style="height:70px;"> <div class="form-group" style="height:70px; width:205px; float: left;"> <input type="text" name="captcha" class="form-control" placeholder="验证码" data-rule="required;length(4)" /> </div> <span class="input-group-btn" style="padding:0;border:none;"> <img src="/captcha.html" width="100" height="45" onclick="this.src = '/captcha.html?r=' + Math.random();"/> </span> </div> <div class="other"> <a href="#" class="forgetPwd aGray" onclick="$('.loginInfo').hide();$('.passwordForget').show();" title="忘记密码">忘记密码</a> </div> <div class="loginBtn mt25"> <button type="submit">登录</button> </div> </form> </div> <div class="selfTabCont registerFormBox" style="display: none;"> <form name="form1" id="register-form" class="form-vertical form" method="POST" action="/index/user/register"> <input type="hidden" name="invite_user_id" value="0"/> <input type="hidden" name="url" value="//17golang.com/article/373205.html"/> <input type="hidden" name="__token__" value="17ae73b4f15d57d393ea509cc45908e9" /> <div class="form-group" style="height:70px;"> <input type="text" name="email" id="email2" data-rule="required;email" class="form-control" placeholder="邮箱"> </div> <div class="form-group" style="height:70px;"> <input type="text" id="username" name="username" data-rule="required;username" class="form-control" placeholder="用户名必须3-30个字符"> </div> <div class="form-group" style="height:70px;"> <input type="password" id="password2" name="password" data-rule="required;password" class="form-control" placeholder="密码必须6-30个字符"> </div> <div class="codeBox" style="height:70px;"> <div class="form-group" style="height:70px; width:205px; float: left;"> <input type="text" name="captcha" class="form-control" placeholder="验证码" data-rule="required;length(4)" /> </div> <span class="input-group-btn" style="padding:0;border:none;"> <img src="/captcha.html" width="100" height="45" onclick="this.src = '/captcha.html?r=' + Math.random();"/> </span> </div> <div class="loginBtn"> <button type="submit">注册</button> </div> </form> </div> </div> </div> <div class="beforeLoginTip">登录即同意 <a href="https://www.17golang.com/about/3.html" target="_blank" class="aBlue" title="用户协议">用户协议</a> 和 <a href="https://www.17golang.com/about/4.html" target="_blank" class="aBlue" title="隐私政策">隐私政策</a></div> </div> <!-- 重置密码 --> <div class="loginInfo passwordForget"> <div class="closeIcon" onclick="$('.popupBg').hide();"></div> <div class="returnLogin cursorPointer" onclick="$('.passwordForget').hide();$('.passwordLogin').show();">返回登录</div> <div class="passwordInfo"> <ul class="logintabs selfTabMenu"> <li class="selfTabItem">重置密码</li> </ul> <div class="selfTabContBox"> <div class="selfTabCont"> <form id="resetpwd-form" class="form-horizontal form-layer nice-validator n-default n-bootstrap form" method="POST" action="/api/user/resetpwd.html" novalidate="novalidate"> <div style="height:70px;"> <input type="text" class="form-control" id="email" name="email" value="" placeholder="输入邮箱" aria-invalid="true"> </div> <div class="codeBox" style="height:70px;"> <div class="form-group" style="height:70px; width:205px; float: left;"> <input type="text" name="captcha" class="form-control" placeholder="验证码" /> </div> <span class="input-group-btn" style="padding:0;border:none;"> <a href="javascript:;" class="btn btn-primary btn-captcha cursorPointer" style="background: #2080F8; border-radius: 4px; color: #fff; padding: 12px; position: absolute;" data-url="/api/ems/send.html" data-type="email" data-event="resetpwd">发送验证码</a> </span> </div> <input type="password" class="form-control" id="newpassword" name="newpassword" value="" placeholder="请输入6-18位密码"> <div class="loginBtn mt25"> <button type="submit">重置密码</button> </div> </form> </div> </div> </div> </div> </div> </div> <script src="/assets/js/juejin-theme.js?v=20260613b" defer></script> <script> var _hmt = _hmt || []; (function() { var hm = document.createElement("script"); hm.src = "https://hm.baidu.com/hm.js?3dc5666f6478c7bf39cd5c91e597423d"; hm.async = true; var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(hm, s); })(); </script> <script src="/assets/js/frontend/common.js"></script> </body> </html>