<?xml version="1.0" encoding="utf-8" standalone="yes"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom">
  <channel>
    <title>前端工程化 on Saiga</title>
    <link>http://localhost:1313/tags/%E5%89%8D%E7%AB%AF%E5%B7%A5%E7%A8%8B%E5%8C%96/</link>
    <description>Recent content in 前端工程化 on Saiga</description>
    <generator>Hugo</generator>
    <language>zh-cn</language>
    <managingEditor>wuwenzen@outlook.com (wuwj)</managingEditor>
    <webMaster>wuwenzen@outlook.com (wuwj)</webMaster>
    <lastBuildDate>Wed, 20 Dec 2023 00:00:00 +0000</lastBuildDate>
    <atom:link href="http://localhost:1313/tags/%E5%89%8D%E7%AB%AF%E5%B7%A5%E7%A8%8B%E5%8C%96/index.xml" rel="self" type="application/rss+xml" />
    <item>
      <title>2023 年技术小结：从前端工程到 AI 应用</title>
      <link>http://localhost:1313/posts/2023-12-20-2023-summary/</link>
      <pubDate>Wed, 20 Dec 2023 00:00:00 +0000</pubDate><author>wuwenzen@outlook.com (wuwj)</author>
      <guid>http://localhost:1313/posts/2023-12-20-2023-summary/</guid>
      <description>&lt;p&gt;如果用一句话概括 2023 年的技术主线，大概是：&lt;/p&gt;&#xA;&lt;blockquote&gt;&#xA;&lt;p&gt;&lt;strong&gt;一边继续把前端工程体系打磨扎实，一边认真把 AI 接到「真业务」里。&lt;/strong&gt;&lt;/p&gt;&#xA;&lt;/blockquote&gt;&#xA;&lt;p&gt;这一年做了几件印象比较深的事情：&lt;/p&gt;&#xA;&lt;ul&gt;&#xA;&lt;li&gt;把多个前端项目合到 Monorepo；&lt;/li&gt;&#xA;&lt;li&gt;尝试微前端，把老系统和新模块串起来；&lt;/li&gt;&#xA;&lt;li&gt;在中台里跑了几轮完整的 A/B 实验；&lt;/li&gt;&#xA;&lt;li&gt;接入大模型 API，做了文档问答、内部工具智能化的小应用；&lt;/li&gt;&#xA;&lt;li&gt;把 AI 真正纳入自己的日常开发流程。&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;p&gt;这篇总结就按这两条主线——&lt;strong&gt;前端工程&lt;/strong&gt; 和 &lt;strong&gt;AI 应用&lt;/strong&gt; 来回顾一下。&lt;/p&gt;&#xA;&lt;hr&gt;&#xA;&lt;h2 id=&#34;1-前端工程线更稳也更合在一起&#34;&gt;1. 前端工程线：更「稳」也更「合在一起」&lt;/h2&gt;&#xA;&lt;h3 id=&#34;11-monorepo-落地&#34;&gt;1.1 Monorepo 落地&lt;/h3&gt;&#xA;&lt;p&gt;年初开始，把几个关联度高的中台项目合进一个 Monorepo：&lt;/p&gt;&#xA;&lt;ul&gt;&#xA;&lt;li&gt;tools：pnpm + Turborepo；&lt;/li&gt;&#xA;&lt;li&gt;结构：&lt;code&gt;apps/&lt;/code&gt; + &lt;code&gt;packages/&lt;/code&gt;；&lt;/li&gt;&#xA;&lt;li&gt;公共库：UI 组件、工具函数、统一 ESLint 配置。&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;p&gt;收益：&lt;/p&gt;&#xA;&lt;ul&gt;&#xA;&lt;li&gt;组件库和工具修一次，多项目同步升级；&lt;/li&gt;&#xA;&lt;li&gt;工程规范「一处改，全员受益」；&lt;/li&gt;&#xA;&lt;li&gt;新项目孵化成本明显降低。&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;p&gt;也逼着自己思考：&lt;strong&gt;「什么才值得抽成库，什么就留在应用里？」&lt;/strong&gt;&lt;br&gt;&#xA;这对边界感的训练很有帮助。&lt;/p&gt;&#xA;&lt;h3 id=&#34;12-微前端小规模应用&#34;&gt;1.2 微前端小规模应用&lt;/h3&gt;&#xA;&lt;p&gt;不是全线切微前端，而是谨慎选择了几块：&lt;/p&gt;&#xA;&lt;ul&gt;&#xA;&lt;li&gt;老 Vue2 中台 + 新 Vue3 模块；&lt;/li&gt;&#xA;&lt;li&gt;部分实验性应用用 React 写。&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;p&gt;用「框架型微前端」把它们挂在一个壳子下：&lt;/p&gt;&#xA;&lt;ul&gt;&#xA;&lt;li&gt;主应用管登录、导航、全局样式；&lt;/li&gt;&#xA;&lt;li&gt;子应用各自管内部路由和业务。&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;p&gt;实践下来感受是：&lt;/p&gt;&#xA;&lt;ul&gt;&#xA;&lt;li&gt;在「多团队 + 多技术栈 + 独立发布」场景下确实好用；&lt;/li&gt;&#xA;&lt;li&gt;但也确实增加了复杂度，需要配套工程规范。&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;h3 id=&#34;13-实验和监控让前端更可观测&#34;&gt;1.3 实验和监控：让前端更「可观测」&lt;/h3&gt;&#xA;&lt;p&gt;这一年比较系统地做了两件事：&lt;/p&gt;</description>
    </item>
    <item>
      <title>从 jQuery 到模块化：一次前端工程意识的转变</title>
      <link>http://localhost:1313/posts/2019-12-20-first-side-project-review/</link>
      <pubDate>Fri, 20 Dec 2019 00:00:00 +0000</pubDate><author>wuwenzen@outlook.com (wuwj)</author>
      <guid>http://localhost:1313/posts/2019-12-20-first-side-project-review/</guid>
      <description>&lt;h2 id=&#34;背景&#34;&gt;背景&lt;/h2&gt;&#xA;&lt;p&gt;在较早阶段的前端开发中，常见技术栈以 &lt;strong&gt;jQuery + 传统页面结构&lt;/strong&gt; 为主。&lt;br&gt;&#xA;这种模式在页面数量有限、业务逻辑简单时，具备实现成本低、交付速度快的优势。&lt;/p&gt;&#xA;&lt;p&gt;但随着功能逐步增多、页面之间产生联动，代码结构问题开始显现，对可维护性提出了更高要求。&lt;/p&gt;&#xA;&lt;hr&gt;&#xA;&lt;h2 id=&#34;传统写法暴露的问题&#34;&gt;传统写法暴露的问题&lt;/h2&gt;&#xA;&lt;h3 id=&#34;1-全局作用域污染&#34;&gt;1. 全局作用域污染&lt;/h3&gt;&#xA;&lt;div class=&#34;highlight&#34;&gt;&lt;pre tabindex=&#34;0&#34; style=&#34;color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4;&#34;&gt;&lt;code class=&#34;language-js&#34; data-lang=&#34;js&#34;&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;&lt;span style=&#34;color:#66d9ef&#34;&gt;var&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;list&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt; [];&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;&lt;span style=&#34;color:#66d9ef&#34;&gt;function&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;init&lt;/span&gt;() {}&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;&lt;span style=&#34;color:#66d9ef&#34;&gt;function&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;render&lt;/span&gt;() {}&#xA;&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;&lt;p&gt;常见问题包括：&lt;/p&gt;&#xA;&lt;ul&gt;&#xA;&lt;li&gt;变量与函数暴露在全局作用域&lt;/li&gt;&#xA;&lt;li&gt;多页面脚本容易互相覆盖&lt;/li&gt;&#xA;&lt;li&gt;问题定位与调试成本逐渐升高&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;hr&gt;&#xA;&lt;h3 id=&#34;2-文件职责混乱&#34;&gt;2. 文件职责混乱&lt;/h3&gt;&#xA;&lt;p&gt;在缺乏结构约束的情况下：&lt;/p&gt;&#xA;&lt;ul&gt;&#xA;&lt;li&gt;单个 JS 文件体积不断膨胀&lt;/li&gt;&#xA;&lt;li&gt;DOM 操作、业务逻辑、接口请求混杂&lt;/li&gt;&#xA;&lt;li&gt;修改局部逻辑时容易产生连锁影响&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;hr&gt;&#xA;&lt;h3 id=&#34;3-代码复用能力弱&#34;&gt;3. 代码复用能力弱&lt;/h3&gt;&#xA;&lt;p&gt;相似功能在不同页面中往往通过复制实现：&lt;/p&gt;&#xA;&lt;ul&gt;&#xA;&lt;li&gt;复制后再做细微修改&lt;/li&gt;&#xA;&lt;li&gt;长期来看难以统一维护&lt;/li&gt;&#xA;&lt;li&gt;Bug 修复成本被成倍放大&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;hr&gt;&#xA;&lt;h2 id=&#34;引入模块化思路&#34;&gt;引入模块化思路&lt;/h2&gt;&#xA;&lt;p&gt;为缓解上述问题，开始尝试在不依赖复杂工具链的前提下，引入基础的模块化设计思想。&lt;/p&gt;&#xA;&lt;hr&gt;&#xA;&lt;h3 id=&#34;1-按职责拆分代码结构&#34;&gt;1. 按职责拆分代码结构&lt;/h3&gt;&#xA;&lt;div class=&#34;highlight&#34;&gt;&lt;pre tabindex=&#34;0&#34; style=&#34;color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4;&#34;&gt;&lt;code class=&#34;language-txt&#34; data-lang=&#34;txt&#34;&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;js/&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;├── api.js&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;├── render.js&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;├── event.js&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;└── main.js&#xA;&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;&lt;p&gt;通过人为约定实现基础分层：&lt;/p&gt;&#xA;&lt;ul&gt;&#xA;&lt;li&gt;接口请求集中管理&lt;/li&gt;&#xA;&lt;li&gt;渲染逻辑独立拆分&lt;/li&gt;&#xA;&lt;li&gt;事件绑定避免分散在各处&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;p&gt;即使不依赖构建工具，也能显著提升代码可读性。&lt;/p&gt;&#xA;&lt;hr&gt;&#xA;&lt;h3 id=&#34;2-使用-iife-隔离作用域&#34;&gt;2. 使用 IIFE 隔离作用域&lt;/h3&gt;&#xA;&lt;div class=&#34;highlight&#34;&gt;&lt;pre tabindex=&#34;0&#34; style=&#34;color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4;&#34;&gt;&lt;code class=&#34;language-js&#34; data-lang=&#34;js&#34;&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;(&lt;span style=&#34;color:#66d9ef&#34;&gt;function&lt;/span&gt; () {&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;  &lt;span style=&#34;color:#66d9ef&#34;&gt;var&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;state&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt; {};&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;  &lt;span style=&#34;color:#66d9ef&#34;&gt;function&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;init&lt;/span&gt;() {}&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;  window.&lt;span style=&#34;color:#a6e22e&#34;&gt;pageInit&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;init&lt;/span&gt;;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;})();&#xA;&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;&lt;p&gt;这种方式在早期用于：&lt;/p&gt;</description>
    </item>
  </channel>
</rss>
