当前位置:首页 > 文章列表 > 文章 > 前端 > JS单页应用开发技巧全解析

JS单页应用开发技巧全解析

2025-08-12 22:17:52 0浏览 收藏

本文深入解析了**JS单页应用(SPA)的实现方法**,并着重强调了SPA相较于传统多页面应用的优势与劣势。单页应用通过动态更新页面内容,提供更流畅的用户体验,但在首屏加载速度和SEO优化方面面临挑战。文章详细阐述了如何通过代码分割、懒加载、服务器端渲染(SSR)等技术手段优化首屏加载速度,以及如何利用SSR、预渲染、动态更新Meta标签等策略提升SPA的SEO效果。此外,文章还对React、Vue和Angular三大主流前端框架在SPA开发中的应用进行了对比分析,帮助开发者根据项目需求和团队实际情况选择合适的框架,最终实现高效、优质的单页应用开发。

单页面应用(SPA)相比传统多页面应用具有更流畅的用户体验、前后端分离、易于构建移动应用和减少服务器压力等优点,但也存在首屏加载时间长、SEO优化困难、复杂性高和依赖JavaScript等缺点;为解决首屏加载慢的问题,可通过代码分割、懒加载、资源压缩、CDN加速、Tree Shaking、预渲染和服务器端渲染(SSR)等方式优化;针对SEO,可采用SSR、预渲染、动态更新Meta标签、使用History API、生成站点地图、添加结构化数据、利用Fetch As Google工具及提升可访问性来改善;在选择React、Vue或Angular框架时,应根据团队经验、项目规模和需求权衡,React适合大型复杂应用,Vue适合快速开发中小型项目,Angular适用于企业级应用,各框架均有优劣,需结合实际情况选择,最终答案取决于具体场景与团队能力。

JS单页面应用如何实现

JS单页面应用(SPA)通过动态更新页面内容,而非每次都向服务器请求新页面,从而提供更流畅的用户体验。其核心在于利用JavaScript操控DOM,配合路由管理和数据交互,模拟传统多页面应用的导航效果。

解决方案:

  1. 前端路由: 使用如vue-routerreact-routerangular router等库,或者手写简单的路由控制。路由负责监听URL变化,并根据URL加载对应的组件或视图。手写路由的一个简单示例如下:
const routes = {
  '/home': () => { document.body.innerHTML = '<h1>Home Page</h1>'; },
  '/about': () => { document.body.innerHTML = '<h1>About Page</h1>'; },
  '/contact': () => { document.body.innerHTML = '<h1>Contact Page</h1>'; }
};

function router() {
  const path = location.hash.slice(1) || '/home'; // 获取URL hash
  const route = routes[path] || (() => { document.body.innerHTML = '<h1>404 Not Found</h1>'; }); // 找不到路由则显示404
  route();
}

window.addEventListener('hashchange', router); // 监听hash变化
window.addEventListener('load', router); // 页面加载时执行
  1. 组件化开发: 将页面拆分成独立的、可复用的组件。这有助于代码维护和复用。流行的框架都强调组件化。

  2. 数据管理: SPA通常需要管理复杂的状态。可以使用ReduxVuexContext API等工具来集中管理应用状态。

  3. 异步数据获取: 使用fetchaxios等工具与后端API进行交互,获取数据并更新页面。

  4. SEO优化: 由于SPA的内容是动态生成的,搜索引擎可能无法正确抓取。可以使用服务器端渲染(SSR)或预渲染来解决这个问题。

SPA的核心挑战在于如何有效地管理状态、路由和异步操作,同时保证性能和可维护性。

单页面应用相比传统多页面应用有哪些优缺点?

优点:

  • 更流畅的用户体验: 页面切换无需重新加载整个页面,响应速度更快。
  • 前后端分离: 前端专注于UI开发,后端提供API,职责分离。
  • 易于构建移动应用: SPA可以很容易地打包成原生移动应用。
  • 减少服务器压力: 减少了不必要的页面请求。

缺点:

  • 首屏加载时间较长: 需要加载所有的JS和CSS资源。
  • SEO优化困难: 搜索引擎爬虫难以抓取动态生成的内容。
  • 复杂性较高: 需要处理路由、状态管理、异步操作等问题。
  • JavaScript依赖: 如果禁用JavaScript,SPA将无法正常工作。

如何解决SPA的首屏加载速度慢的问题?

  • 代码分割(Code Splitting): 将应用拆分成多个小的chunk,按需加载。Webpack等工具可以实现代码分割。
  • 懒加载(Lazy Loading): 延迟加载非必要的资源,例如图片、组件等。
  • 压缩资源: 使用Gzip或Brotli压缩JS、CSS和HTML文件。
  • CDN加速: 将静态资源部署到CDN上,加快访问速度。
  • Tree Shaking: 移除未使用的代码,减小bundle体积。
  • 预渲染(Prerendering): 在构建时生成静态HTML页面,提高首屏加载速度。
  • 服务器端渲染(SSR): 在服务器端渲染页面,返回完整的HTML,有利于SEO。

SPA如何进行SEO优化?

  • 服务器端渲染(SSR): 这是最有效的SEO优化方式。在服务器端执行JavaScript代码,生成完整的HTML页面,搜索引擎可以直接抓取。
  • 预渲染(Prerendering): 在构建时生成静态HTML页面,提供给搜索引擎。适用于内容变化不频繁的SPA。
  • Meta标签: 动态更新</code>、<code><meta description></code>等标签,提供更准确的页面信息。</li><li><strong>使用History API:</strong> 使用HTML5 History API(<code>pushState</code>和<code>replaceState</code>)来管理URL,而不是hash。这可以使URL更友好,有利于SEO。</li><li><strong>站点地图(Sitemap):</strong> 创建站点地图,帮助搜索引擎发现和索引页面。</li><li><strong>结构化数据(Structured Data):</strong> 使用JSON-LD等格式添加结构化数据,帮助搜索引擎理解页面内容。</li><li><strong>使用Fetch As Google工具:</strong> 使用Google Search Console的Fetch As Google工具,检查搜索引擎如何抓取你的页面。</li><li><strong>确保页面可访问性:</strong> 确保页面对所有用户都可访问,包括使用屏幕阅读器的用户。</li></ul><p>选择哪个前端框架(React、Vue、Angular)来构建SPA?</p><p>选择框架取决于团队的经验、项目需求和个人偏好。</p><ul><li><strong>React:</strong> 灵活性高,生态系统庞大,适合构建大型、复杂的应用。需要自行选择状态管理、路由等库。学习曲线适中。</li><li><strong>Vue:</strong> 易于学习和使用,适合快速开发中小型应用。官方提供了<code>vue-router</code>和<code>Vuex</code>等库。</li><li><strong>Angular:</strong> 功能强大,提供了一整套解决方案,适合构建企业级应用。学习曲线较陡峭。</li></ul><p>没有绝对的最佳选择,每个框架都有其优缺点。可以根据具体情况进行选择。例如,如果团队熟悉React,并且需要构建一个大型应用,那么React可能是一个不错的选择。如果需要快速开发一个小型应用,Vue可能更适合。Angular适合构建大型企业级应用,但需要投入更多的时间学习。</p><p>终于介绍完啦!小伙伴们,这篇关于《JS单页应用开发技巧全解析》的介绍应该让你收获多多了吧!欢迎大家收藏或分享给更多需要学习的朋友吧~golang学习网公众号也会发布文章相关知识,快来关注吧!</p> </div> <div class="labsList"> <a href="javascript:;" title="解决方案">解决方案</a> <a href="javascript:;" title="SEO">SEO</a> <a href="javascript:;" title="前端框架">前端框架</a> <a href="javascript:;" title="SPA">SPA</a> <a href="javascript:;" title="首屏加载">首屏加载</a> </div> <div class="cateBox"> <div class="cateItem"> <a href="/article/282779.html" title="Golang错误熔断实现与CircuitBreaker使用" class="img_box"> <img src="/uploads/20250812/1755008212689b4cd479bbb.jpg" onerror="this.onerror='',this.src='/assets/images/moren/morentu.png'" alt="Golang错误熔断实现与CircuitBreaker使用">Golang错误熔断实现与CircuitBreaker使用 </a> <dl> <dt class="lineOverflow"><a href="/article/282779.html" title="Golang错误熔断实现与CircuitBreaker使用" class="aBlack">上一篇<i></i></a></dt> <dd class="lineTwoOverflow">Golang错误熔断实现与CircuitBreaker使用</dd> </dl> </div> <div class="cateItem"> <a href="/article/282781.html" title="JavaScript事件循环优化全攻略" class="img_box"> <img src="/uploads/20250812/1755008312689b4d3833742.png" onerror="this.onerror='',this.src='/assets/images/moren/morentu.png'" alt="JavaScript事件循环优化全攻略"> </a> <dl> <dt class="lineOverflow"><a href="/article/282781.html" class="aBlack" title="JavaScript事件循环优化全攻略">下一篇<i></i></a></dt> <dd class="lineTwoOverflow">JavaScript事件循环优化全攻略</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/282914.html" class="img_box" title="HTML页面自动刷新技巧全解析"> <img src="/uploads/20250812/1755014308689b64a487161.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>   |  21分钟前  |   </span> </dd> <dt class="lineOverflow"> <a href="/article/282914.html" class="aBlack" target="_blank" title="HTML页面自动刷新技巧全解析">HTML页面自动刷新技巧全解析</a> </dt> <dd class="cont2"> <span><i class="view"></i>145浏览</span> <span class="collectBtn user_collection" data-id="282914" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/282911.html" class="img_box" title="CSS磁性按钮吸附效果实现教程"> <img src="/uploads/20250812/1755014191689b642f5a8c4.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>   |  23分钟前  |   <a href="javascript:;" class="aLightGray" title="CSS">CSS</a> <a href="javascript:;" class="aLightGray" title="JavaScript">JavaScript</a> <a href="javascript:;" class="aLightGray" title="transform">transform</a> <a href="javascript:;" class="aLightGray" title="Transition">Transition</a> <a href="javascript:;" class="aLightGray" title="磁性吸附效果">磁性吸附效果</a> </span> </dd> <dt class="lineOverflow"> <a href="/article/282911.html" class="aBlack" target="_blank" title="CSS磁性按钮吸附效果实现教程">CSS磁性按钮吸附效果实现教程</a> </dt> <dd class="cont2"> <span><i class="view"></i>211浏览</span> <span class="collectBtn user_collection" data-id="282911" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/282905.html" class="img_box" title="JS字符串替换方法详解"> <img src="/uploads/20250812/1755013952689b6340f4135.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>   |  27分钟前  |   </span> </dd> <dt class="lineOverflow"> <a href="/article/282905.html" class="aBlack" target="_blank" title="JS字符串替换方法详解">JS字符串替换方法详解</a> </dt> <dd class="cont2"> <span><i class="view"></i>343浏览</span> <span class="collectBtn user_collection" data-id="282905" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/282901.html" class="img_box" title="JS数组分组技巧全解析"> <img src="/uploads/20250812/1755013762689b628211fcc.jpg" 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>   |  30分钟前  |   <a href="javascript:;" class="aLightGray" title="groupby">groupby</a> <a href="javascript:;" class="aLightGray" title="map">map</a> <a href="javascript:;" class="aLightGray" title="数据处理">数据处理</a> <a href="javascript:;" class="aLightGray" title="reduce">reduce</a> <a href="javascript:;" class="aLightGray" title="JS数组分组">JS数组分组</a> </span> </dd> <dt class="lineOverflow"> <a href="/article/282901.html" class="aBlack" target="_blank" title="JS数组分组技巧全解析">JS数组分组技巧全解析</a> </dt> <dd class="cont2"> <span><i class="view"></i>480浏览</span> <span class="collectBtn user_collection" data-id="282901" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/282894.html" class="img_box" title="CSSposition定位详解与实用场景分析"> <img src="/uploads/20250812/1755013529689b619957cb5.png" onerror="this.src='/assets/images/moren/morentu.png'" alt="CSSposition定位详解与实用场景分析"> </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/282894.html" class="aBlack" target="_blank" title="CSSposition定位详解与实用场景分析">CSSposition定位详解与实用场景分析</a> </dt> <dd class="cont2"> <span><i class="view"></i>340浏览</span> <span class="collectBtn user_collection" data-id="282894" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/282886.html" class="img_box" title="JS数组长度获取方法全解析"> <img src="/uploads/20250812/1755013165689b602d4ecdc.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>   |  40分钟前  |   </span> </dd> <dt class="lineOverflow"> <a href="/article/282886.html" class="aBlack" target="_blank" title="JS数组长度获取方法全解析">JS数组长度获取方法全解析</a> </dt> <dd class="cont2"> <span><i class="view"></i>473浏览</span> <span class="collectBtn user_collection" data-id="282886" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/282884.html" class="img_box" title="HTML拖拽排序实现步骤详解"> <img src="/uploads/20250812/1755013051689b5fbb11c2f.jpg" 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>   |  42分钟前  |   </span> </dd> <dt class="lineOverflow"> <a href="/article/282884.html" class="aBlack" target="_blank" title="HTML拖拽排序实现步骤详解">HTML拖拽排序实现步骤详解</a> </dt> <dd class="cont2"> <span><i class="view"></i>365浏览</span> <span class="collectBtn user_collection" data-id="282884" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/282880.html" class="img_box" title="JS实现页面平滑滚动技巧分享"> <img src="/uploads/20250812/1755012929689b5f41d05ee.jpg" 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>   |  44分钟前  |   </span> </dd> <dt class="lineOverflow"> <a href="/article/282880.html" class="aBlack" target="_blank" title="JS实现页面平滑滚动技巧分享">JS实现页面平滑滚动技巧分享</a> </dt> <dd class="cont2"> <span><i class="view"></i>137浏览</span> <span class="collectBtn user_collection" data-id="282880" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/282877.html" class="img_box" title="JS表单验证方法大全"> <img src="/uploads/20250812/1755012810689b5ecad2915.jpg" 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>   |  46分钟前  |   </span> </dd> <dt class="lineOverflow"> <a href="/article/282877.html" class="aBlack" target="_blank" title="JS表单验证方法大全">JS表单验证方法大全</a> </dt> <dd class="cont2"> <span><i class="view"></i>237浏览</span> <span class="collectBtn user_collection" data-id="282877" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/282869.html" class="img_box" title="HTML实现表格可编辑,单元格直接修改方法"> <img src="/uploads/20250812/1755012451689b5d63dbb4e.jpg" 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>   |  52分钟前  |   </span> </dd> <dt class="lineOverflow"> <a href="/article/282869.html" class="aBlack" target="_blank" title="HTML实现表格可编辑,单元格直接修改方法">HTML实现表格可编辑,单元格直接修改方法</a> </dt> <dd class="cont2"> <span><i class="view"></i>354浏览</span> <span class="collectBtn user_collection" data-id="282869" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/282863.html" class="img_box" title="HTML如何判断设备类型?JS+UA实现方法"> <img src="/uploads/20250812/1755012153689b5c39e3917.jpg" onerror="this.src='/assets/images/moren/morentu.png'" alt="HTML如何判断设备类型?JS+UA实现方法"> </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>   |  57分钟前  |   </span> </dd> <dt class="lineOverflow"> <a href="/article/282863.html" class="aBlack" target="_blank" title="HTML如何判断设备类型?JS+UA实现方法">HTML如何判断设备类型?JS+UA实现方法</a> </dt> <dd class="cont2"> <span><i class="view"></i>276浏览</span> <span class="collectBtn user_collection" data-id="282863" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/282861.html" class="img_box" title="CSS雷达图制作:clip-path多边形实现教程"> <img src="/uploads/20250812/1755012031689b5bbf88d2a.jpg" onerror="this.src='/assets/images/moren/morentu.png'" alt="CSS雷达图制作:clip-path多边形实现教程"> </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>   |  59分钟前  |   </span> </dd> <dt class="lineOverflow"> <a href="/article/282861.html" class="aBlack" target="_blank" title="CSS雷达图制作:clip-path多边形实现教程">CSS雷达图制作:clip-path多边形实现教程</a> </dt> <dd class="cont2"> <span><i class="view"></i>344浏览</span> <span class="collectBtn user_collection" data-id="282861" 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">542次学习</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">511次学习</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">498次学习</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">484次学习</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/13035.html" target="_blank" title="千音漫语:智能声音创作助手,AI配音、音视频翻译一站搞定!" class="img_box"> <img src="/uploads/20250723/1753258213688098e5ef34b.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/13035.html" class="aBlack" target="_blank" title="千音漫语">千音漫语</a></dt> <dd class="cont1 lineTwoOverflow"> 千音漫语,北京熠声科技倾力打造的智能声音创作助手,提供AI配音、音视频翻译、语音识别、声音克隆等强大功能,助力有声书制作、视频创作、教育培训等领域,官网:https://qianyin123.com </dd> <dd class="cont2">156次使用</dd> </dl> </li> <li> <a href="/ai/13034.html" target="_blank" title="MiniWork:智能高效AI工具平台,一站式工作学习效率解决方案" class="img_box"> <img src="/uploads/20250716/17526246026876edda8c2a4.jpg" onerror="this.onerror='',this.src='/assets/images/moren/morentu.png'" alt="MiniWork:智能高效AI工具平台,一站式工作学习效率解决方案" style="object-fit:cover;width:100%;height:100%;"> </a> <dl> <dt class="lineTwoOverflow"><a href="/ai/13034.html" class="aBlack" target="_blank" title="MiniWork">MiniWork</a></dt> <dd class="cont1 lineTwoOverflow"> MiniWork是一款智能高效的AI工具平台,专为提升工作与学习效率而设计。整合文本处理、图像生成、营销策划及运营管理等多元AI工具,提供精准智能解决方案,让复杂工作简单高效。 </dd> <dd class="cont2">150次使用</dd> </dl> </li> <li> <a href="/ai/13033.html" target="_blank" title="NoCode (nocode.cn):零代码构建应用、网站、管理系统,降低开发门槛" class="img_box"> <img src="https://s0.wp.com/mshots/v1/nocode.cn?w=383&h=328" onerror="this.onerror='',this.src='/assets/images/moren/morentu.png'" alt="NoCode (nocode.cn):零代码构建应用、网站、管理系统,降低开发门槛" style="object-fit:cover;width:100%;height:100%;"> </a> <dl> <dt class="lineTwoOverflow"><a href="/ai/13033.html" class="aBlack" target="_blank" title="NoCode">NoCode</a></dt> <dd class="cont1 lineTwoOverflow"> NoCode (nocode.cn)是领先的无代码开发平台,通过拖放、AI对话等简单操作,助您快速创建各类应用、网站与管理系统。无需编程知识,轻松实现个人生活、商业经营、企业管理多场景需求,大幅降低开发门槛,高效低成本。 </dd> <dd class="cont2">160次使用</dd> </dl> </li> <li> <a href="/ai/13032.html" target="_blank" title="达医智影:阿里巴巴达摩院医疗AI影像早筛平台,CT一扫多筛癌症急慢病" class="img_box"> <img src="/uploads/20250716/1752631805687709fd1f103.jpg" onerror="this.onerror='',this.src='/assets/images/moren/morentu.png'" alt="达医智影:阿里巴巴达摩院医疗AI影像早筛平台,CT一扫多筛癌症急慢病" style="object-fit:cover;width:100%;height:100%;"> </a> <dl> <dt class="lineTwoOverflow"><a href="/ai/13032.html" class="aBlack" target="_blank" title="达医智影">达医智影</a></dt> <dd class="cont1 lineTwoOverflow"> 达医智影,阿里巴巴达摩院医疗AI创新力作。全球率先利用平扫CT实现“一扫多筛”,仅一次CT扫描即可高效识别多种癌症、急症及慢病,为疾病早期发现提供智能、精准的AI影像早筛解决方案。 </dd> <dd class="cont2">157次使用</dd> </dl> </li> <li> <a href="/ai/13031.html" target="_blank" title="智慧芽Eureka:更懂技术创新的AI Agent平台,助力研发效率飞跃" class="img_box"> <img src="https://s0.wp.com/mshots/v1/eureka.zhihuiya.com?w=383&h=328" onerror="this.onerror='',this.src='/assets/images/moren/morentu.png'" alt="智慧芽Eureka:更懂技术创新的AI Agent平台,助力研发效率飞跃" style="object-fit:cover;width:100%;height:100%;"> </a> <dl> <dt class="lineTwoOverflow"><a href="/ai/13031.html" class="aBlack" target="_blank" title="智慧芽Eureka">智慧芽Eureka</a></dt> <dd class="cont1 lineTwoOverflow"> 智慧芽Eureka,专为技术创新打造的AI Agent平台。深度理解专利、研发、生物医药、材料、科创等复杂场景,通过专家级AI Agent精准执行任务,智能化工作流解放70%生产力,让您专注核心创新。 </dd> <dd class="cont2">164次使用</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/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> <li> <dl> <dt class="lineTwoOverflow"><a href="/article/91359.html" class="aBlack" title="UI设计中为何选择绝对定位的智慧之道">UI设计中为何选择绝对定位的智慧之道</a></dt> <dd> <span class="left">2024-02-03</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/282780.html"/> <input type="hidden" name="__token__" value="5bcc3e7effbc81d8a255a48996cea7d9" /> <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/282780.html"/> <input type="hidden" name="__token__" value="5bcc3e7effbc81d8a255a48996cea7d9" /> <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>