选题[tech]: 20200619 A little bit of plain Javascript can do a lot

sources/tech/20200619 A little bit of plain Javascript can do a lot.md
This commit is contained in:
DarkSun 2020-11-05 05:10:12 +08:00
parent c828845ee1
commit ce1e17c077

View File

@ -0,0 +1,115 @@
[#]: collector: (lujun9972)
[#]: translator: ( )
[#]: reviewer: ( )
[#]: publisher: ( )
[#]: url: ( )
[#]: subject: (A little bit of plain Javascript can do a lot)
[#]: via: (https://jvns.ca/blog/2020/06/19/a-little-bit-of-plain-javascript-can-do-a-lot/)
[#]: author: (Julia Evans https://jvns.ca/)
A little bit of plain Javascript can do a lot
======
Ive never worked as a professional frontend developer, so even though Ive been writing HTML/CSS/JS for 15 years for little side projects, all of the projects have been pretty small, sometimes I dont write any Javascript for years in between, and I often dont quite feel like I know what Im doing.
Partly because of that, Ive leaned on libraries a lot! Ten years ago I used to use jQuery, and since maybe 2017 Ive been using a lot of vue.js for my little Javascript projects (you can see a [little whack-a-mole game I made here as an intro to Vue][1]).
But last week, for the first time in a while, I wrote some plain Javascript without a library and it was fun so I wanted to talk about it a bit!
### experimenting with just plain Javascript
I really like Vue. But last week when I started building <https://questions.wizardzines.com>, I had slightly different constraints than usual I wanted to use the same HTML to generate both a PDF (with [Prince][2]) and to make an interactive version of the questions.
I couldnt really see how that would work with Vue (because Vue wants to create all the HTML itself), and because it was a small project I decided to try writing it in plain Javascript with no libraries just write some HTML/CSS and add a single `<script src="js/script.js"> </script>`.
I hadnt done this in a while, and I learned a few things along the way that made it easier than I thought it would be when I started.
### do almost everything by adding &amp; removing CSS classes
I decided to implement almost all of the UI by just adding &amp; removing CSS classes, and using [CSS transitions][3] if I want to animate a transition.
heres a small example, where clicking the “next” question button adds the “done” class to the parent div.
```
div.querySelector('.next-question').onclick = function () {
show_next_row();
this.parentElement.parentElement.classList.add('done');
}
```
This worked pretty well. My CSS as always is a bit of a mess but it felt manageable.
### add/remove CSS classes with `.classList`
I started out by editing the classes like this: `x.className = 'new list of classes'`. That felt a bit messy though and I wondered if there was a better way. And there was!
You can also add CSS classes like this:
```
let x = document.querySelector('div');
x.classList.add('hi');
x.classList.remove('hi');
```
`element.classList.remove('hi')` is way cleaner than what I was doing before.
### find elements with `document.querySelectorAll`
When I started learning jQuery I remember thinking that if you wanted to easily find something in the DOM you had to use jQuery (like `$('.class')`). I just learned this week that you can actually write `document.querySelectorAll('.some-class')` instead, and then you dont need to depend on any library!
I got curious about when `querySelectorAll` was introduced. I Googled a tiny bit and it looks like the [Selectors API was built sometime between 2008 and 2013 I found a [post from the jQuery author discussing the proposed implementation in 2008][4], and [a blog post from 2011][5] saying it was in all major browsers by then, so maybe it didnt exist when I started using jQuery but its definitely been around for quite a while :)
### set `.innerHTML`
In one place I wanted to change a buttons HTML contents. Creating DOM elements with `document.createElement` is pretty annoying, so I tried to do that as little as possible and instead set `.innerHTML` to the HTML string I wanted:
```
button.innerHTML = `<i class="icon-lightbulb"></i>I learned something!
<object data="/confetti.svg" width="30" height = "30"> </object>
`;
```
### scroll through the page with `.scrollIntoView`
The last fun thing I learned about is `.scrollIntoView` I wanted to scroll down to the next question automatically when someone clicked “next question”. Turns out this is just one line of code:
```
row.classList.add('revealed');
row.scrollIntoView({behavior: 'smooth', block: 'center'});
```
### another vanilla JS example: peekobot
Another small example of a plain JS library I thought was nice is [peekobot][6], which is a little chatbot interface thats 100 lines of JS/CSS.
Looking at [its Javascript][7], it uses some similar patterns a lot of `.classList.add`, some adding elements to the DOM, some `.querySelectorAll`.
I learned from reading peekobots source about [.closest][8] which finds the closest ancestor that matches a given selector. That seems like it would be a nice way to get rid of some of the `.parentElement.parentElement` that I was writing in my Javascript, which felt a bit fragile.
### plain Javascript can do a lot!
I was pretty surprised by how much I could get done with just plain JS. I ended up writing about 50 lines of JS to do everything I wanted to do, plus a bit extra to collect some anonymous metrics about what folks were learning.
As usual with my frontend posts, this isnt meant to be Serious Frontend Engineering Advice my goal is to be able to write little websites with less than 200 lines of Javascript that mostly work. If you are also flailing around in frontend land I hope this helps a bit!
--------------------------------------------------------------------------------
via: https://jvns.ca/blog/2020/06/19/a-little-bit-of-plain-javascript-can-do-a-lot/
作者:[Julia Evans][a]
选题:[lujun9972][b]
译者:[译者ID](https://github.com/译者ID)
校对:[校对者ID](https://github.com/校对者ID)
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创编译,[Linux中国](https://linux.cn/) 荣誉推出
[a]: https://jvns.ca/
[b]: https://github.com/lujun9972
[1]: https://jvns.ca/blog/2017/06/26/vue-js-fun/
[2]: https://www.princexml.com/
[3]: https://3dtransforms.desandro.com/card-flip
[4]: https://johnresig.com/blog/thoughts-on-queryselectorall/
[5]: https://tiffanybbrown.com/2011/08/12/meet-the-selectors-api/
[6]: https://peekobot.github.io/peekobot/
[7]: https://github.com/Peekobot/peekobot/blob/master/peekobot.js
[8]: https://developer.mozilla.org/en-US/docs/Web/API/Element/closest