1
1
mirror of https://github.com/namibia/awesome-cheatsheets.git synced 2024-12-18 16:41:58 +00:00

Vue: options > dom

This commit is contained in:
Julien Le Coupanec 2017-11-29 00:41:46 +01:00
parent 6c98441553
commit 909378aa3e

View File

@ -105,7 +105,7 @@ Vue.compile(template) // Compiles a template string into a render function
* ******************************************************************************************* */ * ******************************************************************************************* */
Vue.component('my-component', { new Vue({
// A list/hash of attributes that are exposed to accept data from the parent component. // A list/hash of attributes that are exposed to accept data from the parent component.
// It has an Array-based simple syntax and an alternative Object-based syntax that allows // It has an Array-based simple syntax and an alternative Object-based syntax that allows
// advanced configurations such as type checking, custom validation and default values. // advanced configurations such as type checking, custom validation and default values.
@ -196,7 +196,57 @@ Vue.component('my-component', {
* ******************************************************************************************* */ * ******************************************************************************************* */
new Vue({
// Provide the Vue instance an existing DOM element to mount on.
// It can be a CSS selector string or an actual HTMLElement.
// After the instance is mounted, the resolved element will be accessible as vm.$el.
el: '#example',
// A string template to be used as the markup for the Vue instance.
// The template will replace the mounted element.
// Any existing markup inside the mounted element will be ignored,
// unless content distribution slots are present in the template.
// If the string starts with # it will be used as a querySelector and
// use the selected elements innerHTML as the template string. This
// allows the use of the common <script type="x-template"> trick to include templates.
template: `
<div class="checkbox-wrapper" @click="check">
<div :class="{ checkbox: true, checked: checked }"></div>
<div class="title">{{ title }}</div>
</div>
`,
// An alternative to string templates allowing you to leverage the full programmatic power of JavaScript.
// The render function receives a createElement method as its first argument used to create VNodes.
// If the component is a functional component, the render function also receives an extra argument context,
// which provides access to contextual data since functional components are instance-less.
render: function (createElement) {
// create kebabCase id
var headingId = getChildrenTextContent(this.$slots.default)
.toLowerCase()
.replace(/\W+/g, '-')
.replace(/(^\-|\-$)/g, '')
return createElement(
'h' + this.level,
[
createElement('a', {
attrs: {
name: headingId,
href: '#' + headingId
}
}, this.$slots.default)
]
)
},
// Provide an alternative render output when the default render function encounters an error.
// The error will be passed to renderError as the second argument.
// This is particularly useful when used together with hot-reload.
renderError (createElement, err) {
return createElement('pre', { style: { color: 'red' }}, err.stack)
}
})
/* ******************************************************************************************* /* *******************************************************************************************
@ -252,6 +302,7 @@ Vue.component('my-component', {
/* ******************************************************************************************* /* *******************************************************************************************
* INSTANCE METHODS > EVENTS * INSTANCE METHODS > EVENTS
* https://vuejs.org/v2/api/#Instance-Methods-Events * https://vuejs.org/v2/api/#Instance-Methods-Events
@ -311,4 +362,3 @@ Vue.component('my-component', {
* ******************************************************************************************* */ * ******************************************************************************************* */