yz3938
    • Create new note
    • Create a note from template
      • Sharing URL Link copied
      • /edit
      • View mode
        • Edit mode
        • View mode
        • Book mode
        • Slide mode
        Edit mode View mode Book mode Slide mode
      • Customize slides
      • Note Permission
      • Read
        • Only me
        • Signed-in users
        • Everyone
        Only me Signed-in users Everyone
      • Write
        • Only me
        • Signed-in users
        • Everyone
        Only me Signed-in users Everyone
      • Engagement control Commenting, Suggest edit, Emoji Reply
    • Invite by email
      Invitee

      This note has no invitees

    • Publish Note

      Share your work with the world Congratulations! 🎉 Your note is out in the world Publish Note

      Your note will be visible on your profile and discoverable by anyone.
      Your note is now live.
      This note is visible on your profile and discoverable online.
      Everyone on the web can find and read all notes of this public team.
      See published notes
      Unpublish note
      Please check the box to agree to the Community Guidelines.
      View profile
    • Commenting
      Permission
      Disabled Forbidden Owners Signed-in users Everyone
    • Enable
    • Permission
      • Forbidden
      • Owners
      • Signed-in users
      • Everyone
    • Suggest edit
      Permission
      Disabled Forbidden Owners Signed-in users Everyone
    • Enable
    • Permission
      • Forbidden
      • Owners
      • Signed-in users
    • Emoji Reply
    • Enable
    • Versions and GitHub Sync
    • Note settings
    • Note Insights New
    • Engagement control
    • Make a copy
    • Transfer ownership
    • Delete this note
    • Save as template
    • Insert from template
    • Import from
      • Dropbox
      • Google Drive
      • Gist
      • Clipboard
    • Export to
      • Dropbox
      • Google Drive
      • Gist
    • Download
      • Markdown
      • HTML
      • Raw HTML
Menu Note settings Note Insights Versions and GitHub Sync Sharing URL Create Help
Create Create new note Create a note from template
Menu
Options
Engagement control Make a copy Transfer ownership Delete this note
Import from
Dropbox Google Drive Gist Clipboard
Export to
Dropbox Google Drive Gist
Download
Markdown HTML Raw HTML
Back
Sharing URL Link copied
/edit
View mode
  • Edit mode
  • View mode
  • Book mode
  • Slide mode
Edit mode View mode Book mode Slide mode
Customize slides
Note Permission
Read
Only me
  • Only me
  • Signed-in users
  • Everyone
Only me Signed-in users Everyone
Write
Only me
  • Only me
  • Signed-in users
  • Everyone
