<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:dc="http://purl.org/dc/elements/1.1/">
  <channel>
    <title>DEV Community: Vishnu Ram V</title>
    <description>The latest articles on DEV Community by Vishnu Ram V (@vishnuramv).</description>
    <link>https://dev.to/vishnuramv</link>
    <image>
      <url>https://media2.dev.to/dynamic/image/width=90,height=90,fit=cover,gravity=auto,format=auto/https:%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Fuser%2Fprofile_image%2F464436%2F1d6f129a-ceb0-409f-a2da-709ab76eca30.jpeg</url>
      <title>DEV Community: Vishnu Ram V</title>
      <link>https://dev.to/vishnuramv</link>
    </image>
    <atom:link rel="self" type="application/rss+xml" href="https://dev.to/feed/vishnuramv"/>
    <language>en</language>
    <item>
      <title>Path to ace️ front-end web development.</title>
      <dc:creator>Vishnu Ram V</dc:creator>
      <pubDate>Sun, 22 Nov 2020 11:37:46 +0000</pubDate>
      <link>https://dev.to/vishnuramv/path-to-ace-in-front-end-web-development-1pc8</link>
      <guid>https://dev.to/vishnuramv/path-to-ace-in-front-end-web-development-1pc8</guid>
      <description>&lt;p&gt;Quite often, beginners who are trying to learn front-end Web development find themselves in a pretty tight spot. They get overwhelmed by a whole lot of frameworks and libraries one could find on the internet. I certainly was overwhelmed.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://i.giphy.com/media/lkK7hFTOp1s4g/source.gif" class="article-body-image-wrapper"&gt;&lt;img src="https://i.giphy.com/media/lkK7hFTOp1s4g/source.gif"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;But are you one of them? Do you need help in finding your path to becoming an amazing front-end developer?&lt;/p&gt;

&lt;p&gt;well, then keep reading further to achieve what you need ;)&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;Where do I start? and how much should I know?&lt;/p&gt;
&lt;/blockquote&gt;

&lt;p&gt;As a complete beginner, you can start by learning &lt;strong&gt;&lt;em&gt;HTML&lt;/em&gt;&lt;/strong&gt;, &lt;strong&gt;&lt;em&gt;CSS&lt;/em&gt;&lt;/strong&gt; and &lt;strong&gt;&lt;em&gt;JavaScript&lt;/em&gt;&lt;/strong&gt;. These are the basic elements for whichever framework you are wanting to learn. As far as &lt;a href="https://www.w3schools.com/html/default.asp"&gt;&lt;em&gt;HTML&lt;/em&gt;&lt;/a&gt; goes you just need to know all the different &lt;a href="https://www.w3schools.com/tags/default.asp"&gt;&lt;em&gt;tags&lt;/em&gt;&lt;/a&gt; and where to use them. It's that simple.&lt;/p&gt;

&lt;p&gt;Speaking about &lt;strong&gt;CSS&lt;/strong&gt; you are required to understand &lt;a href="https://flexboxfroggy.com/"&gt;&lt;em&gt;flex&lt;/em&gt;&lt;/a&gt; and &lt;a href="https://www.w3schools.com/css/css_grid.asp"&gt;&lt;em&gt;grid&lt;/em&gt;&lt;/a&gt; which you'll be using most of the time to layout your website. Other than that all you need to know is basic styling; For instance, You could move on to learn what &lt;a href="https://www.w3schools.com/cssref/css_selectors.asp"&gt;&lt;em&gt;CSS Selectors&lt;/em&gt;&lt;/a&gt; are and how to achieve &lt;a href="https://www.w3schools.com/css/css_rwd_intro.asp"&gt;&lt;em&gt;responsive web design&lt;/em&gt;&lt;/a&gt;.&lt;/p&gt;

&lt;p&gt;Moving on to &lt;strong&gt;JavaScript&lt;/strong&gt;, you just need to understand basic programming; like different &lt;em&gt;data-types, loops, conditional statement and functions&lt;/em&gt;. These are the building blocks of any programming language. Once you get a good grasp of each concept, programming becomes a easier task, even if you have just started to code. And most importantly, you will be required to know &lt;a href="https://www.w3schools.com/js/js_htmldom.asp"&gt;&lt;em&gt;Document Object Model (DOM) Manipulation&lt;/em&gt;&lt;/a&gt;.&lt;/p&gt;

