CSS and AJAX (Week 9) - Learning Objectives
Assessment Structure
- 2 hours, 10 minutes
- Mixture of multiple choice (30-35), free response (1-3) and VSCode (10-15) problems.
- Free response just requires enough detail to answer the question, 1-3 sentences. As long as you are able to explain the concept and answer all aspects that it asks, you are good.
- Coding problems come in two varieties:
- Some will have specs to run (
npm test
) and check your work against (the AJAX project from Tuesday is good practice)
- Some will have an HTML file with specific instructions for CSS rules to apply to achieve the desired styling, as well as some pictures to compare to (the practice assessment is a good example)
- Standard assessment procedures
- You will be in an individual breakout room
- Use a single monitor and share your screen
- Only have open those resources needed to complete the assessment:
- Zoom
- VSCode
- Browser with AAO and Progress Tracker (to ask questions)
- Approved Resources for this assessment:
- MDN: https://developer.mozilla.org/en-US/docs/Web/CSS
Basic CSS (W09D1) - Learning Objectives
Basic CSS
- How to import other CSS files into your CSS file
- Explain how CSS rules are applied based on their order and specificity
- Describe and apply element, id, and class selectors
- Write “combinators” to create compound selector statements to target specific elements
- Explain and apply pseudo selectors for specific elements in specific states (i.e. :hover)
- Explain and apply the
::before
and ::after
pseudo elements, & Use the content CSS property to define the content of an element
- Style content on an HTML page targeting:
- Type faces, sizes, styles, and weights
- Text transformation and alignment
- Colors expresssed as names, hexadecimal RGB values, and decimal RGB values
- Everything about borders
- Shadows
- Opacity (transparency)
- Covering an element with a background image
- Explain the generic font names “serif”, “sans-serif”, and “monospace” and correctly identify examples of each
- Explain why using Web fonts helps with consistent experience across viewing devices:
- Explain absolute and relative length units in CSS
- Demonstrate how to link a stylesheet into an HTML page
- Be able to calculate the specificity of CSS rules and determine which rule override the properties of another
- Use the
content
CSS property to define the content of an element
AJAX (Asynchronous JavaScript and XML) (W09D2) - Learning Objectives
AJAX
- Explain what an AJAX request is
- Identifying the advantages of using an AJAX request.
- Identify what the acronym AJAX means and how it relates to modern Web programming
- Describe the different steps in an AJAX request/response cycle
- Fully use the fetch API to make dynamic Web pages without refreshing the page
- Identify the different types of media that a media query can target
- Explain how the media features (and prefixed subfeatures) of “aspect ratio”, “height”, “orientation”, and “width” are applied
- Use media queries to change the styles of content in an HTML page to achieve a desired effect
Layout and the Box Model
- Describe how:
- padding and margins work in the box model
- the browser positions a fixed positioned element
- the browser positions a relatively positioned element
- the browser positions absolutely positioned elements with and without a relatively positioned parent element
- the browser positions a static positioned element
- Identify elements rendered with specific padding and margin settings
- Apply padding and margins to HTML elements to achieve a desired layout
- Apply positioning settings to HTML elements (fixed, relative, and absolute) to achieve a desired layout. (Sticky positioning is not supported on some older but still used browsers, so it will not be assessed, but can useful.)
- Identify which HTML elements have a default “inline” display value
- Identify which HTML elements have a default “block” display value
- Describe and use z-index positioning of elements
Flexible Box Layout
- Explain how flexible box layout lays out elements
- Use the
flex
property to specify grow, shrink, and basis values.
- Use the
flex-direction
property to direct the layout of the content
- Use the
flex-wrap
property to affect the wrap of content layout within an element using flexible box layout
- Use
align-self
, justify-content
, and align-items
to change the way that children elements are laid out in a flexible box layout
- Use the
order
property to change the order in which elements will appear in a flexible box layout
Grid Layout
- Explain how grid layout lays out elements
- Use the
grid-template-columns
, grid-template-rows
, and grid-template
properties to specify the layout of the grid using relative and absolute measures
- Use
grid-template-areas
to label areas of a grid and grid-area
to assign an element to the area
- Use
column-gap
, row-gap
, and gap
(previously grid-column-gap
, grid-row-gap
, and grid-gap
) to set the “gutter” areas between elements in a grid layout
- Use
grid-column-start
/grid-column-end
and grid-row-start
/grid-row-end
to create spans across multiple columns and rows with positive integers, negative integers, and in conjunction with the “span” operator
- Explain and use the shorthand versions of
grid-column
and grid-row
to define how an element will span a grid layout
- Use the
order
property to change the default order in which items are laid out
- Explain and use the “fr” unit of measure
- Use
justify-items
, align-items
, justify-content
and align-content
to layout items in each grid area
Interactivity and BEM (W09D4) - Learning Objectives
Interactivity
- Use the “hover” pseudo-class to be able to make changes to elements when the device pointer is over an element
- Describe and use the
transition
property to show animated changes due to class and pseudo-class CSS rule application
- Describe and use the
overflow
, overflow-x
, and overflow-y
properties to effect clipping and scrolling on elements
Block, Element, Modifier (BEM)
- Describe what Block means in BEM.
- Describe what Element means in BEM.
- Describe what Modifier means in BEM.
- Identify CSS class names that follow the BEM principle.