93 lines
3.0 KiB
Markdown
93 lines
3.0 KiB
Markdown
# Local Variables
|
|
|
|
How to define and use local variables. #docs #var #language #variables
|
|
|
|
### @parent language
|
|
|
|
A variable is a place where you can store and retrieve data. Variables have a name, a [type](/microbit/blocks/types), and value:
|
|
|
|
* *name* is how you'll refer to the variable
|
|
* *type* refers to the kind of data a variable can store
|
|
* *value* refers to what's stored in the variable
|
|
|
|
### Var statement
|
|
|
|
Use the Block Editor variable statement to create a local variable and the [assignment operator](/microbit/reference/variables/assign) to store something in the variable.
|
|
|
|
For example, this code stores the number `2` in the `num1` variable:
|
|
|
|
data:image/s3,"s3://crabby-images/0843f/0843f9fd0487e220d43467eac7e329b56775fcd6" alt=""
|
|
|
|
Here's how to define a variable in the Block Editor:
|
|
|
|
1. Click `variables`.
|
|
|
|
2. Change the default variable name if you like.
|
|
|
|
3. Drag a block type on the right-side of the [assignment operator](/microbit/reference/variables/assign) and click the down arrow to change the variable name.
|
|
|
|
The resulting code should look something like this:
|
|
|
|
// string variable
|
|
|
|
data:image/s3,"s3://crabby-images/191ba/191ba2537a8c492cf493a5ffa559627ebdb38da1" alt=""
|
|
|
|
// number variable
|
|
|
|
data:image/s3,"s3://crabby-images/69aeb/69aeb933a5b6b3784dd747e51a8643110934bdf7" alt=""
|
|
|
|
// boolean variable
|
|
|
|
data:image/s3,"s3://crabby-images/720f0/720f086602ffb6f6b4d01c11ecc0822e55ec6d68" alt=""
|
|
|
|
// image variable
|
|
|
|
data:image/s3,"s3://crabby-images/aa3e7/aa3e7bf6478791b957bff8fbbf06335aae83a38e" alt=""
|
|
|
|
See [Image](/microbit/blocks/image) for info on creating and using image variables.
|
|
|
|
The resulting code should look something like this:
|
|
|
|
data:image/s3,"s3://crabby-images/c3c71/c3c7139a9e92059abe0156da59abb97ea0fe1f39" alt=""
|
|
|
|
A variable is created for the number returned by the [brightness](/microbit/reference/led/brightness) function.
|
|
|
|
### Using variables
|
|
|
|
Once you've defined a variable, just use the variable's name whenever you need what's stored in the variable. For example, the following code shows the value stored in `counter` on the LED screen:
|
|
|
|
data:image/s3,"s3://crabby-images/0f5ea/0f5ea981245a10420fb91a321f07f1dc3ecc9ccf" alt=""
|
|
|
|
To change the contents of a variable use the assignment operator. The following code sets `counter` to 1 and then increments `counter` by 10:
|
|
|
|
data:image/s3,"s3://crabby-images/23a67/23a67f238860a25425b649a6c982391d4579582b" alt=""
|
|
|
|
### Why use variables?
|
|
|
|
Variables help simplify your code. For example, instead of turning on LEDs one by one like this:
|
|
|
|
data:image/s3,"s3://crabby-images/ee9fa/ee9fab04be8610e285942a78faf13ab506893d8c" alt=""
|
|
|
|
You can use a variable (`i`) and a [for loop](/microbit/reference/loops/for) to plot the same series of points (`i` is incremented by 1, each time the loop repeats):
|
|
|
|
data:image/s3,"s3://crabby-images/ff388/ff388bef4128b241bd87d8e5135ac52d989b4678" alt=""
|
|
|
|
### Local variables
|
|
|
|
Local variables exist only within the function or block of code where they're defined. For example:
|
|
|
|
data:image/s3,"s3://crabby-images/17f90/17f907e3ca004baeda97d9844d34eac537711abf" alt=""
|
|
|
|
#### Notes
|
|
|
|
* You can use the default variable names if you'd like, however, it's best to use descriptive variable names. To change a variable name in the editor, select the down arrow next to the variable and then click "new variable".
|
|
|
|
### Lessons
|
|
|
|
[glowing pendulum](/microbit/lessons/glowing-pendulum), [love meter](/microbit/lessons/love-meter), [temperature](/microbit/lessons/temperature), [zoomer](/microbit/lessons/zoomer)
|
|
|
|
### See also
|
|
|
|
[types](/microbit/blocks/types), [assignment operator](/microbit/reference/variables/assign)
|
|
|