&lt;p&gt;Now that you know all the basics, can you implement everything to provide functionality? To find the answer to this question, you will have to examine yourselves. That's where exercises come into play. Try to replicate some of the simplest designs from websites like &lt;a href="https://dribbble.com/"&gt;&lt;em&gt;dribbble&lt;/em&gt;&lt;/a&gt;. If you are able to do that with ease, then you are ready to move forward and learn something new.&lt;/p&gt;




&lt;blockquote&gt;
&lt;p&gt;Yeah, you can develop a website now but can you design one?&lt;/p&gt;
&lt;/blockquote&gt;

&lt;p&gt;Most people know how to develop and write clean code all those stuff but their  design sucks &lt;em&gt;(So was mine)&lt;/em&gt;. Every year, millions of students graduate from high schools and colleges with web development as a skill in their resume. It's basically a crowd of students that have mastered a skill, in our case it's web development.&lt;/p&gt;

&lt;h4&gt;
  
  
  What can make you standout from that crowd?
&lt;/h4&gt;

&lt;p&gt;If you are looking forward to stand out from a crowd of skilled individuals, It's not going to be an easy task. But that doesn't mean it is unachievable. All you need to do is develop better-looking websites. In order to be a better front-end developer you are supposed to be creative in your designs. Learn how to use softwares like AdobeXd, Figma, Photoshop, Illustrator for designing and coming up with prototypes of eye-catching websites. Remember, the interface is what draws an user to a website. Functionality comes right after.&lt;/p&gt;

&lt;p&gt;furthermore, get inspired by visiting pleasing (design-wise) websites on the internet like &lt;a href="https://dribbble.com/"&gt;&lt;em&gt;dribbble&lt;/em&gt;&lt;/a&gt; and &lt;a href="https://www.awwwards.com/"&gt;&lt;em&gt;awwwards&lt;/em&gt;&lt;/a&gt;. Few websites are truly a visual treat and looking up to them could highly enhance your designing ability. You can learn all the designing principles and elements of modern web designing from articles and YouTube. Personally I learnt a lot from &lt;a href="https://www.youtube.com/user/DesignCourse"&gt;&lt;em&gt;Design Course&lt;/em&gt;&lt;/a&gt; and &lt;a href="https://www.youtube.com/c/FluxWithRanSegall"&gt;&lt;em&gt;Flux&lt;/em&gt;&lt;/a&gt;.&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;I hope you can design and develop some cool website.&lt;/p&gt;
&lt;/blockquote&gt;

&lt;h4&gt;
  
  
  Choosing a perfect framework for you
&lt;/h4&gt;

