ng-zorro-antd 入门初体验


Posted in Javascript onDecember 03, 2018

Angular版本的 Ant Design 总算发布了,其名曰:ng-zorro-antd。

这人要是越期待,心就越着急。早在8月上旬我就开发好了 ng-zorro-vscode;一个在vscode下的snippets。因此,虽然那时未能探到源代码,但从官网的SDK中,就已经对 ng-zorro-antd 有一定全面性了解。

下面将基于我的理解,从宏观角度解析一下,或许能帮助你更好的去使用 ng-zorro-antd。

再次说一下,ng-zorro-antd 真的是非常有良心的作品。

一、安装

ng-zorro-antd 本身只是一个antd组件Angular实现的合集,因此,如果你希望基于 ng-zorro-antd 开发依然需要先安装 Angular Cli。

1、创建项目

# 安装全局,这样允许直接在CMD命令行中使用 `ng` 命令。
npm install -g @angular/cli@latest

# 创建项目
ng new demo

# 安装包
npm install --save ng-zorro-antd

2、导入模块

我建议在 SharedModuel 中导入模块。

@NgModule({
  imports: [
    NgZorroAntdModule.forRoot()
  ],
  exports: [
    NgZorroAntdModule
  ]
});

3、根组件

务必要引入 nz-root 根组件;有且只需引用一次。部分组件需要依赖 nz-root 所以最佳位置放在根组件内,比如 ./src/app.component.html

<nz-root>
  <router-outlet></router-outlet>
</nz-root>

至此,你可以放心在任何页面中使用 ng-zorro-antd 组件。

二、最佳实践

已经实现了绝大多数的 React 版本的组件;虽然今天刚发布,但是已经在阿里内部已经在使用了。

1、命名

ng-zorro-antd 在命名方面还是很讲究的,而且有几个特点:

  • 所有组件、指令都是以 nz- 开头(例:ng-button)。
  • 所有组件、指令属性都是 nz 开头,紧跟大驼峰式命名法(例:[nzSize])。

2、栅格

antd 是以 24 等分的栅格来划分区域,这一点可能跟经常使用 bootstrap 的人会有一点不习惯。

<div nz-row>
  <div nz-col [nzSpan]="12"></div>
  <div nz-col [nzSpan]="12"></div>
</div>

一个 nz-row 内的 nz-col 总格数([nzSpan] 总和)为24表示一行,如果超过会自动换行。

当然,也支持类似 bootstrap 的响应式设计,内置了几种不同的响应。

Size  ng-zorro-antd bootstrap
auto  [nzXs] .col-xs-
540px  [nzSm] .col-sm-
720px  [nzMd] .col-md-
960px  [nzLg] .col-lg-
1140px  [nzXl] .col-xl-

如果你喜欢 flex 布局,需要手动开启:

<div nz-row [nzType]="'flex'" [nzJustify]="'center'" [nzAlign]="'top'">
  <div nz-col [nzSpan]="12"></div>
  <div nz-col [nzSpan]="12"></div>
</div>

3、样式

无须再额外的引用外部任何 antd 的样式,因为 ng-zorro-antd 是以 encapsulation: ViewEncapsulation.None 不隔离的方式封装样式,可以直接在任何地方运用到这些样式。

比如:

<div class="ant-row">
  <div class="ant-col-12">col-12</div>
  <div class="ant-col-12">col-12</div>
</div>

4、时间处理

Angular 默认的时间处理简直就是一个痛,而 ng-zorro-antd 依赖了 moment,因此在处理时间格式上,正确的姿势应该是:

_value | nzDate: 'YYYY-MM-DD ddd'
Outpu: 2017-08-15 周二

5、货币

也是Angular痛点,ng-zorro-antd 并无提供相应Pipe,应该后续会有!

三、工欲善其事,必先利其器

如果你在 vscode 中编写Angular,那么安装 ng-zorro-vscode 代码片断,对开发效率很有帮助。

ng-zorro-antd 入门初体验

四、结论

ng-zorro-antd 对Angular应该会有一个非常大的推动。

