# VueJS Tips
1. VueJS component contains 3 parts: - template: html view - script: logics - style: css styling (scoped: meaning style only works for this component)
2. data()
: contains all the data (eg API returns) for the component
3. methods
: a place to write all customized functions
4. Vue LifeCycle methods:
beforeCreate()
: before template get readycreated()
: able to getdata()
attributes value for this componentbeforeMount()
: runs beforeinitial render
aftertemplate
orrender functions
have been compiledmounted()
: component finishrendered
[proves that component has finished load process (we can shw some data aftermounted
)]beforeUpdate()
: get running afterdata changed
and beforeDOM re-rendered
updated()
: trigger DOM re-renderbeforeDestroy()
: reset some values before componentvanished
destroyed()
:destroyed
component
beforeCreate && created -> initialization beforeMount && mounted -> render beforeUpdate && updated -> re-render beforeDestroy && destroyed -> teardown
5. common directives:
v-once
: only the first time variable setup value get rendered, eg: you set variableX
value atdata()
function as 1, andmounted()
setX
to 2, so now, only 1 get rendered !!v-html
: render html pieces of code which is set insidedata()
functionv-for
: loop array of elements, eg below:
<li v-bind:key="greeting.content" v-for="(greeting, index) in greetings">
{{ index + 1 }} - {{ greeting.content }}
</li>
v-on:click
: trigger clicks event, define method insidemethods
object [another syntax sugar:@click
]v-bind:value
: bind the value withdata()
function value [another syntax sugar::value
]@input="handleChange($event)"
: 2 way data binding, example below:
<input type="text" :value="textString" @input="handleChange($event)" />
or simpler solution: using `v-model`:
<input type="text" v-model="textString" />
@keyup.enter
: try to trigger event when we clickEnter
key on keyboard
6. Command vue ui
is so cool, which allows developer to create a project visually and also able to run build
process and so easily
check with the code performance !!!!!!!!!!
7. computed
vs methods
:
- computed:
- when we need to
filter
ortransform
the data, we consider to use computed property - computed values are
cached
for avoiding repetitive calculations (very important) - in html, no need parentheses
()
- when we need to
- method:
- just like
normal
js method, - normally
don't
usearrow
function, because not able to readthis
value - in html,
needs
parentheses()
- just like
*** Difference example: addToA() and addToB() methods put inside methods
and computed
, which results are different (see here)
8. watch
: used for handling expensive operations
like frequently data change
-> ask user input and make an API request call and get its response [Example - here]
here is the difference between
computed
andwatch
.computed: create a
new
property & dore-calculation
if anydependent properties
get updated,cannot
pass any argumentswatch: does
NOT
create new property, watch changes only forone
specific property and has argumentsnew
andold
9. Vue Reactivity concept: simple word, when we change a element data value, the page will reflect the changes and get value updated as latest value !!!! This video is like must
watch!!
10. $emit
: trigger an event and also allows to pass data from child to parent level, example:
// child component
// method:
onClickButton() {
this.$emit('clicked', 'aloha');
}
// trigger:
<div><button @click="onClickButton">pass child data to parent component</button></div>
// parent component
// method:
onClickChild(value) {
console.log('value from child pass to parent: ', value);
this.childText = value;
}
// trigger:
<Child @clicked="onClickChild($event)" />
<p>Text from child: {{ childText }}</p>
11. event bus: allow to pass data between components, example: Reference lazy today ~~~
12. mixins
: is similar concept with sass mixin functions, basically just make code DRY!!! Example:
// create a mixin function (extract same function block code out to an independent file)
export default {
computed: {
... ...
}
}
// Then, call mixin from each component:
import mixinFunction from './relative/path/from/codebase';
export default {
data() {
...
},
methods: ...,
mixins: [mixinFunction]
}
// now your code no longer repeated!!
13. dynamic component
: change component view based on condition, 2 key words:
- component: is the
<component :is="condition ? componentName : anotherComponent"></component>
- keep-alive: make sure previous component contents still there, like fulfilled form, contents kept !!!
Example:
<keep-alive>
<component :is="currentComponent"></component>
</keep-alive>
<v-btn @click="currentComponent = 'AppDynamicComponentTwo'">
Switch To AppDynamicComponentTwo
</v-btn>
<v-btn @click="currentComponent = 'AppDynamicComponentOne'">
Switch To AppDynamicComponentOne
</v-btn>
14.
Please send to me by email to correct me here if it's wrong