Only me Signed-in users Everyone
Engagement control Commenting, Suggest edit, Emoji Reply
  • Invite by email
    Invitee

    This note has no invitees

  • Publish Note

    Share your work with the world Congratulations! 🎉 Your note is out in the world Publish Note

    Your note will be visible on your profile and discoverable by anyone.
    Your note is now live.
    This note is visible on your profile and discoverable online.
    Everyone on the web can find and read all notes of this public team.
    See published notes
    Unpublish note
    Please check the box to agree to the Community Guidelines.
    View profile
    Engagement control
    Commenting
    Permission
    Disabled Forbidden Owners Signed-in users Everyone
    Enable
    Permission
    • Forbidden
    • Owners
    • Signed-in users
    • Everyone
    Suggest edit
    Permission
    Disabled Forbidden Owners Signed-in users Everyone
    Enable
    Permission
    • Forbidden
    • Owners
    • Signed-in users
    Emoji Reply
    Enable
    Import from Dropbox Google Drive Gist Clipboard
       Owned this note    Owned this note      
    Published Linked with GitHub
    • Any changes
      Be notified of any changes
    • Mention me
      Be notified of mention me
    • Unsubscribe
    --- tags: mstu5003, tinker, js team: Claire, Fei, Tiansong --- # TINKER - Javascript Part I See demonstration: https://codepen.io/jmk2142/pen/eGZRME :::info **README:** At the bottom (after the tinker activities) there is a [**NOTES**](#NOTES) section with a text-based conceptual explanation of many of the things going on here. My recommendation: - Play with the interface to get a sense of what it does. - Look at the Tinker Tasks and code first to get a sense of the context. - Read the NOTES as it will arm you with ideas to approach the tinker task/problems. - Then try the tinker problems. ::: ## Tinker Tasks This tinker takes the basics of what you learned about variables, functions, arrays, and puts it in a real context of web-pages. This is our first foray into actual user-computer interaction. As a general rule of thumb, at the very least, for every section/part you should be thinking: > What is the STATE? > What is the SEQUENCE? > What is the CAUSALITY? In your groups - try to articulate these line by line, part by part. Articulation should be _out loud_ or _in writing_. It's very important that you do this outside of your head. ### Part 0 - Warmup - [Definitely Maybe](https://youtu.be/TDe1DqxwJoc) > Jimmy asks, Sally... will you go to the prom with me? > [Sally](https://youtu.be/cmpRLQZkTb8?t=1m10s) handwrites the following reply back. ```javascript= function yes(x){ return x(); } function no(x){ return 'yes'; } function maybe(no){ return no; } var definitely = maybe(yes(no)); ``` **Inputs and Outputs** - Try to mentally solve the problem first (using pen and paper OKAY.) Then try it to see the actual answer. Then adjust your answer accordingly. - What do you think is the value of `definitely`? - Is Jimmy going to the prom with Sally? > Yes - How does this work? (Code, not relationships.) > - When is the `no` function called? > In the second step - On the line `var definitely = maybe(yes(no));` there aren't ()s immediately after `no`. What is the significance of this? > It indicates that no is a value, not a fuction. - Explain how this code snippet works, line by line, part by part. - Be very specific - Use important keywords - Provide explanation of what each syntax detail represents as well > First step: ```javascript function yes(x){ return x(); } ``` result in function`no()` > second step ```javascript function no(x){ return "yes"; } ``` result in string "yes" >third step ```javascript function maybe(x){ return x; } ``` result in string "yes" **Template Literals** - Backtick symbols `` ` `` in JS are different than single-quotes `'` and double-quotes`"`. They are used to make what is called, `template literals`. ```javascript var x = "bitter"; var y = "sweet"; var z = `Coffee is ${x}, Sugar is ${y}, Monday mornings are ${x}${y}.`; var n = "Coffee is " + x + ", Sugar is " + y + ", Monday mornings are " + x + y + "."; // z and n end up being the same values after the String is resolved. // "Coffee is bitter, Sugar is sweet, Monday mornings are bittersweet." ``` - What does the `${}` syntax represent? > It means adding variable [x] in the sentence. - Why are template literals super useful for us? > it saves a lot of space and requires less syntax rules. ### Part 1 :::info **Parts 1-4: Breaking it Apart** It might help to start by forking the codepen into four separate pens. And for each pen, reducing/removing all unused code, i.e. both HTML and JS for that part, so that all that remains are the functional ones for that part to work. (There is a reason why I don't do this for you...) Reducing what is visually in front of you can greatly help you to focus on the bits that are relevant to the sub-problem at hand. Note that `printLog()` is utilized across multiple parts. ::: - Click on the link at the top to view the `index-simple.html` version. Compare the HTML between this version and the Bootstrap version. Compare the JS between this version and the Bootstrap version. - How do these two versions compare with regard to helping you understand Javascript? > We notice that HTML is different while JS remians the same. HTML is different in terms of bootstrap version addes more style classes including `panel`, `panel-default`,`panel-body`,`btn`,`btn-` - Play with the interface (each of the buttons) and observe how the program reacts. When tinkering, try changing the order in which you play with the interface. Take note of the printed _history_. - Explain how this program works with regard to STATE, SEQUENCE, and CAUSALITY of each line, and/or specific parts of a line as appropriate. Use specific vocabulary, as demonstrated in the notes section. - Be sure to articulate both aspects of the HTML and JS. - What does the `prompt` function return? > `prompt` function is similar to alter function. but prompt allow user to text something in the prompt box - Explain what you think the `document.querySelector()` does. Talk about this in terms of the functions vocabulary presented in the Notes. - If I told you that `document.querySelector` RETURNS something, what do you think that something is? - How could you alter the `printName` function in order to print the users first and last name in the browser window tab? > `function makeFullName(first, last) { return first + " " + last; }` - How would you use the `makeFullName` function to shorten the `greetUser` and `printName` code? - `function greetUser(){` - `return first +''+last}` ### Part 2 - Play with the interface (each of the buttons) and observe how the program reacts. When tinkering, try changing the order in which you play with the interface. Take note of the printed _history_. - Explain how this program works with regard to STATE, SEQUENCE, and CAUSALITY of each line, and/or specific parts of a line as appropriate. Use specific vocabulary, as demonstrated in the notes section. - Be sure to articulate both aspects of the HTML and JS. > STATE is set as default mode, showing undefined username and undefined email. Following with the function definition and data input storage, the state of username and email has been updated and assigned attributes, which we point to SEQUENCE. The CAUSALITY will realize once the print info ensures the data are displayed. And the reset button allows the new data to be entered and stored. - What kind of events are happening in Part 2 and explain how this relates to when the handlers will run. > When the global and window events like click happen, the handlers will be triggered. - What is `event.target`? > The event.target property can aim at the element which originally occurred. And the element that prompted the event is returned by the property. - What does the dot `.value, .textContent, .innerHTML` represent in this context? > The .value is used to represent the value of an element, input, select. The .textContent lets the text content of a node be set. The .innerHTML property represents the HTML content of an element, relating to how a web page is displayed. - Why does `updateEmail` have a parameter for `event` data but the other functions do not? > The parameter for event data that updateEmail have but other functions do not have can allow the data to be assigned a new value which will be displayed later by print info. - `resetInfo` is actually a little broken. Why? > Because it triggers the previous data to be still stored in the input and causes the new value not being displayed. ### Part 3 - Play with the interface (each of the buttons) and observe how the program reacts. Take note of the printed _INFO_. - Explain how this program works with regard to STATE, SEQUENCE, and CAUSALITY of each line, and/or specific parts of a line as appropriate. Use specific vocabulary, as demonstrated in the notes section. - Be sure to articulate both aspects of the HTML and JS. > - if we click a "Show Image Data" button written with HTML, an onclick event will be triggered and the "printElementPartialData" function will be executed. If we click the "Change Image" button, the "changeImage" function is trigered that change the cat image to a dog image. ::info State in JS is an object that stores dynamic data of a component to follow changes between renderings. It changes based on user input. For HTML, the state shows the state stored in the state object. Sequence in JS is a set of instructions executed one after the other. Sequence in HTML refers to the order of tags used in a document and there is only one sequnce, which is html tag, head tag, title tag and body tag. Causality in JS - Compare and contrast the `showImageData` and `showImageViaParent` functions. - How do these two different functions achieve the same output? > - They both have function called printElementPartialData and they both called the querySelector to choose the image. But they have different parameter of this function. - Compare and contrast the `showParentData` and `showParentViaImage` functions. - How do these two different functions achieve the same output? > - They both have function called printElementPartialData and they both called the querySelector to choose the image. But they have different parameter of this function. - Play with the Change Image button. - Can you modify the related code so that each time you pressed it, it would show 1 of 5 images, cycling through to the next image per click? - There are several ways to solve this. > - set clickCount = 0 keeping track of the numbers of change image. ``` if (clickCount < 6){ clickCount++ } else { clickCount = 0 } ``` - Play with the Show This Button button. - What is the value of the property `onclick` of the button? ``` function onclick(event) { showButtonData(event) } ``` ### Part 4 - Challenge - Play with the interface (each of the form inputs) and observe how the program reacts. Carefully take note of what actions cause what results, in what order. **ALSO**, open up your Chrome Devtools and watch your inspect elements tool pane as you interact with this form. - Explain how this program works with regard to STATE, SEQUENCE, and CAUSALITY of each line, and/or specific parts of a line as appropriate. Use specific vocabulary, as demonstrated in the notes section. - Be sure to articulate both aspects of the HTML and JS. - Explain the differences between `select`, `checkbox`, `radio`, `textarea` with regard to how we get the input `values`. - What is the importance of the `name` attribute, especially for radio buttons? - Explain the significance of `e`, `banana`, `bananaEvent`, and `event`. - How are they the same and how are they different? - Try tinkering with some of these functions to produce some diffent looking, behaving results in the results pane. - Explain what you tinkered with and what the results were. --- # NOTES I wasn't sure whether to include this supplementary reading as part of the Tinker or a separate document. But here it is. You can read it first, but it probably would help to at least scan through the Tinker questions so as you read this, you can think of the Tinker questions as a context and how they relate, to make sense of some of these extras I've included. ## Programming Overview You've already "coded" things. HTML/CSS is a way to code web-documents for consuming in browsers, and style documents for declaring how style rules apply to your web-documents. You've learned that there is structure to code, hierarchy and sequence to code, syntax to code, that specific important keywords mean something in code. Now, we're going to go further and start to "program" things using these principles, and then some. Programming is just a set of instructions (through code) to tell the computer how to execute a particular task, a series of **routines**. There is syntax involved (as defined by the Javascript language) and logic involved (how things should happen, when). This is what really makes the web so powerful - with programming, we can make things react to users, produce human-computer interactions, hopefully in joyful ways. ### How to think about programming I've been thinking about this one a lot. And from my years of experience, I've kind of distilled it down to three things you should be thinking about with every little thing you learn about programming. Really, these are the golden questions you should ask anytime you are writing, reading, studying programs. That is: 1. What is the STATE of the program? 2. What is the SEQUENCE of the program? 3. What is the CAUSALITY of the things in the program? That's really it. If you do the following things, pretty much you can start to break problems down into manageable parts, as well as ask the right questions when it comes to figuring out parts you don't understand. ### STATE > the particular condition that something is in at a specific time You can imagine that when you visit Facebook for the first time, the program is at a certain zero state. You see a splash page and some marketing to get you to sign up. This state is easy to imagine as you can visually think of the state of the program. But what you are now trying to see as a programmer, is how the state might be defined beyond the surface of what you can see. For example, we might represent this state as the result of some code like this: ```javascript= var loggedIn = cookie.authentication; if (loggedIn === true) { showUserFeed(); } else { showSplashPage(); } ``` Since we're on the splash page, you can imagine that the state of the program, more specifically, the state of the variable `loggedIn` is false. If they were already logged in, you could imagine the state of the program starting with `loggedIn === true` and therefore, pushing the displayed state to the _user feed_. Let's say that the user doesn't have an account. We could say that the state of the program is that `var user = undefined;` Let's say the user starts filling out the signup form and each time they fill in one item, we update the state of the user: - `user.firstName = "Santa";` State of user (firstName) updated. - `user.lastName = "Claus";` State of user (lastName) updated. Each time this user data is updated, we are changing the state of the program. And through these states and assignments of states we can push how the program looks and behaves. For example, if the user leaves the page and comes back, maybe we want the program state not to start back at zero, but to start where the user left off. States are represented by variables. You set variables to save the state of a particular program. This data that represents a certain state of a program can then be used to do something about it. That is, to _cause_ an update in the way the page looks or behaves as demonstrated in the above example. **So the takeaway**: When you are learning this stuff, each line, each routine, each little part of a routine, you should be asking yourself: > What is the state of the variables? > What is the state of the program? ### SEQUENCE > a particular order in which related events, movements, or things follow each other. We've already established how sequence can have an effect on HTML/CSS. As a matter of fact, in Javascript sequence also has an important role. In general, code runs from top to bottom, left to right. However, with programming we have the ability to make for much more sophisticated, and dynamic sequences of things to happen. ```javascript= var userTopicPrefs = []; if (userTopicPrefs.length > 0) { showPinboard(userTopicPrefs); } else { showTopicPicker(); } ``` In the above code, based on the user's topic preferences we influenced the sequence of routines to happen. Since the user has no preferences (an empty array) we bypased the routine to show the pinterest like pinboard via `showPinboard()` and instead went to a "pick your topic preferences" interaction via `showTopicPicker()`. Take a look at the following code: ```htmlmixed= <input type="text" onchange="updateComment(event)" /> <button onclick="postComment()">SAVE</button> ``` ```javascript= var comment = undefined; function updateComment(event) { var inputElement = event.target; comment = inputElement.value; } function postComment() { // get comment data and save it to the database } ``` In this example, when the text input changes value (user fills it in) the `updateComment` function is called `updateComment()`. This sets the state of the comment variable to whatever text the user wrote in the input. The `postComment` function is called `postcomment()` when the html button is clicked. And we could get the state of the `comment` variable and send that data to the database. We could say that the intended sequence of this is: 1. User types in text - change event triggered - `updateComment()` called with `event` data passed in as argument - `updateComment` routine begins - `inputElement` is set to the HTML input element, via `event` property of `target` - `comment` is set to the text, via the `value` property of `inputElement` - `updateComment` routine ends 2. User clicks on the button - click event triggered - `postComment()` function is called - `postComment` routine begins - `comment` state is the user text and sent to the database - `postComment` routine ends However, what if the user clicks on the **SAVE** button before they enter any text in the input? Sequence is more than just the order in which you write your code. When a function is called will change the sequence of what routines, and sub-routines execute. When you have user interactive things (like button clicks) the sequence can change depending on when a user triggers an interactive event. Sometimes, some code might not happen at all. These are all things you need to think about very explicitly and conscientiously. > What are the independent groups of code sequences (routines) in my program? > How will the STATES and EVENTS affect the SEQUENCE of the program? ### CAUSALITY You can't really mention programming without addressing causality. And in our prior work, we've been very adamant about seeing and understanding the causality of things we do. It may seem obvious, but we program things in order to cause things to happen. Mostly, it's about causing: - Changes to the STATE of the program - Changes to the SEQUENCE of the program To be honest, I can't think of anything else any line of code would do. Even things like using code to GET the state of a program, is usually for the purpose of eventually changing the state of the program. This third golden principle of programming ties the two other golden principles together. Programming is by nature, a very explicit exercise. Understanding how each part of a program, from the higher level logic to the lower level syntax, _causes_ the program to work in a certain way is the key. Each rule in programming usually is tied to a SINGULAR result. Programming has very little ambiguity in that regard. You tell the computer precisely what you need it to do in a very exact way, or it won't work. Ambiguity, is for the humans. > What does this program routine cause? > What does this part of the routine cause? > What does this syntax: symbol, operation, pattern cause? (low-level) Ask yourself questions regarding these three golden rules with each line of code you write and you should be on your way to understanding it in a more systematic manner. ## FUNCTIONS: Inputs and Outputs Arguably, the biggest problems I see when students are learning functions are the conceptual understandings around the following things: - Understanding a `function` _declaration_ vs. a `function` _call_. - Understanding `function` sub-routines in the context of a larger sequence. - Understanding the difference between _parameters_ and _arguments_ in relation to INPUTS. - Understanding the `return` keyword in relation to OUTPUTS. ### Declaring and Calling Functions > Declaring a function is telling the computer: "Remember this code and run it when I tell you to in the future." > Calling a function is telling the computer: "Remember that code? Run it now." #### Declaring To setup a function, you have to declare a function. That's about it. There is one key giveaway that something is a function declaration. That giveaway is the keyword `function`. Also note, that when we declare a function we also define it as a block of code to run. The giveaway here is the opening and closing curly-braces `{}`. ```javascript // Function declaration and definition PATTERN function funcName(params) { // sub-routine defined } ``` ```javascript function doSomething() { ... } ``` Do you see the keyword `function` above? Yep, it's a declaration. Won't execute on its own but you essentially told the computer to be ready for the future. ```javascript var doIt = function() { ... }; ``` Do you see the keyword `function` above? Yep, it's a declaration. Won't execute on its own but you essentially told the computer to be ready for the future. This function doesn't have a name like the first example (i.e. `doSomething`). It has a reference to it, via the variable `doIt`. But it is nameless. We call this an `anonymous` function. The variable `doIt` becomes the _inferred name_. For the most part, you can treat these similarly although there are some caveats which we might discuss later. How about this one? ```javascript doIt(); ``` Nope. There is no `function` keyword. Here we are not declaring a function. We can assume it was already declared prior, or maybe declared as a default with the browser, which comes with a set of functions already declared and usable for us. Let's look at a stranger example: ```javascript setInterval(function() { // code }, 1000); ``` Do you see the keyword `function` above? Kind of? Here there are actually two functions. The first is a function named `setInterval`, the second is an anonymous function that we happen to declare right there. Having trouble seeing these two? Let's separate them a little bit so you can see. ```javascript setInterval( ___ , 1000); function() { // code } ``` `setInterval` is a function given to us by default. It has already been declared somewhere by our browser. Notice there is no `function` keyword associated with it. Here we are actually _calling_ the function. The second function is anonymous. There is no name given to it. But it is a `function` and it is being declared right there inside the _call_. Again, the key point is to see the keyword `function` and know that you are declaring a function, and that you have defined a function. What does this do? `setInterval` is basically a timer. It accepts two parameters. The first argument must be a `function` and second is a `Number`. Basically, `setInterval` needs a `function` that will be used every X milliseconds. Thus, in this example the `function` will run every 1 second interval. Every second, internally, `setInterval` will _call_ the function you passed in. Thus, it is convenient for us to declare a function right within the `setInterval` call, giving us this funny looking but common format. We could have easily rewritten this like the following: ```javascript function moveClockSecHand() { // code to move the second hand of the analog clock } setInterval(moveClockSecHand, 1000); ``` It's the same as above, except we declared a named function on the lines prior, and passed that function into the `setInterval` as an argument through the reference. #### Calling To use a function, you have to _call_ a function. There is one key giveaway that something is a function _call_. That giveaway is that you see parentheses `()` immediately after some reference and there is no keyword `function`. The pattern to call a function is the following: ```javascript funcName(); // Without arguments funcRef(argA, argB, ...); // With arguments ``` If you see `something()` or `something(arg, arg)` or something like that you are _calling_ an already declared function. You might have declared it yourself, it might come from the default, it might come from a library like Bootstrap. You'll also notice that we don't have curly-braces `{}` when calling a function. Makes sense since curly-braces are for blocking off and defining the code to be run. Since we've already done that, when you call a function you won't see any `{}`. ```javascript doSomething(); ``` Do you see the keyword `function` above? Any `{}`? No. So it's not a declaration. Does it fit the pattern of `something()`? With `()` right after the function name? Yup. Thus, here we are _calling_ the function, telling the computer to execute it as it was declared and defined earlier. ```javascript doSomething("Thomas"); ``` Does it fit the pattern of a function call? Yes. Do you see a `function` keyword or `{}`? No. Here, we are _calling_ the `doSomething` function and passing in the argument `"Thomas"` which, depending on how the function was declared - will probably do something with the input. ```javascript doSomething; ``` Do you see the keyword `function` above? No. So it's not a declaration. Do you see any `()` following this reference in the pattern of `something()`? No. So we are not _calling_ a function either. Here, this is essentially a variable. Much earlier in this section, we did declare it and define it. So we can say that the variable `doSomething` just points to a function. `doSomething` is a function. But the declaration happened way earlier, and it is not being called right now. ### Thinking of Function Sequence as Sub-routines A function is basically a block of code, a sub-routine that will execute when you _call_ upon it to do so. Take a look at the following routine. ```javascript= function setName(someName) { myName = someName; } var myName = "Anonymous"; setName("George Washington"); myName = "Valentina Tereshkova"; setName("Mark Twain"); ``` You can think of the sequence of this routine as executing top to bottom. But keep in mind that the code inside the function `setName` is a sub-routine of the larger code. That sub-routine does not actually happen until the function is called upon `setName(...)`. So the order of how this code happens is the following: ``` Line 1 - function is declared. Line 5 - variable is declared and assigned a value. Line 7 - function is called. Line 2 - sub-routine executes. Line 8 - variable is assigned a value. Line 9 - function is called. Line 2 - sub-routine executes. ``` ### Paramters vs. Arguments as INPUT > A parameter is a variable in a function definition. > An argument is the data you pass into the function's parameters, when a function is called. Here is the pattern to understand this: ```javascript= var kelvin; function celciusToKelvin(celcius) { kelvin = celcius + 273.15; } celciusToKelvin(0); // kelvin = 273.15 ``` We declared and defined the `celciusToKelvin` function on line 3. Inside the `()`, `celcius` is the parameter, a variable name we made up. `0` is the argument we pass into the function when we call it on line 7. We could have defined the parameter like this: ```javascript function celciusToKelvin(c) { kelvin = c + 273.15; } celciusToKelvin(-273.15); // kelvin = 0 // OR this in honor of Hawaii's official State Fish function celciusToKelvin(humuHumuNukuNukuApuaA) { kelvin = humuHumuNukuNukuApuaA + 273.15; } celciusToKelvin(100); // kelvin = 373.15 ``` The computer doesn't care how we define our parameters when we declare and define our function. These variations are essentially the same as the original. What is important is that we give the parameters, variable names that makes sense; because as you can see, it is how we access the data that is passed into the function for use internally by the function. What people tend to mess up most is that they see an example with a parameter defined a certain way. Then they think that parameter name is something special like a keyword. You might call it `celcius`, I might call it `c`. Strange people might name it after a fish. A common example that messes people up: Finally, you can pass data in as arguments by reference of course. ```javascript var myApartmentTemp = 20; var someTemp = myApartmentTemp; var x = someTemp; celciusToKelvin(x); // kelvin = 293.15 ``` ### Return as function OUTPUT > Get data back, where the function was called. Sometimes functions have OUTPUTS. What people confuse is output in terms of data vs. output in terms of behaviors. For example: ```javascript= function hello() { document.write("Hello"); } ``` Many people have the misconception that the output here is `"Hello"`. This may make sense from a user perspective, it is not what we mean by output from a programming perspective. For example, using the above code if I did something like the following: ```javascript=+ var message = hello() + " World!"; // "undefined World!" ``` `message` would _not_ be set to `"Hello World"`. Our `hello` function never had any data output. It probably sent data to the screen and printed "Hello" on the page somewhere. But it didn't have a functional data output. The key point here is when we talk about functions and output, we are really talking about using the keyword `return`. > Return data back to where the function was called. For example: ```javascript= var first = "Jean Luc"; var last = "Picard"; function makeFullName(first, last) { return last + ", " + first; }; var username = makeFullName(first, last); // Picard, Jean Luc ``` `makeFullName` formats the name and returns a string "Picard, Jean Luc" to where it was originally called. That is, the right side of `=` operator. `username` is set to this value. Or another: ```javascript= function hello() { return "Hello"; } var message = hello() + " World!"; // "Hello World!" ``` Our function `hello` _returns_ data back to where it was called. The way to think about the above example, line 5 is like this. ``` Right side looks like: hello() + " World!" Evaluate the right side: Evaluate the function call, hello() returns a string "Hello" Right side now looks like: "Hello" + " World!" Continue evaluating right side: Concatenate "Hello" + " World!" Right side now looks like: "Hello World!" Assign the variable message to "Hello World!" ``` Take a look at this example: ```javascript= function halfLife(materialVolume) { return materialVolume / 2; } var volume = 100; halfLife(halfLife(halfLife(volume))); // 12.5 ``` Since the function `halfLife` will always return a number, we can call it and use the return output number as the argument for the next call. On line 7, we do this 3 times to get 12.5. As a rule of thumb, if you want your function to have an output, so that you can use that output to construct more sophisticated statements, use the keyword `return` and be aware of what kind of data you are returning. ## HTML and Javascript There are a few key concepts that I want you to understand for this Tinker, with regard to how HTML and Javascript relate. The point of Javascript, is to "connect" with HTML. That is, we basically use Javascript to manipulate our things on our HTML page. As we have learned: - HTML is a language that represents the structure and organization of a web-based, browser readable `document`. - It consists of things like `elements` and `text` nodes that are structured in a parent-child hierarchy. - These things have `attributes` and `values` that further shape how these things are represented. ```htmlmixed= <!-- Within larger HTML Document --> <div id="kittens" class="cute meow"> <img src="images/meowth.jpg" /> <img src="images/purrrr.jpg" /> <p> I really like <span>fluffy</span> kittens. </p> </div> <!-- Pattern of HTML Nodes --> <element attrA="valueA" attrB="valueB"> <element attrC="valueC"/> <element attrD="valueD"/> <element> Text Node <element>text</element> text. </element> </element> ``` Javascript can **_read/access_** the page by `selecting` elements: ```javascript= var kittenDiv = document.querySelector('#kittens'); // An element: div#kittens var imageElements = document.querySelectorAll('img'); // List of elements: [imgA, imgB] ``` Javascript can **_read/access_** `properties` of elements: ```javascript= document.querySelector('#kittens').id; // "kittens" document.querySelectorAll('img')[0].src; // "images/meowth.jpg" document.querySelectorAll('img')[1].src; // "images/purrrr.jpg" ``` Javascript can **_read/access_** other useful properties of elements: ```javascript= // I'm use "el" as shorthand for "element", a common convention. var el = document.querySelector('p'); var myText = el.textContent; // "I really like fluffy kittens." var myHTML = el.innerHTML; // "I really like <span>fluffy</span> kittens." ``` Javascript can **_traverse_** the document structure: ```javascript= var imgOne = document.querySelectorAll('img')[0]; // <img src="images/meowth.jpg" /> var imgTwo = imgEl.nextElementSibling; // <img src="images/purrrr.jpg" /> var spanEl = document.querySelector('span'); // <span>fluffy</span> var pEl = spanEl.parentElement; // <p>I really like <span>fluffy</span> kittens.</p> ``` Javascript can **_manipulate_** elements: ```javascript= var imgOne = document.querySelectorAll('img')[0].src; // "images/meowth.jpg" imgOne.src = "images/nyancat.jpg"; // "images/nyancat.jpg" var kittenEl = document.querySelector('#kittens'); var kittenClasses = kittenEl.className; // "cute meow" var kittenClassList = kittenEl.classList; // ["cute", "meow"] kittenClassList.add("hungry"); // ["cute", "meow", "hungry"] kittenClassList.remove("cute"); // ["meow", "hungry"] kittenClasses = "dogWasHere"; // className "dogWasHere", classList ["dogWasHere"] ``` And when you do these things, your page will dynamically change. ### Javascript Events Javascript, also makes it possible to react to user actions. Common actions are things like: - Clicking the mouse - Pressing a key - Scrolling a mouse wheel - Pinching on mobile - Value changes on forms These things are called **_events_** and there is pattern to how you go about hooking up your JS to these things. That pattern is you need to: - **_Listen_** for a specific event - **_Trigger_** an event (often by the user actions) - **_Handle_** what to do when the event is triggered There are a few ways to get your page to listen for events but the one we're using for now is to use HTML markup to tell the page what to listen to. ```htmlmixed= <div onclick=""></div> <textarea onkeypress=""></textarea> <input onchange=""/> ``` This `on` `event`, rather `onevent` pattern works for many different kinds of events. What we are doing here is setting a _listener_ for that particular event on that particular element. `div` will do something when it is _clicked_. `textarea` will do something when _key is pressed_. `input` will do something when the `value` changes. Thus, the `event` part of it is _triggered_ by the user actions. Finally, what then happens? We need to _handle_ these events. That is, when an _event_ occurs, we need to tell it what function to call. That function is referred to as a _handler_ function. In the above example, you'll notice that the values are all empty. This is where we will tell HTML what the handler should be. Declare the `printGreeting` function. ```javascript= function printGreeting() { // sub-routine to print greeting } ``` Attach handler to event. Call `printGreeting()` handler function when click event is triggered. ```htmlmixed= <div onclick="printGreeting()"></div> ``` This `onclick` attribute and `printGreeting()` value - an event handler call, is the connection between your HTML and JS. It's worth noting here that when events happen, you might want to know something about the event in your handler function. For example, what kind of event was triggered? What key was pressed? What element was it that triggered the event? (You can have multiple elements share the same handler function). To deal with this, you can design your handler function to accept a parameter that represents the event data. If you do this, when you call the handler you would pass in an argument representing the event data. For example: Declare the `printGreeting` function with a parameter to accept event data. ```javascript= // "e" is an arbitrary name representing the event data function printGreeting(e) { e.target; // element that the event handler was attached to e.type; // "click" e.target.innerHTML = "<strong>Hello World!</strong>"; } ``` Attach handler to event. Call `printGreeting(event)` handler function with `event` data passed into function when click event is triggered. ```htmlmixed= <!-- Call printGreeting and pass in event argument --> <!-- Here you must use the exact word: event --> <div onclick="printGreeting(event)"></div> ``` I want you to study this _pattern_ and recognize where I've used this throughout this Tinker exercise. You should take the process concept: `listen`, `trigger`, `handle` and map it to your understanding of HTML and JS functions. If you can understand this pattern, you'll be able to apply it to all these interesting categories of events [Events](https://developer.mozilla.org/en-US/docs/Web/API/Event). Some of the ones you might find interesting are: - https://developer.mozilla.org/en-US/docs/Web/API/KeyboardEvent - https://developer.mozilla.org/en-US/docs/Web/API/InputEvent - https://developer.mozilla.org/en-US/docs/Web/API/MouseEvent Take a look at some of the `properties` available to you through the event argument. For example, `event.type` (I used `e.type` in the example above) is a generic property of all [Events](https://developer.mozilla.org/en-US/docs/Web/API/Event). But if you go into [MouseEvents](https://developer.mozilla.org/en-US/docs/Web/API/MouseEvent) you'll find that there are special properties for mouse events like the click coordinates X and Y. Browse through it and finding linkages between the docs and the examples provided in this exercise.

    Import from clipboard

    Paste your markdown or webpage here...

    Advanced permission required

    Your current role can only read. Ask the system administrator to acquire write and comment permission.

    This team is disabled

    Sorry, this team is disabled. You can't edit this note.

    This note is locked

    Sorry, only owner can edit this note.

    Reach the limit

    Sorry, you've reached the max length this note can be.
    Please reduce the content or divide it to more notes, thank you!

    Import from Gist

    Import from Snippet

    or

    Export to Snippet

    Are you sure?

    Do you really want to delete this note?
    All users will lose their connection.

    Create a note from template

    Create a note from template

    Oops...
    This template has been removed or transferred.
    Upgrade
    All
    • All
    • Team
    No template.

    Create a template

    Upgrade

    Delete template

    Do you really want to delete this template?
    Turn this template into a regular note and keep its content, versions, and comments.

    This page need refresh

    You have an incompatible client version.
    Refresh to update.
    New version available!
    See releases notes here
    Refresh to enjoy new features.
    Your user state has changed.
    Refresh to load new user state.

    Sign in

    Forgot password

    or

    By clicking below, you agree to our terms of service.

    Sign in via Facebook Sign in via Twitter Sign in via GitHub Sign in via Dropbox Sign in with Wallet
    Wallet ( )
    Connect another wallet

    New to HackMD? Sign up

    Help

    • English
    • 中文
    • Français
    • Deutsch
    • 日本語
    • Español
    • Català
    • Ελληνικά
    • Português
    • italiano
    • Türkçe
    • Русский
    • Nederlands
    • hrvatski jezik
    • język polski
    • Українська
    • हिन्दी
    • svenska
    • Esperanto
    • dansk

    Documents

    Help & Tutorial

    How to use Book mode

    Slide Example

    API Docs

    Edit in VSCode

    Install browser extension

    Contacts

    Feedback

    Discord

    Send us email

    Resources

    Releases

    Pricing

    Blog

    Policy

    Terms

    Privacy

    Cheatsheet

    Syntax Example Reference
    # Header Header 基本排版
    - Unordered List
    • Unordered List
    1. Ordered List
    1. Ordered List
    - [ ] Todo List
    • Todo List
    > Blockquote
    Blockquote
    **Bold font** Bold font
    *Italics font* Italics font
    ~~Strikethrough~~ Strikethrough
    19^th^ 19th
    H~2~O H2O
    ++Inserted text++ Inserted text
    ==Marked text== Marked text
    [link text](https:// "title") Link
    ![image alt](https:// "title") Image
    `Code` Code 在筆記中貼入程式碼
    ```javascript
    var i = 0;
    ```
    var i = 0;
    :smile: :smile: Emoji list
    {%youtube youtube_id %} Externals
    $L^aT_eX$ LaTeX
    :::info
    This is a alert area.
    :::

    This is a alert area.

    Versions and GitHub Sync
    Get Full History Access

    • Edit version name
    • Delete

    revision author avatar     named on  

    More Less

    Note content is identical to the latest version.
    Compare
      Choose a version
      No search result
      Version not found
    Sign in to link this note to GitHub
    Learn more
    This note is not linked with GitHub
     

    Feedback

    Submission failed, please try again

    Thanks for your support.

    On a scale of 0-10, how likely is it that you would recommend HackMD to your friends, family or business associates?

    Please give us some advice and help us improve HackMD.

     

    Thanks for your feedback

    Remove version name

    Do you want to remove this version name and description?

    Transfer ownership

    Transfer to
      Warning: is a public team. If you transfer note to this team, everyone on the web can find and read this note.

        Link with GitHub

        Please authorize HackMD on GitHub
        • Please sign in to GitHub and install the HackMD app on your GitHub repo.
        • HackMD links with GitHub through a GitHub App. You can choose which repo to install our App.
        Learn more  Sign in to GitHub

        Push the note to GitHub Push to GitHub Pull a file from GitHub

          Authorize again
         

        Choose which file to push to

        Select repo
        Refresh Authorize more repos
        Select branch
        Select file
        Select branch
        Choose version(s) to push
        • Save a new version and push
        • Choose from existing versions
        Include title and tags
        Available push count

        Pull from GitHub

         
        File from GitHub
        File from HackMD

        GitHub Link Settings

        File linked

        Linked by
        File path
        Last synced branch
        Available push count

        Danger Zone

        Unlink
        You will no longer receive notification when GitHub file changes after unlink.

        Syncing

        Push failed

        Push successfully