呼~~终於写完所有躲在浏览器後面的东西了,现在我们已经架好了主机、布好了 API 程序、装好了 MySQL,就只差前端页面了。从今天开始,我们就要开始一步一步做出我们的前端 APP。
写前端程序必须得要对以下几个语言有基本的掌握度
如果读者对於这三个必备技能还不熟悉,笔者非常推荐 W3Schools 的教学,里头的教材设计得非常好,即使是张白纸,只要从头到尾一步一步跟着读懂、做完,就能对这三个既能有一定程度的掌握。
有别於後端有非常多种语言、框架可以选,前端的世界已经被 JavaScript 统一了,除了一些非常阳春的纯 HTML 静态网页,几乎没有一个网页不用 JavaScript。就像之前所说的,实际工作之後我们几乎不会再自干 library,而是会用框架跟套件,前端当然也是,而前端现在有三个主流框架:Vue, Angular, React。以下简略说明三个框架的差别,
(图片取自三大框架的 Wiki 页面)
笔者自己只有用过 Angular,所以关於这三个框架的比较,笔者是根据跟前同事们聊天得来的主观意见,不代表客观事实。三大框架的优劣比较一直以来都是网路上的热门话题,邦友们如果有兴趣看看比较,随便搜寻一下都有优质的比较文章。
框架的选择与 Day21 的 ORM 选择一样,基本上看团队还有信仰。任一个框架能做的事,其他框架也都做得到。笔者当时因为信仰 Google,加上爬文人家说会後端学 Angular 容易上手,於是就选择入坑了。笔者的前端技能是自己做菜的一部份,系列文中如果出现错误还请大家不吝指教。
笔者认为,介绍 Angular 就必须从 Angular 不是 AngularJS 开始!
Angular 不是 AngularJS!
Angular 不是 AngularJS!
Angular 不是 AngularJS!
很重要所以要说三次!
笔者没有写过 AngularJS,但是认识的写过 AngularJS 的同事没有一个不酸 AngularJS 的,所以即便没写过,也不难想像,AngularJS 以前是如何被 React 按在地上磨擦。2016 年 AngularJS 的团队把 Angular 整个砍掉重练,现在已经是一个成熟又好用的框架,但是没有接触 Angular 生态的人,还有很多停留在「Angular(JS) 很烂,最好学 React 或 Vue」的想法,资讯完全没有更新。
Angular 每半年更新一次主版号,现在已经到了 Angular 12,内容的迭代改进非常之快,整个框架越来越进步、越来越强大。Angular 身为三大框架中最肥大的一个,有以下几个优点:
不过,像是笔者前一份工作,某外国主管坚持用 jQuery 的思维硬干写 "Anygular" 又是另一回事了(苦笑)
虽然有些大神认为合格的工程师不应该依赖强型别来帮自己侦错,应该要做什麽事情都在自己掌握之中,不应该牺牲 JavaScript 的自由变成强型别,但笔者认为,除了整个团队全部都是神,不然以凡人的世界来讲,TypeScript 牺牲自由带来的好处绝对利大於弊。
当然, Angular 也有他的缺点,首先就是入门门槛相对高一些,像是他的架构因为职责拆分得很细而且横跨很多档案,没有 K 文件或者有人带,自己光看程序码要搞懂真的有一点难度。其他像是框架太大,写个小网页就像用牛刀在杀鸡等等。但不管怎样,做为一个不断进步的主流框架,笔者觉得 Angular 还是非常值得学习。本系列的最後几篇,就要来介绍如何用牛刀来杀鸡,用 Angular 做一个简单的前端 APP,我们明天见!
<<: JavaScript Day 14. 灵活运用 reduce()
>>: [Day23] CH11:刘姥姥逛物件导向的世界——多型
今天要来做一个计算BMI的简易App! activity_main.xml: 使用LinearLay...
一日客语:中文:早安 客语:anˋzoˋ安走 前提:在学习Array.methods时会想知道他是如...
这是我们今天要聊的内容,老样的,如果你已经可以轻松看懂,欢迎直接左转去看我同事 Andy 精彩的文...
前言 跟变数一样 JavaScript 在 ES6 为函式新添加一种写法,他和传统函式有以下差异: ...
所谓工欲善其事,必先利其器。 选择 Python 的理由又是什麽? 那我们得先从语言的特性及优缺点来...