当前组件与React组件还有几个比较重要的组件未完成,比如:autocomplate、Cascader 一些很常用的组件。希望有更多大牛加入贡献行列,让 ng-zorro-antd 社区环境更丰富。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
JQuery SELECT单选模拟jQuery.select.js
Nov 12 Javascript
web前端开发也需要日志
Dec 09 Javascript
基于jquery的文本框与autocomplete结合使用(asp.net+json)
May 30 Javascript
js 金额格式化来回转换示例
Feb 23 Javascript
JavaScript对象之深度克隆介绍
Dec 08 Javascript
深入理解JavaScript系列(49):Function模式(上篇)
Mar 04 Javascript
jquery+html仿翻页相册功能
Dec 20 Javascript
用户管理的设计_jquery的ajax实现二级联动效果
Jul 13 jQuery
动态加载、移除js/css文件的示例代码
Mar 20 Javascript
教你使用vue-cli快速构建的小说阅读器
May 13 Javascript
Vue filter 过滤当前时间 实现实时更新效果
Dec 20 Javascript
解决vue-router的beforeRouteUpdate不能触发
Apr 14 Vue.js
如何使用 vue + d3 画一棵树
Dec 03 #Javascript
Vue.js中 v-model 指令的修饰符详解
Dec 03 #Javascript
浅谈ng-zorro使用心得
Dec 03 #Javascript
JS跨域请求的问题解析
Dec 03 #Javascript
VueJS 组件参数名命名与组件属性转化问题
Dec 03 #Javascript
Vue.Draggable拖拽功能的配置使用方法
Jul 29 #Javascript
小程序实现授权登陆的解决方案
Dec 02 #Javascript
You might like
PHPThumb图片处理实例
2014/05/03 PHP
深入理解PHP之源码目录结构与功能说明
2016/06/01 PHP
php多线程并发实现方法
2016/09/30 PHP
一键生成各种尺寸Icon的php脚本(实例)
2017/02/08 PHP
ThinkPHP 在阿里云上的nginx.config配置实例详解
2017/10/11 PHP
php之header的不同用法总结(实例讲解)
2017/11/28 PHP
node.js中的fs.truncate方法使用说明
2014/12/15 Javascript
JavaScript如何自定义trim方法
2015/07/28 Javascript
比例尺、缩略图、平移缩放之百度地图添加控件方法
2015/08/03 Javascript
js判断移动端是否安装某款app的多种方法
2015/12/18 Javascript
js内置对象处理_打印学生成绩单的简单实现
2016/09/24 Javascript
JavaScript 巧学巧用
2017/05/23 Javascript
bootstrap table使用入门基本用法
2017/05/24 Javascript
基于原生js运动方式关键点的总结(推荐)
2017/10/01 Javascript
html中通过JS获取JSON数据并加载的方法
2017/11/30 Javascript
Node.Js生成比特币地址代码解析
2018/04/21 Javascript
解决vuejs项目里css引用背景图片不能显示的问题
2018/09/13 Javascript
ES6 Iterator接口和for...of循环用法分析
2019/07/31 Javascript
[04:48]DOTA2亚洲邀请赛林书豪为VGJ加油
2017/04/01 DOTA
python根据经纬度计算距离示例
2014/02/16 Python
星球大战与Python之间的那些事
2016/01/07 Python
Python的“二维”字典 (two-dimension dictionary)定义与实现方法
2016/04/27 Python
Python通过属性手段实现只允许调用一次的示例讲解
2018/04/21 Python
python抓取网页内容并进行语音播报的方法
2018/12/24 Python
Ubuntu下Anaconda和Pycharm配置方法详解
2019/06/14 Python
选择python进行数据分析的理由和优势
2019/06/25 Python
Python socket模块方法实现详解
2019/11/05 Python
matplotlib源码解析标题实现(窗口标题,标题,子图标题不同之间的差异)
2021/02/22 Python
html5摇一摇代码优化包括DeviceMotionEvent等等
2014/09/01 HTML / CSS
MADE法国:提供原创设计师家具
2018/09/18 全球购物
结构和类有什么异同
2012/07/16 面试题
学习自我鉴定
2014/02/01 职场文书
工作总结与自我评价
2014/09/18 职场文书
财务工作检讨书
2014/10/29 职场文书
Django显示可视化图表的实践
2021/05/10 Python
SSM项目使用拦截器实现登录验证功能
2022/01/22 Java/Android