SVG On
The Web
Brought to you by:
Joni (Bologna) Trythall
Nora the NowSecure narwhal
Oh hi, I'm Joni.
- Started as an Illustrator; but not required!
- Wrote Pocket Guide to Writing SVG
- Publish SVG tutorials
- Product designer NowSecure
- Bake GF cookies for classes
Oh hi, this is Nora.
- Our NowSecure mascot
- Assisting with presentation
Agenda
- What is SVG?
- Why SVG is the best
- Using as <img> & inline
- & CSS
- Where to get 'em
- Preparation
- Advanced features
What is it tho?
- Scalable Vector Graphics
- Two-demential graphics in XML
- Consists of paths, shapes, text
- Powerful alternative to rasters
- Nora & I are SVGs ... on these slides
Why It's Amazing
- Complete scalability
- Responsive logos
- Unique UI capabilities
- The DOM
- Super Accessible
- Neat advanced features
data:image/s3,"s3://crabby-images/87687/8768753cf9604e57cc86b8c2757e43d0925af8ae" alt=""
VS
Ways Of Using
- As an <img> *
- Inline *
- CSS background-img
- As an <object>
- Data URIs
As An img
- Pros
- Straightforward & familiar, minimal markup required
- Cons
- No real editing power, no access to "innards" of graphic
<img src="nora.svg" alt="Nora the narwhal being adorable" />
Inline
- Graphic's code inline in HTML
- svgpocketguide.com
-
Pros
- Total editing power, access all parts, source code; unlimited potential
-
Cons
- Can get messy, more difficult to get started
"AKA the best way."
- Me all the time
Inline: Document Structure
- Organization & Semantics
- SVG element
- g element
- defs element
- symbol & use elements
<svg>
<!-- Where all the magic happens -->
</svg>
Inline: Document Structure
- Stacking order; no z-index
data:image/s3,"s3://crabby-images/e5482/e5482a6d336913b6260574d9e6e87d1adb876f80" alt=""
data:image/s3,"s3://crabby-images/902c1/902c11bf774c5a965f3f23a35b2a3ad8e0f44d3e" alt=""
data:image/s3,"s3://crabby-images/9287b/9287bb60bd16e6b94588a34a3014e4d0016478b0" alt=""
Inline: Basic Shapes
- Rectangles, circles, ellipses, straight lines, polylines, polygons
- Varying attributes required
data:image/s3,"s3://crabby-images/3383f/3383f42ef0df83ce4fba8dbfa7a20f4278a04635" alt=""
Inline: Basic Shapes
- circle:
- rectangle:
<svg>
<rect width="200" height="100" fill="#33ccff" />
</svg>
<svg>
<circle cx="75" cy="75" r="75" fill="#254cff" />
</svg>
data:image/s3,"s3://crabby-images/d5246/d5246ba205a13154ba1f8279f2d5abea2392d867" alt=""
data:image/s3,"s3://crabby-images/06998/0699834f4b0deba813f84f55a88f212f036b4c8c" alt=""
Inline: Basic Shapes Nora :(
data:image/s3,"s3://crabby-images/c7733/c77333159be341ce218cd14f028e94fb6a02fd33" alt=""
- Possible but not recommended because nightmares
Inline: Workspace
- Tricky, but fame & fortune when it makes sense
- Infinite "canvas" with set viewing window
- Two coordinate systems
- Coordinate system transforms
- translate, rotate, scale, skew
"This is hard."
- Me all the time
data:image/s3,"s3://crabby-images/def64/def64c2ebcb9cf23235e9febbf880d80081d2db3" alt=""
data:image/s3,"s3://crabby-images/97e63/97e63a5583f94103e29da3529f8c0d0693c3d207" alt=""
Inline: Workspace
data:image/s3,"s3://crabby-images/cf112/cf112b1e7ad8a881e46d0a611e60aa882122ac75" alt=""
Inline: fill & stroke
- fill = like background
- stroke = like border
data:image/s3,"s3://crabby-images/7f2f6/7f2f6cc99fa4dd816cac368966955616a2942b72" alt=""
data:image/s3,"s3://crabby-images/030e2/030e21b4f57262690431edc4cfc87eb112c536ff" alt=""
Inline: fill & stroke
- Lots of neat <stroke> attributes
- stroke-linecap & stroke line-join
data:image/s3,"s3://crabby-images/8a8b6/8a8b6a0c07b78d5d083773ecefffb4e6e2e0e5ae" alt=""
data:image/s3,"s3://crabby-images/b5b6c/b5b6c1102a529b223f518199dabfea905968e260" alt=""
- dashes & offsets
Inline: text
- Written within the <text> element
<svg width="600" height="100">
<text x="30" y="80">
<!-- Clever or not clever text goes here -->
</text>
</svg>
- No word-wrapping like CSS; use <tspan>
- Interesting effects
& CSS
- Styling edits w/in code or in CSS; when inline
- As an <img> CSS can:
- change size
- use as background-image
-
@keyframe animations === fun
- OK fine, some practical stuff too
Where To Get 'Em
- The Noun Project
- Icomoon
- Nucleo
-
Vector Graphic Software
- Ai, Sketch, Inkscape
- Hand code
Prepping For Use
- Get code from Vector Graphic Software or open w/ text editor (like Atom)
- Run code through optimizer to clean up nonsense
- SVGO (also a Grunt plugin)
- Peter Collingridge's Optimiser
Browser Support
- As <img>
data:image/s3,"s3://crabby-images/fa24b/fa24ba222246a49e2a9166682b75c2713ba7c0d1" alt=""
Browser Support Cont.
- CSS background-img
data:image/s3,"s3://crabby-images/d0807/d080766bf011514545f567c3f16cf76dab404f64" alt=""
Browser Support Cont.
- Inline
data:image/s3,"s3://crabby-images/52d7a/52d7abfd4012072b6296d208066d7d72e811b02c" alt=""
Browser Support Cont.
tl;dr Very strong until things get weird
Advanced Features
- Sprites & icons systems
- Hand coded gradients & patterns
- "Drawing" line animations
- Animation libraries
Advanced: Gradients
<defs>
<radialGradient id="Gradient1" cy="60%" fx="95%" fy="70%" r="2">
<stop offset="0%" stop-color="#0099ff" />
<stop offset="20%" stop-color="#252a46" />
<stop offset="40%" stop-color="#0099ff" />
<stop offset="60%" stop-color="#eafaff" />
<stop offset="80%" stop-color="#252a46" />
<stop offset="100%" stop-color="#252a46" />
</radialGradient>
</defs>
data:image/s3,"s3://crabby-images/38f13/38f131f33b17166951ece4378c614dc4f85f4a29" alt=""
Advanced: "Drawing" Things
- Demo
- Playing with stroke-dasharray & stroke-dashoffset
Advanced: Icon Systems
- Demo
- The power of <symbol> & <use>
data:image/s3,"s3://crabby-images/acac1/acac133e0bba838a7c9b73cebf07106088703a19" alt=""
Wrap Up
- Use it today
- Illustration background not required
- HTML/CSS knowledge
- Join us in Philly & Wilmington
Bye & Contact
@jonitrythall
jonibologna.com
Using SVG On The Web
By Joni Trythall
Using SVG On The Web
- 1,624