web组件开发入门
本文是学习慕课网阿当大话西游之WEB组件后的一个总结。
组件的分类
1 框架组件:依赖于某种框架的组件
2 定制组件:根据公司业务定制的组件
3 独立组件:不依赖框架的组件
定义和加载组件
解决css和js命名冲突
css:通过加前缀来形成命名空间,不要用子孙选择器
js:通过匿名函数自执行来隐藏变量,通过给window添加属性来暴露全局变量
(function(){
var abc = 5;
function TabView(cfg){
this.a = cfg.a;
this.b = cfg.b;
}
TabView.prototype = {
c: function(){
abc++;
},
d: function(){
abc--;
}
}
window.TabView = TabView;
})();
组件的依赖关系
传统通过script标签引入组件的问题:
1 需手动处理组件间的依赖关系
2 加载项太多,破坏页面的整洁度
如何解决:使用require.js
具体实现
如何定制皮肤
通过cfg设置一个skinClassName参数来给容器添加class来控制皮肤
自定义事件
简单回调的问题
1)只能绑定一个回调
2)回调的绑定时间和组件的实例化时间耦合在一起
如果相对独立的多个功能模块都需要绑定组件的同一事件,怎么办?
自定义事件本质:观察者模式
优点:跳出原生事件的限制,提高封装的抽象层级
链式调用
return this
Widget类
原生function类的问题
1)所有类继承自object
2)Object提供的帮助太少了
组件分类:
Utility:与UI无关
Widget:与UI有关
为Widget类添加统一的生命周期
更高级的内容
组件的MVC
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?