````javascript
$('.foo');
````
````javascript
$('.foo'); // jQuery
````
````javascript
d3.selectAll('.foo'); // D3
````
````javascript
$('div'); // jQuery
````
````javascript
d3.selectAll('div'); // D3
````
## Attributes
````javascript
$('a').attr('href', 'http://vctr.me')
````
````javascript
d3.selectAll('a').attr('href', 'http://vctr.me')
````
## Styles
````javascript
$('div').css('color', 'red')
````
````javascript
d3.selectAll('div').style('color', 'red')
````
(assuming our document already has 3 divs)
````javascript
$('div');
````
data:image/s3,"s3://crabby-images/2dab7/2dab7ce72f7539b4475940462cae8f7aadeadab9" alt=""
(assuming our document already has 3 divs)
````javascript
d3.selectAll('div');
````
data:image/s3,"s3://crabby-images/f2fa7/f2fa788c40bd5117df57154d87cecada24b2d335" alt=""
+ instead of collections of elements
+ d3 selectors are collections of (data, element) pairs
+ assuming our document already has 3 divs
(our document has 3 divs)
````javascript
d3.selectAll('div').data([18, 4, 7]);
````
data:image/s3,"s3://crabby-images/fa3ed/fa3ed4a2620cafe9c79e23dccf6eb8fa456c9218" alt=""
data binding
````javascript
d3.selectAll('div').data(['red', 'green', 'blue'])
.style('color', function(d){ return d})
````
data binding
````javascript
d3.selectAll('div').data([18, 4, 7])
.attr('width', function(d){ return d + '%' })
````
(our document has no divs)
````javascript
d3.selectAll('div').data([18, 4, 7]);
````
data:image/s3,"s3://crabby-images/3a31f/3a31f1a27289dbd0911fa72db51f7d0ed015c642" alt=""
+ here's where things get really different
+ assuming our document does NOT have any DIVS
(our document has no divs)
````javascript
d3.selectAll('div').data([18, 4, 7])
.enter().append('div');
````
data:image/s3,"s3://crabby-images/fa3ed/fa3ed4a2620cafe9c79e23dccf6eb8fa456c9218" alt=""
(our document now has 3 divs)
+ here's where things get epic
+ assuming our document does NOT have any DIVS
(our document has 3 divs)
````javascript
d3.selectAll('div').data([18, 4, 7, 11])
.enter().append('div');
````
data:image/s3,"s3://crabby-images/9bbee/9bbee5ccf26df9a302de22c971b3aa942cf0423a" alt=""
(our document now has 4 divs)
+ here's where things get epic
+ assuming our document does NOT have any DIVS
(our document has 4 divs)
````javascript
d3.selectAll('div').data([18, 4])
.exit().remove();
````
data:image/s3,"s3://crabby-images/de17a/de17abeef625027eefb1116f8fe874ed34b1f49c" alt=""
(our document now has 2 divs)
+ here's where things get epic
+ assuming our document does NOT have any DIVS
````javascript
d3.selectAll('div').data([8, 3, 7])
.enter().append('div').style('opacity', 0)
````
+ just like with jQuery, the selector methods that don't return a new selector apply to each of the selected data/element pairs.
+ add three divs and set their opacity to 0
````javascript
d3.selectAll('div').data([8, 3, 7])
.enter().append('div').style('opacity', 0)
.text('hello world')
.transition().style('opacity', 1)
````
[demo](demos/demo-opacity.html)
+ add three divs, set their opacity to zero, slowly transition in their opacity
data:image/s3,"s3://crabby-images/3a3c9/3a3c9a484886f6159427acff525efd445c002b79" alt=""