&lt;p&gt;Back to being stuck between what framework to choose, you are required make a choice between &lt;a href="https://angularjs.org/"&gt;&lt;em&gt;AngularJS&lt;/em&gt;&lt;/a&gt;, &lt;a href="https://reactjs.org/"&gt;&lt;em&gt;ReactJs&lt;/em&gt;&lt;/a&gt;, and &lt;a href="https://v3.vuejs.org/"&gt;&lt;em&gt;VueJs&lt;/em&gt;&lt;/a&gt; &lt;em&gt;(of course, you can go with PHP, wordpress, etc, too)&lt;/em&gt;. These are some of the most popular web frameworks and libraries used by top tech companies and MNCs. Additionally, they are all open-source.&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;&lt;p&gt;&lt;a href="https://angularjs.org/"&gt;&lt;em&gt;AngularJS&lt;/em&gt;&lt;/a&gt; is a structural framework for dynamic web apps. It uses HTML as template language and extend HTML's syntax to express your application's components clearly and succinctly. It is developed and maintained by &lt;em&gt;Google&lt;/em&gt;.&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;&lt;a href="https://v3.vuejs.org/"&gt;&lt;em&gt;VueJs&lt;/em&gt;&lt;/a&gt; is a progressive JavaScript framework for building &lt;strong&gt;&lt;em&gt;user interfaces (UIs)&lt;/em&gt;&lt;/strong&gt; and single-page applications. it uses &lt;strong&gt;&lt;em&gt;"high decoupling"&lt;/em&gt;&lt;/strong&gt;, allowing developers to progressively create user interfaces (UIs). It is developed and maintained by &lt;em&gt;Evan You&lt;/em&gt;.&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;&lt;a href="https://reactjs.org/"&gt;&lt;em&gt;ReactJs&lt;/em&gt;&lt;/a&gt; is a JavaScript library for building &lt;strong&gt;&lt;em&gt;UI components&lt;/em&gt;&lt;/strong&gt;. It is a component based library in which you can divide the entire website into simpler components which makes development a lot easier. It is developed and maintained by &lt;em&gt;Facebook&lt;/em&gt;.&lt;/p&gt;&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--66BnQJDA--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/i/slrhhhawvmgrbsp6m3ng.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--66BnQJDA--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/i/slrhhhawvmgrbsp6m3ng.png"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;I chose &lt;strong&gt;&lt;em&gt;ReactJs&lt;/em&gt;&lt;/strong&gt; because it is easier to learn and is used by many tech companies. I highly hope that it will not be replaced in the next 5 to 10 years. I personally feel comfortable with react which is why I don't regret choosing it. If you're looking forward to choosing &lt;em&gt;ReactJs&lt;/em&gt;, you will need to learn how to create components; either &lt;strong&gt;&lt;em&gt;Functional component&lt;/em&gt;&lt;/strong&gt; or &lt;strong&gt;&lt;em&gt;Class based component&lt;/em&gt;&lt;/strong&gt;. My preference would be functional component because it can be used effortlessly. Also, it is the current trend.&lt;/p&gt;

&lt;p&gt;Finally, try to understand the &lt;em&gt;life cycle of a component, hooks, styled component&lt;/em&gt;, and &lt;em&gt;state management&lt;/em&gt;. For state management, you can basically use &lt;strong&gt;&lt;em&gt;Context API&lt;/em&gt;&lt;/strong&gt; or &lt;strong&gt;&lt;em&gt;Redux&lt;/em&gt;&lt;/strong&gt; (&lt;em&gt;Context API&lt;/em&gt; is much simpler than &lt;em&gt;Redux&lt;/em&gt;). You can also use &lt;strong&gt;&lt;em&gt;Material-UI&lt;/em&gt;&lt;/strong&gt; to style your app it makes development a lot easier.&lt;/p&gt;

&lt;h4&gt;
  
  
  Conclusion
&lt;/h4&gt;

&lt;p&gt;So, that was a basic road map to learning front-end development. If you follow the path sketched throughout the blog, you can develop pretty great websites but always remember, learning never ceases. You have a lot more to learn and explore. As your next step, try building your own portfolio and do some projects that are based on your tastes &lt;em&gt;(you can do freelancing🚀)&lt;/em&gt;. Taking on a project can be highly fruitful because you will learn; how to be committed to your work, finishing work before deadlines, time management, communicating with clients and finally, become experienced. So, there you have it. Your path to becoming a reliable web developer (There is always an alternative, you can go with &lt;em&gt;Wix&lt;/em&gt;.)&lt;/p&gt;

&lt;p&gt;Happy Learning 😊 !!!&lt;/p&gt;




&lt;p&gt;&lt;strong&gt;Thank you for reading this far. If you enjoyed this post, please share, comment, and press that ❤️. . .&lt;/strong&gt;&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Follow me on &lt;a href="https://dev.to/vishnuramv"&gt;&lt;em&gt;dev.to&lt;/em&gt;&lt;/a&gt;, &lt;a href="http://instagram.com/vvishnu___"&gt;&lt;em&gt;Instagram&lt;/em&gt;&lt;/a&gt; and &lt;a href="https://vishnuramv.medium.com/"&gt;&lt;em&gt;Medium&lt;/em&gt;&lt;/a&gt; if you're interested in more in-depth and informative write-ups like these in the future!&lt;/strong&gt;&lt;/p&gt;

</description>
      <category>webdev</category>
      <category>react</category>
      <category>frontend</category>
      <category>leaning</category>
    </item>
  </channel>
</rss>
