Chapter 1: Introduction
Chapter 1.1: Introduction to Web Technologies:
While implementing any business solution application, developer has to be specific on which platform the
application will run. The most common choices are desktop or web platform. Web application development
has been seeing increasing share in the overall world IT projects.since there is high demand for this in real
world business there is a need for the technology to be more compatible, flexible and advance. The html which
is the base for all the web technology was developed by Tim berners-Lee. The main drawback with this early
version was it supported only text at a time and had only 18 supporting tags. Later the little advance html 4.0
was published which supported CSS for the first time. At that time Internet explorer 3 become popular world
wide. Later the new browser scripting language called Mocha was published which is now popularly renamed
as JavaScript.
The early problem with CSS was most browsers were not compatible with standardized CSS specification. So
it was very difficult for developers to develop web application that was compatible to most devices.A group
known as the the Web Standard Projects created a series of CSS tests called the ACID tests.
Just like CSS, JavaScript went through a bit of a rough patch where browser compatibility was an issue. One
of the earliest libraries that made working with JavaScript fun was jQuery. In 2014, a central repository for
frontend packages was created, called the npm registry.
Now there are more than 20+ powerful tools for web development. The google has come up with Angular js
which is a platform for building mobile and web application. The latest maintenance by google is development
of flutter. The facebook came up with its own library called React. Vue.js , the new emerging javascript
framework was developed by ex-google employee and is the combination of both angular and react.
fig1 : popular web application frameworks
1
Chapter 1.2: Introduction to ReactJS
ReactJS is a declarative, efficient, and flexible JavaScript library for building reusable UI components. It
is an open-source, component-based front end library responsible only for the view layer of the application. It
was created by Jordan Walkie, who was a software engineer at Facebook. It was initially developed and
maintained by Facebook and was later used in its products like Whatsapp and Instagram. Facebook developed
ReactJS in 2011. Today, most of the websites are built using MVC (model view controller) architecture. In
MVC architecture, React is the 'V' which stands for view, whereas the architecture is provided by the Redux or
Flux.A ReactJS application is made up of multiple components, each component responsible for outputting a
small, reusable piece of HTML code. The components are the heart of all React applications. These
Components can be nested with other components to allow complex applications to be built of simple building
blocks. ReactJS uses virtual DOM based mechanism to fill data in HTML DOM. The virtual DOM works fast
as it only changes individual DOM elements instead of reloading complete DOM every time.To create React
app, we write React components that correspond to various elements. We organize these components inside
higher level components which define the application structure.
Fig1 : React logo
2
Chapter 1.3: Introduction to AngularJS
AngularJs is a Javscript open source front-end framework that is mainly used to develop single page web
applications(SPAs).It is a continuously growing and expanding framework which provides better ways for
developing web applications.It changes the static HTML to dynamic HTML.It’s features like dynamic
binding and dependency injection eliminates the need of code that we have to write otherwise.AngularJs is
rapidly growing and because of this reason we have different versions of AngularJs . .It extends HTML
attributes with Directives, and data is binded with HTML.
AngularJs was originally developed in 2008-2009 by Misko hevery and Adam abrons,and is now maintained
by google
The impedance mismatch between dynamic applications and static documents is often solved with:
* a library - a collection of functions which are useful when writing web apps. Your code is in charge and it
calls into the library when it sees fit. E.g., jQuery.
* frameworks - a particular implementation of a web application, where your code fills in the details. The
framework is in charge and it calls into your code when it needs something app specific. E.g., durandal, ember,
etc.
.
Fig2: Angular logo
3
Chapter 1.4: Introduction to Vue.js
Vue.js is a popular JavaScript ES6 based open source frameworks developed by Evan You in 2014 . Vue’s
first development intention is to achieve responsive data binding and UI components with easy Application
Programming Interface(API) . Although Vue is supposed to apply in a single-page application usually
considered as limited functions and hard to adopt in commercial usage, the open source community provide
strong third party supporting library and packages to support Vue to drive complex single page application
with routing, state management and build tooling
Fig3 : Vue logo
4
Chapter 2: Literature survey
1 .Jyoti Shetty, Deepika Dash, Akshaya Kumar Joish, Guruprasad, “Review Paper on Web Frameworks,
Databases and Web Stacks”
International Research Journal of Engineering and Technology (IRJET) e-ISSN: 2395-0056
The development of a web application involves identifying product requirements, designing, coding, and
testing using frameworks and technologies. Frameworks are libraries and classes that give a rich collection of
functionalities. Applications are built on top of frameworks so that the fundamental requirements in
developing a web application are already setup. There are various frameworks available for front-end, and
back-end development supporting different programming languages. The most important part of a web
development lifecycle is choosing the right combination of front-end framework, back-end framework, and
database environment.
2. YongKang Xing, JiaPeng Huang, YongYao Lai, “Research and Analysis of the Front-end Frameworks and
Libraries in E-Business Development”.
With web technology rapidly expands out in recent years, there is a significant trend that Hypertext
Markup Language(HTML)5 turns into a worldwide web consortium and leads the front-end development to
stand on the front stage of internet history. However, there are numerous front-end development frameworks
and libraries such as React, Angular and Vue.These framework and libraries has been boon for developer by
maximizing code reusability and rich components.
5
Chapter 3: Proposed work
Chapter 3.1: React
ReactJS is a declarative, efficient, and flexible JavaScript library for building reusable UI components. It
is an open-source, component-based front end library responsible only for the view layer of the application.
Chapter 3.1.1: Architecture of ReactJS
Core building blocks of React
JSX
Components
State and props
Conditional rendering
Components
Components are the building blocks of any React application, and a single app usually consists of multiple
components. A component is essentially a piece of the user interface. React splits the UI into independent,
reusable parts that can be processed separately.
There are 2 types of components:
1. Class based component
2. Function-based component
Class-based component:
A class-based component is also known as a stateful component
Function-based
They are called function-based because they are literally JavaScript functions. Also, these types of
components are also referred as stateless or representational components because they are best used to only
display UI.A function-based component can also be used as a stateful component.
Props
Passing data from one component to the other is done through properties known as React props. Meaning that,
when a custom component is used we can pass data to it by adding custom attributes to it. React passes the
attribute to the component as an object where the attribute name is the key and it assigns to it the given
value.Props are READ-ONLY and should never be modified.All react components should act like pure
functions with respect to their props.
6
State
State allows components to change the output when a user action has taken place, or when we receive recent
network data etc., without violating the above-mentioned rule. State properties are private and fully controlled
by the component. Therefore, local and encapsulated within the component. When the state is changed in a
component React triggers DOM render and updates the value in UI.
Conditional rendering
It is often needed in our application to show or hide various UI elements based on the state of the application.
To achieve this in React use the JavaScript conditional if statement or ternary operator within the JSX code.
Chapter 3.1.2: Features of react
1.JSX
JSX stands for JavaScript XML. It is a JavaScript syntax extension. Its an XML or HTML like syntax used by
ReactJS. This syntax is processed into JavaScript calls of React Framework. It extends the ES6 so that HTML
like text can co-exist with JavaScript react code. It is not necessary to use JSX, but it is recommended to use in
ReactJS.
2.Components
ReactJS is all about components. ReactJS application is made up of multiple components, and each component
has its own logic and controls. These components can be reusable which helps to maintain the code when
working on larger scale projects.
3.One-way Data Binding
ReactJS is designed in such a manner that follows unidirectional data flow or one-way data binding. The
benefits of one-way data binding gives the better control throughout the application. If the data flow is in
another direction, then it requires additional features. It is because components are supposed to be immutable
and the data within them cannot be changed. Flux is a pattern that helps to keep the data unidirectional. This
makes the application more flexible that leads to increase efficiency.
4.Virtual DOM
A virtual DOM object is a representation of the original DOM object. It works like a one-way data binding.
Whenever any modifications happen in the web application, the entire UI is re-rendered in virtual DOM
representation. Then it checks the difference between the previous DOM representation and new DOM. Once
it has done, the real DOM will update only the things that have actually changed. This makes the application
faster, and there is no wastage of memory.
5.Simplicity
7
ReactJS uses JSX file which makes the application simple and to code as well as understand. We know that
ReactJS is a component-based approach which makes the code reusable as per need. This makes it simple to
use and learn.
6.Performance
ReactJS is known to be a great performer. This feature makes it much better than other frameworks out there
today. The reason behind this is that it manages a virtual DOM. The DOM is a cross-platform and
programming API which deals with HTML, XML or XHTML. The DOM exists entirely in memory. Due to
this, when we create a component, we did not write directly to the DOM. Instead, we are writing virtual
components that will turn into the DOM leading to smoother and faster performance.
Chapter 3.1.3:Pros and Cons of ReactJS
Advantage of ReactJS
1. Easy to Learn and Use
ReactJS is much easier to learn and use. It comes with a good supply of documentation, tutorials, and training
resources. Any developer who comes from a JavaScript background can easily understand and start creating
web apps using React in a few days. It is the V(view part) in the MVC (Model-View-Controller) model. It is
not fully featured but has the advantage of open-source JavaScript User Interface(UI) library, which helps to
execute the task in a better manner.
2. Creating Dynamic Web Applications Becomes Easier
To create a dynamic web application specifically with HTML strings was tricky because it requires a complex
coding, but React JS solved that issue and makes it easier. It provides less coding and gives more functionality.
It makes use of the JSX(JavaScript Extension), which is a particular syntax letting HTML quotes and HTML
tag syntax to render particular subcomponents. It also supports the building of machine-readable codes.
3. Reusable Components
A ReactJS web application is made up of multiple components, and each component has its own logic and
controls. These components are responsible for outputting a small, reusable piece of HTML code which can be
reused wherever you need them. The reusable code helps to make your apps easier to develop and maintain.
These Components can be nested with other components to allow complex applications to be built of simple
building blocks. ReactJS uses virtual DOM based mechanism to fill data in HTML DOM. The virtual DOM
works fast as it only changes individual DOM elements instead of reloading complete DOM every time.
4. Performance Enhancement
ReactJS improves performance due to virtual DOM. The DOM is a cross-platform and programming API
which deals with HTML, XML or XHTML. Most of the developers faced the problem when the DOM was
updated, which slowed down the performance of the application. ReactJS solved this problem by introducing
virtual DOM. The React Virtual DOM exists entirely in memory and is a representation of the web browser's
DOM. Due to this, when we write a React component, we did not write directly to the DOM. Instead, we are
writing virtual components that react will turn into the DOM, leading to smoother and faster performance.
5. The Support of Handy Tools
React JS has also gained popularity due to the presence of a handy set of tools. These tools make the task of
the developers understandable and easier. The React Developer Tools have been designed as Chrome and
8
Firefox dev extension and allow you to inspect the React component hierarchies in the virtual DOM. It also
allows you to select particular components and examine and edit their current props and state.
6. Known to be SEO Friendly
Traditional JavaScript frameworks have an issue in dealing with SEO. The search engines generally having
trouble in reading JavaScript-heavy applications. Many web developers have often complained about this
problem. ReactJS overcomes this problem that helps developers to be easily navigated on various search
engines. It is because React.js applications can run on the server, and the virtual DOM will be rendering and
returning to the browser as a regular web page.
7. The Benefit of Having JavaScript Library
ReactJS is choosen by most of the web developers. It is because it is offering a very rich JavaScript library.
The JavaScript library provides more flexibility to the web developers to choose the way they want.
8. Scope for Testing the Codes
ReactJS applications are extremely easy to test. It offers a scope where the developer can test and debug their
codes with the help of native tools.
Disadvantage of ReactJS
1. The high pace of development
The high pace of development has an advantage and disadvantage both. In case of disadvantage, since the
environment continually changes so fast, some of the developers not feeling comfortable to relearn the new
ways of doing things regularly. It may be hard for them to adopt all these changes with all the continuous
updates. They need to be always updated with their skills and learn new ways of doing things.
2. Poor Documentation
It is another cons which are common for constantly updating technologies. React technologies updating and
accelerating so fast that there is no time to make proper documentation. To overcome this, developers write
instructions on their own with the evolving of new releases and tools in their current projects.
3. View Part
ReactJS Covers only the UI Layers of the app and nothing else. So you still need to choose some other
technologies to get a complete tooling set for development in the project.
4. JSX as a barrier
ReactJS uses JSX. It's a syntax extension that allows HTML with JavaScript mixed together. This approach
has its own benefits, but some members of the development community consider JSX as a barrier. Developers
complain about its complexity in the learning curve.
9
Chapter 3.1.4: Websites developed with ReactJS
Fig 4: Websites developed using ReactJS
10
Chapter 3.2: Angular
AngularJs is a Javscript open source front-end framework that is mainly used to develop single page web
applications(SPAs).It changes the static HTML to dynamic HTML.It’s features like dynamic binding and
dependency injection eliminates the need of code that we have to write otherwise.
Chapter 3.2.1: Architecture of AngularJS
Angular.js follows the MVC architecture,
* The Controller represents the layer that has the business logic. User events trigger the functions which are
stored inside the controller. The user events are part of the controller.
*Views are used to represent the presentation layer which is provided to the end users
*Models are used to represent data. The data in model can be as simple as just having primitive declarations.
Chapter 3.2.2: Features of AngularJS
The core features of AngularJS are as follows −
1Data-binding − It is the automatic synchronization of data between model and view components.
2Scope − These are objects that refer to the model. They act as a glue between controller and view.
3Controller − These are JavaScript functions bound to a particular scope.
11
4Services − AngularJS comes with several built-in services such as $http to make a XMLHttpRequests. These
are singleton objects which are instantiated only once in app.
5Filters − These select a subset of items from an array and returns a new array.
6Directives − Directives are markers on DOM elements such as elements, attributes, css, and more. These can
be used to create custom HTML tags that serve as new, custom widgets. AngularJS has built-in directives
such as ngBind, ngModel, etc.
7Templates − These are the rendered view with information from the controller and model. These can be a
single file (such as index.html) or multiple views in one page using partials.
8Routing − It is concept of switching views.
9Model View Whatever − MVW is a design pattern for dividing an application into different parts called
Model, View, and Controller, each with distinct responsibilities. AngularJS does not implement MVC in the
traditional sense, but rather something closer to MVVM (Model-View-ViewModel).
10Deep Linking − Deep linking allows to encode the state of application in the URL so that it can be
bookmarked. The application can then be restored from the URL to the same state.
11Dependency Injection − AngularJS has a built-in dependency injection subsystem that helps the developer
to create, understand, and test the applications easily.
Chapter 3.2.3: Pros and cons of AngularJS
Advantages of AngularJS
1. It provides the capability to create Single Page Application in a very clean and maintainable way.
2. It provides data binding capability to HTML. Thus, it gives user a rich and responsive experience.
3. AngularJS code is unit testable.
4. AngularJS uses dependency injection and make use of separation of concerns.
5. AngularJS provides reusable components.
6. With AngularJS, the developers can achieve more functionality with short code.
12
7. In AngularJS, views are pure html pages, and controllers written in JavaScript do the business processing.
8.On the top of everything, AngularJS applications can run on all major browsers and smart phones, including
Android and iOS based phones/tablets.
Disadvantages of AngularJS
1. Not Secure − Being JavaScript only framework, application written in AngularJS are not safe. Server side
authentication and authorization is must to keep an application secure.
2.Not degradable − If the user of the application disables JavaScript, then nothing would be visible, except
the basic page.
Chapter 3.2.4: Websites developed with AngularJS
Fig 5: Websites developed using Angular
13
Chapter 3.3: Vue js
Chapter 3.3.1: Architecture of VueJS
Vue.js is a JavaScript framework known for its fast loading speed and easy scalability. Some of its features
can be linked directly its use of a virtual DOM to update the actual DOM as necessary.The Document Object
Model, or DOM, is a kind of interface that treats all the markup language (your HTML) as connected nodes. It
can be seen as an interface of objects for markup elements stored in a tree-like structure.
14
Chapter 3.3.2:Features of Vue.js
1.Components
Vue.js Components are one of the important features of this framework. They are used to extend basic HTML
elements to encapsulate reusable code. You can create reusable custom elements in Vue.js applications that
can be later reused in HTML.
2.Templates
Vue.js provides HTML-based templates that can be used to bind the rendered DOM with the Vue instance
data. All Vue templates are valid HTML that can be parsed by specification-compliant browsers and HTML
parsers. Vue.js compiles the templates into Virtual DOM render functions. Vue renders components in virtual
DOM memory before updating the browser. Vue can also calculate the minimum number of components to
re-render and apply the minimum amount of DOM manipulations when we change the application's state.
3.Reactivity
Vue provides a reactivity system that uses plain JavaScript objects and optimizes re-rendering. In this process,
each component keeps track of its reactive dependencies, so the system knows precisely when, and which
components to re-render.
4.Routing
Navigation between pages is performed with the help of vue-router. We can use the officially-supported
vue-router library for our Single Page Application or if we only need a simple routing and do not want to use
the full-featured router library, we can do this by dynamically rendering a page-level component as following.
Chapter 3.3.3: Pros and cons of VueJS
Advantages of VueJS
1.Very Small in Size
One of Vue.js' biggest advantages is that it is very small in size. The success of a JavaScript framework very
much depends on its size and this exciting JavaScript plug-in is only 18-21KB, so we can download and use it
very easily in no time.
2.Easy to Understand and Code
The Vue.js framework has a very simple structure and very easy to understand. It is one of the reasons for the
popularity of this framework. If we are familiar with HTML and JavaScript, we can easily code in Vue.js. The
users can easily add Vue.js to their web project because of its simple structure and develop applications.
3.Simple Integration with Existing Applications
Vue.js has a lot of components for everything and can be integrated with the existing applications very quickly.
we can integrate it with any application that is written in JavaScript.
15
4.Flexible in nature
Vue.js's flexible nature also makes it easy to understand for the developers of Reactjs, AngularJS, and any
other new JavaScript framework. It provides a lot of flexibility to use virtual nodes to write HTML files,
JavaScript files, and pure JavaScript files.
5.Components
We can create reusable custom elements in Vue.js applications.
6.Easy, comprehensive & detailed documentation
Vue.js provides very easy, comprehensive, and detailed documentation, so the developers who have little idea
about HTML and JavaScript can use it to code.
7.Virtual DOM
Vue.js uses virtual DOM similar to other existing frameworks such as ReactJS, Ember, etc. Virtual DOM is a
light-weight in-memory tree representation of the original HTML DOM and updated without affecting the
initial DOM.
8.Two-Way Communication
Vue.js provides two-way communications with its MVVM architecture that makes it very easy to handle
HTML blocks.
Disadvantages of VueJS
1.Lack of support for large-scale projects
Vue.js is still a young framework. Its community and development team size is still incomparable with more
mature Angular.
2.Risk of over flexibility
Giving development team too many options might result in philosophically different programming approaches
battling inside one team. And, as a result, it is an ultimate nullifier instead of a working software.
3.Limited resources
While the ecosystem is pretty wide, and there are all the required tools to start developing with Vue, it’s still
not as big as React or Angular. Existing plugins that can be used with other frameworks are often not
supported as well.
4.Lack of experienced developers
Vue.js is a relatively young technology that just started gaining popularity.
16
Chapter 3.3.4: Websites developed using VueJS
Fig 6: websites developed using VueJS
17
Chapter 3.4:Comparision of React ,Vue and Angular
Titles Angular React Vue
Baseline A highly performing Library to build A library that has all good
framework excellent UI things of React and Angular
Coading Typescript JavaScript JavaScript and HTML
Functionality Ideal to build native Best to develop SPA Good for both advanced
apps, hybrid apps and and mobile apps SPA and supporting Native
Web apps apps
Ideal for Large-scale and Modern web Suitable for light weight
feature rich application development and web development and
native-rendered apps single-page application
for iOS and Android
Learning Curve A deep learning curve Bit easier than Small learning curve with
angular basic programming
knowledge
Developer note Completely a Offers flexibility in To have separation of
structured-based developer concerns
framework environment
model Based on MVC Based on virtual Based on virtual DOM
architecture/ real DOM
DOM
Community Large community of Facebook developers Open-source project
support developers and community sponsored
supporters
18
Chapter 3.5:Future of web development technology
Front-end development is more than developing websites and making them look good. The bigger picture is
how the product caters to the requirement of the user. Therefore, the prime focus should be tailoring the
products as per the requirements of the target audience and this requires research from the developer’s side.
Front-end development is not limited to the actions a user will be taking. The future demands more of
consistency, a clear visual hierarchy, and simple navigation. Therefore, the front-end developers have to
focus on increased usability.
As the number of users is alarmingly increasing and has no look back in the future as well. With the increase
in the number of browsing, the websites have a significant decrease in accommodation. The front-end
developers should be responsible for providing the users with the comfort of sliding, tapping, and ticking on
mobile devices.
The front-end developers are expected to build the application with highly interactive, accessible, and
consistent. It is expected that they would keep the user-centric approach in mind and make convenience as a
prime focus for the target customers.
Thus, front-end developers have a huge responsibility in the coming years when it comes to frontend
development
19
Chapter 4: About the base paper
With web technology rapidly expands out in recent years, there is a significant trend that Hypertext Markup
Language(HTML)5 turns into a worldwide web consortium and leads the front-end development to stand on
the front stage of internet history. However, there are numerous front-end development frameworks and
libraries such as React, Angular and Vue.These framework and libraries has been boon for developer by
maximizing code reusability.
As developers while creating any application, the main objective is to build a cross platform compatible
application. The frameworks and libraries available in the market today pose a solution to all the problems.
The modern framework and libraries helps developers to built more responsible and native applications. The
boon for developers with modern framework and libraries are, they maximizes the reusability of code there by
not burdening the developer.
The author tries to bring out the importance of these framework and libraries and their benifits.
20
Chapter 5: Conclusion
Every web framework has its own set of advantages and disadvantages. The choosing of framework should be
done based on few critical factors like time needed to take the product to market, long term scalability and
maintenance, ease of programming, developer’s proficiency with the technologies etc.with early entry the
angular has gained much popularity but with the ease for development the react is gaining market rapidly. The
Vue being the combination of these two and being little more power is emerging slowly in the industry.
21
References
[1]Jyoti Shetty, Deepika Dash, Akshaya Kumar Joish, Guruprasad, “Review Paper on Web Frameworks,
Databases and Web Stacks”
International Research Journal of Engineering and Technology (IRJET) e-ISSN: 2395-0056
[2]YongKang Xing, JiaPeng Huang, YongYao Lai, “Research and Analysis of the Front-end Frameworks and
Libraries in E-Business Development”.
[3]Wikipedia,”ReactJS”
https://en.wikipedia.org/wiki/React_(JavaScript_library)
[4]Wikipedia,”AngularJS”
https://en.wikipedia.org/wiki/AngularJS
[5]Wikipedia,”VueJS”
https://en.wikipedia.org/wiki/Vue.js
https://www.codeinwp.com/blog/angular-vs-vue-vs-react/
22