Atitit api design Usability simple 易用性之简单化设计
目录
1.2. 切换到了"write less, do more"模式 2
2.2. Linux every thins is file api 3
3.4. 支持链式操作,可以在一条语句中完成很复杂的逻辑 4
3.6. 1.3. 参数接收 JSON 对象 2命名参数 4
3.7. 细粒度api + 粗粒度快捷api +高级api三层 4
3.9. 2.1. 语言简单性 弱类型 动态变量 动态实体 2 4
3.10. 2.2. 数据结构简单 arr 代替了array map set 2 4
7.5. 2.10. 资源释放一次性 不常驻内存 vs 常驻类 4 6
根本不需要去了解真正的 Array 和 List 有什么区别,也不需要去管数据流、缓冲区,也不用管多线程并发编程,从长期来看,这一点是致命的,它使得 PHP 生态中的重要一环很脆弱,很可能是导致 PHP 最终衰落的真正因素。
,jQuery正是通过一个字符一个字符地节约程序员的工作量来达到这一伟大目标的。
压缩后仍达97k的jQuery竟然帮助我们少写了这么多代码,好神奇啊啊啊!这正是库/框架设计的要点,那就是"没有问题创造问题也要解决问题!"
据我所知,就图书馆的预期哲学而言,改进是"多做少写"之类的。我认为他们做得很好。您可以编写一些非常简洁而富有表现力的代码,以完成大量工作。
-
- 归一化(锤子钉子理论)
- 1. 好API的6个特质 极简(minimal 语义清晰简单(have clear and simple semantics)、符合直觉(be intuitive)、易于记忆(be easy to memorize)和引导API使用者写出可读代码(lead to readable code
API之于程序员就如同图形界面之于普通用户(end-user)。API中的『P』实际上指的是『程序员』(Programmer),而不是『程序』(Program),强调的是API是给程序员使用的这一事实。
在第13期Qt季刊,Matthias 的关于API设计的文章中提出了观点:API应该极简(minimal)且完备(complete)、语义清晰简单(have clear and simple semantics)、符合直觉(be intuitive)、易于记忆(be easy to memorize)和引导API使用者写出可读代码(lead to readable code)。
- 范例
- Php win jq
- Linux every thins is file api
- Jq $ multi override
- Api设计的简单规则
取值赋值统一化
-
- 层次简单
- 支持批量的操作数组中的元素,也叫隐式迭代
- 支持链式操作,可以在一条语句中完成很复杂的逻辑
-
- 1.3. 参数接收 JSON 对象 2命名参数
- 细粒度api + 粗粒度快捷api +高级api三层
- 2. 具体 2
- 2.1. 语言简单性 弱类型 动态变量 动态实体 2
- 2.2. 数据结构简单 arr 代替了array map set 2
2.3. 免编译 热部署 2
2.4. Api简单性 内部dsl相对于 3
2.5. 最常见的操作都有优化的简短api 3
2.6. 单线程 稳定健壮可靠 vs 并发 3
2.7. Sql vs orm 3
2.8. 面向过程 pop vs oop 3
2.9. 同步模式 vs 异步 3
2.10. 资源释放一次性 不常驻内存 vs 常驻类 4
2.11. 然支持热部署 4
2.12. 实现了高度的封装,让开发人员专心面对业务 4
2.13. 业务逻辑文本预处理器 4
2.14. Win vs linux 4
Mysql 代替redis es等
ATITIT提升效率 U易用性简单性优化 简化 提升 FURPS的 方法总结
Atitit lib api design 原则 类库设计原则