Change of the front end (I) : change and invariance of technology
Starting this week, I’m going to write down some thoughts on the changes in front-end technology.
This is part one: Technology changes and doesn’t change
Variable with the same
First of all, as a technical person, you should understand a truth:
With technology: the only constant is change
So if you want to be a good programmer, you can’t expect that just knowing a language or a few framework libraries will be your eternal asset and make you invincible in the world of technology.
That’s not going to happen.
This is why a lot of technical personnel ready to quit the reason why some years may as the growth of the age, they think that they have been unable to keep up with the change, trapped in his own mind or ability, they expect to escape from this kind of change, to find a stable expectations they can secure life things. Of course, it’s not “technology” in their mind.
But this is obviously a myth.
Because they don’t realize that there is something “constant” about technology as it changes. Once you have mastered and understood the immutable, change can be as easy and simple to you as changing your skin.
This is why many excellent programmers abroad are still in the technical front line at an age. The list goes on, Robert C.Martin,Martin Flow, authors of Linux.
And here, maybe before 30, a lot of coders are trying to figure out how to get out, thinking they might not be able to learn or work anymore.
Why can’t we do what others can do in our land? This is a very reflective and reflective phenomenon.
Some of my encounters with the front end in 2020 made me realize how much technology changes and doesn’t change. It felt like a whole new world to me.
That’s why I wanted to share it.
I and the front
Most of the front end people are pipelined, probably starting with the code and working in the front end direction all the time, with only time and experience, 2 years, 5 years or more.
Obviously, I’m not a front-end techie, and in fact my experience with mainstream front-end techies is so different that I can hardly say I’m one of them or anything like them.
My intersection with the front end is not an assembly line. It’s broken point.
There may be three main stages:
Stage 1: Before work
At this stage, because my major was somewhat related to computer, I remember that there was a special course in my university to learn HTML knowledge, WHICH was HTML4 at that time. At the end of the course, the teacher also required me to build a website with HTML.
This was probably my first encounter with the front end.
Stage 2: Back-end development
I spent a lot of time working on back-end development, and maybe the backend people today don’t have that kind of experience, but in my back end years, the front end wasn’t a separate technology direction. In fact, the front end was more backend oriented.
So some of the technologies that most front-end people don’t know about today were front-end technologies in the early days, such as JSPS, Freemarker templates, and Struts pages.
What are these? These technologies may be unfamiliar to both the front end and the back end. Because now the dominant development model should be front – end separation. That is, the back-end logic is implemented by the backend people, and then the REST API is provided. The front end logic is handled by the front end people. This was not the case in the early years of my career, when pages were done by the back end themselves using techniques like JSPS and Freemarker templates.
Why is that?
Because the front-end technology alone wasn’t enough to provide the technical capability to dynamically render complex pages
As WEB pages become more and more complex, static pages like HTML in the early days can no longer adapt to the needs of complex WEB pages, but at that time the front-end itself can not provide dynamic rendering of complex pages. Although JQuery dynamic DOM operation has certain page operation ability, it can not cope with very complex pages. So the dynamic rendering of pages from the back end became the mainstream at that time.
Stage 3: Front and rear end separation
In the years leading up to 2020, I was mostly coding on the mobile side and didn’t do much with the back end at this stage, although there was some. I don’t know much about the front end.
So by the time I meet the front end again in 2020, it’s a completely different world. JQuery and HTML, both of which I’m familiar with, are on the fringes of the front-end world, or even discarded.
In the first half of 2020, I started developing PCX, which is a cross-platform desktop development based on Electron.
I am match with the front end of a complete set of technology, including the TypeScript, React, WebPack, Mobx etc., made a cross-platform desktop software.
I didn’t do front-end development, but it was based on a whole set of front-end technologies, so when I did it, I understood what front-end development was all about again.
What has changed and what hasn’t?
Because it’s not pipelined experience, it’s broken point experience, combined with back-end, mobile development experience. So, I think it’s kind of amazing how far the front end has come, compared to the back end and the mobile end, it’s simply a sea change.
So, I often wonder, why?
It has changed
Yeah, obviously, it’s changed a lot.
The technology of the back end and mobile hasn’t changed nearly as much in recent years as the technology of the front end.
I didn’t touch the back end that much in the first few years, but when I returned to it, I didn’t feel out of place. The main trends are the shift from SSH to Spring Boot and the popularity of microservices. In fact, even with the rise of microservices, there is no way to replace the monolithic or clustered services of the past. Or the emerging Kotlin or responsive programming model, but it’s still too small to be mainstream, and even with that, it’s still not changing as much as the front end.
On mobile, there are Native development, Hibrid hybrid development, and cross-platform development like React Native and Flutter. These are far from changes. They are just different solutions that adapt to different scenarios, not evolution or change. Because none of them is an overwhelming substitute for the others.
The front end is different. It’s not just a new technology or framework, it’s a new coding concept that completely replaces the old coding concept. The new coding mode overwhelms the old coding mode.
Including but not limited to:
-
The front end is transformed from back-end rendering to front-end dynamic rendering
-
From HTML+JS scripting to TypeScript+React object-oriented coding
-
React,Vue component UI coding has replaced the old HTML+JQuery DOM mode UI coding
-
The shift from imperative to declarative UI
-
From code being a product, to code and product being two very different things
It is not an exaggeration to say that these changes have been turned upside down.
It doesn’t change
Of course, since I have coding experience on both the back end and mobile, when I scale up these changes to the technical background, I can see that there are a lot of things that haven’t really changed.
It just feels like a kid who has been out in the field has come back into the mainstream.
Including but not limited to:
- TypeScript is an object-oriented language that is very similar to Java.
- I took DDD domain driven application to PCX development
- The database framework I extracted in PCX is just a copy of the database framework I extracted in iOS.
- The front end can now apply basic face object principles and design patterns
So, you see, if you zoom in, do you say it changes?
The tao and technique
This is one of the biggest things I have learned in 2020. Technology has two sides: change and immutability.
This is the Tao and art
Understand and master this, and you can become a good programmer without fear of change or new technology.
I will cover these topics separately in the future.
As a matter of fact, WHEN I was preparing for PCX, I hadn’t worked on any of the front-end technologies mentioned above, and TypeScript was something I heard about from other front-end people. I didn’t even know it existed until I started working on it, and it took me two weeks to see what it was. I ended up doing the first version of PCX in less than five months.
I didn’t know anything about Kotlin or vert.x until I started myDDD-Vertx this year, but myDDD-Vertx probably didn’t go from my idea to implementation to application to a specific project for two months.
So if you want to be a good programmer, be sure to pursue the path of coding.
Front-end changes and causes
I talked about these front-end changes in the front end, which means that there is a qualitative change in the front-end code.
What changes have taken place on the front end, and what are the specific manifestations?
What caused this qualitative change in the front end?
In the next article, I will talk about the change of the front end (2) : the change of the front end and the search for reasons
Support me by following our official website: taoofcode.cc