Class Central is learner-supported. When you buy through links on our site, we may earn an affiliate commission.

National University of Singapore

Web Coding Fundamentals: HTML, CSS and Javascript

National University of Singapore via Kadenze

Overview

This course is an introduction to using the Web for artistic creation. It is a "literacy" course designed to introduce you to the various core components that make the web such a powerful platform for art – art that is not only visual, but sonic, physical, interactive, and social. It will give you the basics (in terms of knowledge and code templates) to make things that run in browsers using:

• Animation with graphics and sound,

• Interaction with graphics and sound,

Just as you don't need to be a mechanic to drive a car, you do not need to wait until you are an expert programmer before creating work for the web.

There is a vast array of tools for making things for the web. Making things for the web is a process of constant learning and discovery – not one of knowing everything first and then making. It is also a process of ripping and mashing rather than writing everything from scratch. Getting comfortable with this process is the first step, and is the approach we take in this introductory course.

By the end of this course, you will be making things with the real-world core components that give the web its potential for art, but you will have only just begun. More importantly, you will understand what you have to learn more about to accomplish your artistic objectives, be able to recognize things and be able to evaluate their value to you, and have a command of the terminology you need to search for and discuss your needs and interests with the huge community of people on the net with experience (and code chunks) to share.

Why JavaScript and the Web?

There are some excellent special-purpose coding platforms for artists out there such as Processing for interactive graphics, Chuck or supercollider for synthesis, graphical languages such as Max/MSP or PD for interactive sound and graphics. These platforms have extensive communities of people to share experience and code with. However, these special-purpose platforms are not standard web building and design tools.

What they offer is a direct path to achieving a specific artistic objective, but it is at the expense of a more general applicability of language, tools, and skills that would allow you to interact with people in the web-based creative industries. They do a great job at "hiding" things you may not want to worry about as an artist, but dealing with a bit of the scaffolding is necessary if the web is the space you have chosen to embark on for developing your work.

This course will take you through the basics you need to develop artistic content for the web using standard web tools – JavaScript, html, and several fundamental libraries. It will point you to exactly what concerns an artist most – making creative content. It will guide you and teach you what you can ignore for now in order to focus on artistic content, but will not prevent you from integrating with the vast world of the web and learning and using some of the scaffolding if and when you should need it later.

Our basic approach to achieving this goal is to "throw you in to the deep end" with a set of code templates for meeting artistic goals – interactive graphical mobile applications using physical sensors, for example, and explaining simple things you can do immediately to explore and implement your own ideas.

The advantages to JavaScript:

• It is the language embedded in all browsers today.

• It is general purpose, and makes no assumptions that limit your artistic objectives.

• You can deploy all your work on the web for others to experience.

• You only need to learn one language for writing both client and server code.

• A *lot* of other people use it that you can share and communicate with.

• It is a marketable skill.

Thus, we are not restricting you to special-purpose tools that don't generalize well to the web – but that doesn't mean you will have to write a bunch of code not related to your artistic vision. The "template" technique used in this course is a "middle way" that gets you up and going fast, but provides a path to future growth and connection to the real world.

You will learn to recognize patterns of code that you need not know how to write. This will provide you with a basic understanding of how things work in the real world (let's call it literacy). This will help you find, recognize, and use chunks of code that others share, and it will allow you to focus on code directly relevant to artistic content.

This will give you the foundations you need to go on learning on your own by exploring the unstructured wealth of material available out there on the web to pillage and modify for your own work. That is how real web programmers work all the time, anyway!

Syllabus

  • Intro To The Web Landscape
    • This session will cover set up, HTML & CSS, how to structure a document, as well as help and support resources.
  • Color, Events, Interactivity
    • This session will introduce how to use color and basic interactivity such as events and callbacks, mouse interaction, and sliders and buttons.
  • Scalar Vector Graphics
    • In this session we will discuss paths, curves, event listeners, functions and arguments, as well as animation (with Raphael).
  • Computational Thinking Concept Review
    • This session will review key computational thinking concepts, and the put them to use in a series of DIY tasks and talk-throughs.
  • Lists, Loops, & Interactive Animation
    • In the final session we will look at periodic callback timers, per-frame drawing functions, animation, and calculating motion.
  • Javascript Basics
    • This session will introduce operators, variables, strings, objects, and functions; course template directory and file structures, how to use console.log, communicating with the DOM, and interaction.
  • Timer Animation
    • In this session we will further our work with shapes and colors, interaction, and animation including timers and callbacks.

Taught by

Lonce Wyse

Reviews

4.8 rating, based on 5 Class Central reviews

Start your review of Web Coding Fundamentals: HTML, CSS and Javascript

  • Anonymous
    The course is good, clear, well explained and at the right pace for a beginner. I would recommend it if you have never written a line of code, it's a great start to learn more.
  • Anonymous
    This introduction to javaScript goes directly to the most difficult parts in a very didactic fashion. The lecturer is a scientist with a PhD in physics/engineering and several papers on his name. He attacks directly the notion of event object, the latter I had a hard time understanding from other courses, and pretty much forces you to understand it. The lessons are meticulously correct, the assignments quite demanding but very rewarding. I have never seen such well prepared lessons before.
  • Anonymous
    It guides you to become more confident with your skills while you're coding. There's enough material to bring you through most of the challenges but urges you to explore out of your comfort zone because not everything is spoon-fed. Great course.
  • Clyde Wayeni
    I have been doing JavaScript lesson to grasshopper so I decided to do it online and I liked it

    And I just really want to learn more to explore besides that it's a type of a job that I just like I really want to spend all most my entire life doing that
  • Anonymous
    He's so good at teaching web development and I almost understand all of it and I hope that it will help me near in the future and I also hope that with this course I could help myself to become an expert IT

Never Stop Learning.

Get personalized course recommendations, track subjects and courses with reminders, and more.

Someone learning on their laptop while sitting on the floor.