Slides available at: http://kansascitywomenintechnology.github.io/IntroToWebConcepts
IDE: Integrated Development Environment - Software meant to support the entire development process, often including compilation for a server-side language.
CMS: Content Management System - A program that allows publishing, editing, and modifying content as well as maintenance from a central interface.
Open source: A program in which the source code is available to the general public for use and/or modification from its original design.
Version Control: is a system that records changes to a file or set of files over time so that you can recall specific versions later.
Architecture: an approach to the design and planning of websites that involves technical, aesthetic and functional criteria. Ex. MVC
Library: a collection of resources used to help build software. Ex. Underscore
Framework: Already architected code that provides a structure for you to build in. Ex. Angular Framework
API: Application Programming Interface - An easy-to-use interface or set of tools made available to access a complex application
IP Address: Internet Protocol Address - A unique address for a computer or a server. Some IP Addresses are only unique to the network they are on while others are completely unique
URL: Uniform Resource Locator - a reference (an address) to a resource on the Internet.
DNS: Domain Name Service - A directory that associates domain names with host IPs to allow users to connect to web sites via URLs
SEO: Search Engine Optimization - The process of increasing your web site's perceived value to search engine algorithms, raising its rank in search results
Web 2.0: Buzzword generally describing a trend towards interactivity, rich media, and social engagement in web design
The Cloud: Services and technology that offer remote storage, processing, or other functionality by way of the internet
Hyper Text Markup Language - The code structure used to convey the content of a web site
<p class="TweetTextSize TweetTextSize--16px js-tweet-text tweet-text" lang="en" data-aria-label-part="0">Think a bunch of <a href="/hashtag/ladydevs?src=hash" data-query-source="hashtag_click" class="twitter-hashtag pretty-link js-nav" dir="ltr"><s>#</s><b>ladydevs</b></a> can beat <a href="/SportingKC" class="twitter-atreply pretty-link js-nav" dir="ltr"><s>@</s><b>SportingKC</b></a> players' record at <a href="/BreakoutKC" class="twitter-atreply pretty-link js-nav" dir="ltr"><s>@</s><b>breakoutkc</b></a>? We do! Join our July <a href="/hashtag/TechTalk?src=hash" data-query-source="hashtag_click" class="twitter-hashtag pretty-link js-nav" dir="ltr"><s>#</s><b>TechTalk</b></a>! <a href="http://t.co/4ST2bAIMwu" rel="nofollow" dir="ltr" data-expanded-url="http://bit.ly/1S4zQV2" class="twitter-timeline-link" target="_blank" title="http://bit.ly/1S4zQV2"><span class="tco-ellipsis"></span><span class="invisible">http://</span><span class="js-display-url">bit.ly/1S4zQV2</span><span class="invisible"></span><span class="tco-ellipsis"><span class="invisible"> </span></span></a></p>
Cascading Style Sheets - A language used to describe the presentation of the content
.tweet { border-bottom: 1px solid #e1e8ed;
cursor: pointer;}
An object-oriented computer programming language commonly used to create interactive effects within web browsers.
console.log("why isn't my shit working?");
A dynamic, open source programming language with a focus on simplicity and productivity.
A package manager for the Ruby programming language that provides a standard format for distributing Ruby programs and libraries (in a self-contained format called a "gem"), a tool designed to easily manage the installation of gems, and a server for distributing them.
An open source, cross-platform runtime environment for server-side and networking applications
A package manager that makes it easy for JavaScript developers to share and reuse code, and it makes it easy to update the code that you're sharing. link
A package manager for Javascript libraries that allows you to define, version, and retrieve your dependencies. link
A typical web site will live or is "hosted" on a web server. Web servers are often large computers connected to a network.
How we get our code to servers for people to see.
Typically across 3 environments:
This is where branching and version control come in handy.
How do other people see my website?
A software development method that stresses communication, collaboration, integration, automation, and measurement of cooperation between software developers and other information-technology (IT) professionals.
tl;dr - Releasing software in an efficient way. It's harder than it sounds.
Clients make requests, servers fulfill them (usually).
For our web discussions, client = browser, but search engine crawlers, command line interfaces, and other applications can also behave as clients.
While any type of computer can be used as a server, they are generally larger and more powerful than others.
Client-side:
Sever-side:
Java:
JavaScript:
In general, this means a site should:
A user-friendly, well-architected site will:
PHP
echo "Hello, world!";
Java
class HelloWorld {
static public void main( String args[] ) {
System.out.println( "Hello World!" );
}
}
Python
'Hello, world!'
Ruby
puts 'Hello, world!'
JavaScript
Not server-side, but just for example
document.writeln('Hello, World!');
To build your web site, you will probably need:
You will also need: