| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885 |
- import Vue from 'vue'
- import { hasSymbol } from 'core/util/env'
- describe('Directive v-for', () => {
- it('should render array of primitive values', (done) => {
- const vm = new Vue({
- template: `
- <div>
- <span v-for="item in list">{{item}}</span>
- </div>
- `,
- data: {
- list: ['a', 'b', 'c']
- }
- }).$mount()
- expect(vm.$el.innerHTML).toBe('<span>a</span><span>b</span><span>c</span>')
- Vue.set(vm.list, 0, 'd')
- waitForUpdate(() => {
- expect(vm.$el.innerHTML).toBe(
- '<span>d</span><span>b</span><span>c</span>'
- )
- vm.list.push('d')
- })
- .then(() => {
- expect(vm.$el.innerHTML).toBe(
- '<span>d</span><span>b</span><span>c</span><span>d</span>'
- )
- vm.list.splice(1, 2)
- })
- .then(() => {
- expect(vm.$el.innerHTML).toBe('<span>d</span><span>d</span>')
- vm.list = ['x', 'y']
- })
- .then(() => {
- expect(vm.$el.innerHTML).toBe('<span>x</span><span>y</span>')
- })
- .then(done)
- })
- it('should render array of primitive values with index', (done) => {
- const vm = new Vue({
- template: `
- <div>
- <span v-for="(item, i) in list">{{i}}-{{item}}</span>
- </div>
- `,
- data: {
- list: ['a', 'b', 'c']
- }
- }).$mount()
- expect(vm.$el.innerHTML).toBe(
- '<span>0-a</span><span>1-b</span><span>2-c</span>'
- )
- Vue.set(vm.list, 0, 'd')
- waitForUpdate(() => {
- expect(vm.$el.innerHTML).toBe(
- '<span>0-d</span><span>1-b</span><span>2-c</span>'
- )
- vm.list.push('d')
- })
- .then(() => {
- expect(vm.$el.innerHTML).toBe(
- '<span>0-d</span><span>1-b</span><span>2-c</span><span>3-d</span>'
- )
- vm.list.splice(1, 2)
- })
- .then(() => {
- expect(vm.$el.innerHTML).toBe('<span>0-d</span><span>1-d</span>')
- vm.list = ['x', 'y']
- })
- .then(() => {
- expect(vm.$el.innerHTML).toBe('<span>0-x</span><span>1-y</span>')
- })
- .then(done)
- })
- it('should render array of object values', (done) => {
- const vm = new Vue({
- template: `
- <div>
- <span v-for="item in list">{{item.value}}</span>
- </div>
- `,
- data: {
- list: [{ value: 'a' }, { value: 'b' }, { value: 'c' }]
- }
- }).$mount()
- expect(vm.$el.innerHTML).toBe('<span>a</span><span>b</span><span>c</span>')
- Vue.set(vm.list, 0, { value: 'd' })
- waitForUpdate(() => {
- expect(vm.$el.innerHTML).toBe(
- '<span>d</span><span>b</span><span>c</span>'
- )
- vm.list[0].value = 'e'
- })
- .then(() => {
- expect(vm.$el.innerHTML).toBe(
- '<span>e</span><span>b</span><span>c</span>'
- )
- vm.list.push({})
- })
- .then(() => {
- expect(vm.$el.innerHTML).toBe(
- '<span>e</span><span>b</span><span>c</span><span></span>'
- )
- vm.list.splice(1, 2)
- })
- .then(() => {
- expect(vm.$el.innerHTML).toBe('<span>e</span><span></span>')
- vm.list = [{ value: 'x' }, { value: 'y' }]
- })
- .then(() => {
- expect(vm.$el.innerHTML).toBe('<span>x</span><span>y</span>')
- })
- .then(done)
- })
- it('should render array of object values with index', (done) => {
- const vm = new Vue({
- template: `
- <div>
- <span v-for="(item, i) in list">{{i}}-{{item.value}}</span>
- </div>
- `,
- data: {
- list: [{ value: 'a' }, { value: 'b' }, { value: 'c' }]
- }
- }).$mount()
- expect(vm.$el.innerHTML).toBe(
- '<span>0-a</span><span>1-b</span><span>2-c</span>'
- )
- Vue.set(vm.list, 0, { value: 'd' })
- waitForUpdate(() => {
- expect(vm.$el.innerHTML).toBe(
- '<span>0-d</span><span>1-b</span><span>2-c</span>'
- )
- vm.list[0].value = 'e'
- })
- .then(() => {
- expect(vm.$el.innerHTML).toBe(
- '<span>0-e</span><span>1-b</span><span>2-c</span>'
- )
- vm.list.push({})
- })
- .then(() => {
- expect(vm.$el.innerHTML).toBe(
- '<span>0-e</span><span>1-b</span><span>2-c</span><span>3-</span>'
- )
- vm.list.splice(1, 2)
- })
- .then(() => {
- expect(vm.$el.innerHTML).toBe('<span>0-e</span><span>1-</span>')
- vm.list = [{ value: 'x' }, { value: 'y' }]
- })
- .then(() => {
- expect(vm.$el.innerHTML).toBe('<span>0-x</span><span>1-y</span>')
- })
- .then(done)
- })
- if (hasSymbol) {
- it('should render native iterables (Map)', () => {
- const vm = new Vue({
- template: `<div><span v-for="[key, val] in list">{{key}},{{val}}</span></div>`,
- data: {
- list: new Map([
- [1, 'foo'],
- [2, 'bar']
- ])
- }
- }).$mount()
- expect(vm.$el.innerHTML).toBe(`<span>1,foo</span><span>2,bar</span>`)
- })
- it('should render native iterables (Set)', () => {
- const vm = new Vue({
- template: `<div><span v-for="val in list">{{val}}</span></div>`,
- data: {
- list: new Set([1, 2, 3])
- }
- }).$mount()
- expect(vm.$el.innerHTML).toBe(
- `<span>1</span><span>2</span><span>3</span>`
- )
- })
- it('should render iterable of primitive values', (done) => {
- const iterable = {
- models: ['a', 'b', 'c'],
- index: 0,
- [Symbol.iterator]() {
- const iterator = {
- index: 0,
- models: this.models,
- next() {
- if (this.index < this.models.length) {
- return { value: this.models[this.index++] }
- } else {
- return { done: true }
- }
- }
- }
- return iterator
- }
- }
- const vm = new Vue({
- template: `
- <div>
- <span v-for="item in list">{{item}}</span>
- </div>
- `,
- data: {
- list: iterable
- }
- }).$mount()
- expect(vm.$el.innerHTML).toBe(
- '<span>a</span><span>b</span><span>c</span>'
- )
- Vue.set(vm.list.models, 0, 'd')
- waitForUpdate(() => {
- expect(vm.$el.innerHTML).toBe(
- '<span>d</span><span>b</span><span>c</span>'
- )
- vm.list.models.push('d')
- })
- .then(() => {
- expect(vm.$el.innerHTML).toBe(
- '<span>d</span><span>b</span><span>c</span><span>d</span>'
- )
- vm.list.models.splice(1, 2)
- })
- .then(() => {
- expect(vm.$el.innerHTML).toBe('<span>d</span><span>d</span>')
- vm.list.models = ['x', 'y']
- })
- .then(() => {
- expect(vm.$el.innerHTML).toBe('<span>x</span><span>y</span>')
- })
- .then(done)
- })
- it('should render iterable of primitive values with index', (done) => {
- const iterable = {
- models: ['a', 'b', 'c'],
- index: 0,
- [Symbol.iterator]() {
- const iterator = {
- index: 0,
- models: this.models,
- next() {
- if (this.index < this.models.length) {
- return { value: this.models[this.index++] }
- } else {
- return { done: true }
- }
- }
- }
- return iterator
- }
- }
- const vm = new Vue({
- template: `
- <div>
- <span v-for="(item, i) in list">{{i}}-{{item}}</span>
- </div>
- `,
- data: {
- list: iterable
- }
- }).$mount()
- expect(vm.$el.innerHTML).toBe(
- '<span>0-a</span><span>1-b</span><span>2-c</span>'
- )
- Vue.set(vm.list.models, 0, 'd')
- waitForUpdate(() => {
- expect(vm.$el.innerHTML).toBe(
- '<span>0-d</span><span>1-b</span><span>2-c</span>'
- )
- vm.list.models.push('d')
- })
- .then(() => {
- expect(vm.$el.innerHTML).toBe(
- '<span>0-d</span><span>1-b</span><span>2-c</span><span>3-d</span>'
- )
- vm.list.models.splice(1, 2)
- })
- .then(() => {
- expect(vm.$el.innerHTML).toBe('<span>0-d</span><span>1-d</span>')
- vm.list.models = ['x', 'y']
- })
- .then(() => {
- expect(vm.$el.innerHTML).toBe('<span>0-x</span><span>1-y</span>')
- })
- .then(done)
- })
- it('should render iterable of object values', (done) => {
- const iterable = {
- models: [{ value: 'a' }, { value: 'b' }, { value: 'c' }],
- index: 0,
- [Symbol.iterator]() {
- const iterator = {
- index: 0,
- models: this.models,
- next() {
- if (this.index < this.models.length) {
- return { value: this.models[this.index++] }
- } else {
- return { done: true }
- }
- }
- }
- return iterator
- }
- }
- const vm = new Vue({
- template: `
- <div>
- <span v-for="item in list">{{item.value}}</span>
- </div>
- `,
- data: {
- list: iterable
- }
- }).$mount()
- expect(vm.$el.innerHTML).toBe(
- '<span>a</span><span>b</span><span>c</span>'
- )
- Vue.set(vm.list.models, 0, { value: 'd' })
- waitForUpdate(() => {
- expect(vm.$el.innerHTML).toBe(
- '<span>d</span><span>b</span><span>c</span>'
- )
- vm.list.models[0].value = 'e'
- })
- .then(() => {
- expect(vm.$el.innerHTML).toBe(
- '<span>e</span><span>b</span><span>c</span>'
- )
- vm.list.models.push({})
- })
- .then(() => {
- expect(vm.$el.innerHTML).toBe(
- '<span>e</span><span>b</span><span>c</span><span></span>'
- )
- vm.list.models.splice(1, 2)
- })
- .then(() => {
- expect(vm.$el.innerHTML).toBe('<span>e</span><span></span>')
- vm.list.models = [{ value: 'x' }, { value: 'y' }]
- })
- .then(() => {
- expect(vm.$el.innerHTML).toBe('<span>x</span><span>y</span>')
- })
- .then(done)
- })
- it('should render iterable of object values with index', (done) => {
- const iterable = {
- models: [{ value: 'a' }, { value: 'b' }, { value: 'c' }],
- index: 0,
- [Symbol.iterator]() {
- const iterator = {
- index: 0,
- models: this.models,
- next() {
- if (this.index < this.models.length) {
- return { value: this.models[this.index++] }
- } else {
- return { done: true }
- }
- }
- }
- return iterator
- }
- }
- const vm = new Vue({
- template: `
- <div>
- <span v-for="(item, i) in list">{{i}}-{{item.value}}</span>
- </div>
- `,
- data: {
- list: iterable
- }
- }).$mount()
- expect(vm.$el.innerHTML).toBe(
- '<span>0-a</span><span>1-b</span><span>2-c</span>'
- )
- Vue.set(vm.list.models, 0, { value: 'd' })
- waitForUpdate(() => {
- expect(vm.$el.innerHTML).toBe(
- '<span>0-d</span><span>1-b</span><span>2-c</span>'
- )
- vm.list.models[0].value = 'e'
- })
- .then(() => {
- expect(vm.$el.innerHTML).toBe(
- '<span>0-e</span><span>1-b</span><span>2-c</span>'
- )
- vm.list.models.push({})
- })
- .then(() => {
- expect(vm.$el.innerHTML).toBe(
- '<span>0-e</span><span>1-b</span><span>2-c</span><span>3-</span>'
- )
- vm.list.models.splice(1, 2)
- })
- .then(() => {
- expect(vm.$el.innerHTML).toBe('<span>0-e</span><span>1-</span>')
- vm.list.models = [{ value: 'x' }, { value: 'y' }]
- })
- .then(() => {
- expect(vm.$el.innerHTML).toBe('<span>0-x</span><span>1-y</span>')
- })
- .then(done)
- })
- }
- it('should render an Object', (done) => {
- const vm = new Vue({
- template: `
- <div>
- <span v-for="val in obj">{{val}}</span>
- </div>
- `,
- data: {
- obj: { a: 0, b: 1, c: 2 }
- }
- }).$mount()
- expect(vm.$el.innerHTML).toBe('<span>0</span><span>1</span><span>2</span>')
- vm.obj.a = 3
- waitForUpdate(() => {
- expect(vm.$el.innerHTML).toBe(
- '<span>3</span><span>1</span><span>2</span>'
- )
- Vue.set(vm.obj, 'd', 4)
- })
- .then(() => {
- expect(vm.$el.innerHTML).toBe(
- '<span>3</span><span>1</span><span>2</span><span>4</span>'
- )
- Vue.delete(vm.obj, 'a')
- })
- .then(() => {
- expect(vm.$el.innerHTML).toBe(
- '<span>1</span><span>2</span><span>4</span>'
- )
- })
- .then(done)
- })
- it('should render an Object with key', (done) => {
- const vm = new Vue({
- template: `
- <div>
- <span v-for="(val, key) in obj">{{val}}-{{key}}</span>
- </div>
- `,
- data: {
- obj: { a: 0, b: 1, c: 2 }
- }
- }).$mount()
- expect(vm.$el.innerHTML).toBe(
- '<span>0-a</span><span>1-b</span><span>2-c</span>'
- )
- vm.obj.a = 3
- waitForUpdate(() => {
- expect(vm.$el.innerHTML).toBe(
- '<span>3-a</span><span>1-b</span><span>2-c</span>'
- )
- Vue.set(vm.obj, 'd', 4)
- })
- .then(() => {
- expect(vm.$el.innerHTML).toBe(
- '<span>3-a</span><span>1-b</span><span>2-c</span><span>4-d</span>'
- )
- Vue.delete(vm.obj, 'a')
- })
- .then(() => {
- expect(vm.$el.innerHTML).toBe(
- '<span>1-b</span><span>2-c</span><span>4-d</span>'
- )
- })
- .then(done)
- })
- it('should render an Object with key and index', (done) => {
- const vm = new Vue({
- template: `
- <div>
- <span v-for="(val, key, i) in obj">{{val}}-{{key}}-{{i}}</span>
- </div>
- `,
- data: {
- obj: { a: 0, b: 1, c: 2 }
- }
- }).$mount()
- expect(vm.$el.innerHTML).toBe(
- '<span>0-a-0</span><span>1-b-1</span><span>2-c-2</span>'
- )
- vm.obj.a = 3
- waitForUpdate(() => {
- expect(vm.$el.innerHTML).toBe(
- '<span>3-a-0</span><span>1-b-1</span><span>2-c-2</span>'
- )
- Vue.set(vm.obj, 'd', 4)
- })
- .then(() => {
- expect(vm.$el.innerHTML).toBe(
- '<span>3-a-0</span><span>1-b-1</span><span>2-c-2</span><span>4-d-3</span>'
- )
- Vue.delete(vm.obj, 'a')
- })
- .then(() => {
- expect(vm.$el.innerHTML).toBe(
- '<span>1-b-0</span><span>2-c-1</span><span>4-d-2</span>'
- )
- })
- .then(done)
- })
- it('should render each key of data', (done) => {
- const vm = new Vue({
- template: `
- <div>
- <span v-for="(val, key) in $data">{{val}}-{{key}}</span>
- </div>
- `,
- data: { a: 0, b: 1, c: 2 }
- }).$mount()
- expect(vm.$el.innerHTML).toBe(
- '<span>0-a</span><span>1-b</span><span>2-c</span>'
- )
- vm.a = 3
- waitForUpdate(() => {
- expect(vm.$el.innerHTML).toBe(
- '<span>3-a</span><span>1-b</span><span>2-c</span>'
- )
- }).then(done)
- })
- it('check priorities: v-if before v-for', function () {
- const vm = new Vue({
- data: {
- items: [1, 2, 3]
- },
- template:
- '<div><div v-if="item < 3" v-for="item in items">{{item}}</div></div>'
- }).$mount()
- expect(vm.$el.textContent).toBe('12')
- })
- it('check priorities: v-if after v-for', function () {
- const vm = new Vue({
- data: {
- items: [1, 2, 3]
- },
- template:
- '<div><div v-for="item in items" v-if="item < 3">{{item}}</div></div>'
- }).$mount()
- expect(vm.$el.textContent).toBe('12')
- })
- it('range v-for', () => {
- const vm = new Vue({
- template: '<div><div v-for="n in 3">{{n}}</div></div>'
- }).$mount()
- expect(vm.$el.textContent).toBe('123')
- })
- it('without key', (done) => {
- const vm = new Vue({
- data: {
- items: [
- { id: 1, msg: 'a' },
- { id: 2, msg: 'b' },
- { id: 3, msg: 'c' }
- ]
- },
- template: '<div><div v-for="item in items">{{ item.msg }}</div></div>'
- }).$mount()
- expect(vm.$el.textContent).toBe('abc')
- const first = vm.$el.children[0]
- vm.items.reverse()
- waitForUpdate(() => {
- expect(vm.$el.textContent).toBe('cba')
- // assert reusing DOM element in place
- expect(vm.$el.children[0]).toBe(first)
- }).then(done)
- })
- it('with key', (done) => {
- const vm = new Vue({
- data: {
- items: [
- { id: 1, msg: 'a' },
- { id: 2, msg: 'b' },
- { id: 3, msg: 'c' }
- ]
- },
- template:
- '<div><div v-for="item in items" :key="item.id">{{ item.msg }}</div></div>'
- }).$mount()
- expect(vm.$el.textContent).toBe('abc')
- const first = vm.$el.children[0]
- vm.items.reverse()
- waitForUpdate(() => {
- expect(vm.$el.textContent).toBe('cba')
- // assert moving DOM element
- expect(vm.$el.children[0]).not.toBe(first)
- expect(vm.$el.children[2]).toBe(first)
- }).then(done)
- })
- it('nested loops', () => {
- const vm = new Vue({
- data: {
- items: [
- { items: [{ a: 1 }, { a: 2 }], a: 1 },
- { items: [{ a: 3 }, { a: 4 }], a: 2 }
- ]
- },
- template:
- '<div>' +
- '<div v-for="(item, i) in items">' +
- '<p v-for="(subItem, j) in item.items">{{j}} {{subItem.a}} {{i}} {{item.a}}</p>' +
- '</div>' +
- '</div>'
- }).$mount()
- expect(vm.$el.innerHTML).toBe(
- '<div><p>0 1 0 1</p><p>1 2 0 1</p></div>' +
- '<div><p>0 3 1 2</p><p>1 4 1 2</p></div>'
- )
- })
- it('template v-for', (done) => {
- const vm = new Vue({
- data: {
- list: [{ a: 1 }, { a: 2 }, { a: 3 }]
- },
- template:
- '<div>' +
- '<template v-for="item in list">' +
- '<p>{{item.a}}</p>' +
- '<p>{{item.a + 1}}</p>' +
- '</template>' +
- '</div>'
- }).$mount()
- assertMarkup()
- vm.list.reverse()
- waitForUpdate(() => {
- assertMarkup()
- vm.list.splice(1, 1)
- })
- .then(() => {
- assertMarkup()
- vm.list.splice(1, 0, { a: 2 })
- })
- .then(done)
- function assertMarkup() {
- const markup = vm.list
- .map(function (item) {
- return '<p>' + item.a + '</p><p>' + (item.a + 1) + '</p>'
- })
- .join('')
- expect(vm.$el.innerHTML).toBe(markup)
- }
- })
- it('component v-for', (done) => {
- const vm = new Vue({
- data: {
- list: [{ a: 1 }, { a: 2 }, { a: 3 }]
- },
- template:
- '<div>' +
- '<test v-for="item in list" :msg="item.a" :key="item.a">' +
- '<span>{{item.a}}</span>' +
- '</test>' +
- '</div>',
- components: {
- test: {
- props: ['msg'],
- template: '<p>{{msg}}<slot></slot></p>'
- }
- }
- }).$mount()
- assertMarkup()
- vm.list.reverse()
- waitForUpdate(() => {
- assertMarkup()
- vm.list.splice(1, 1)
- })
- .then(() => {
- assertMarkup()
- vm.list.splice(1, 0, { a: 2 })
- })
- .then(done)
- function assertMarkup() {
- const markup = vm.list
- .map(function (item) {
- return `<p>${item.a}<span>${item.a}</span></p>`
- })
- .join('')
- expect(vm.$el.innerHTML).toBe(markup)
- }
- })
- it('dynamic component v-for', (done) => {
- const vm = new Vue({
- data: {
- list: [{ type: 'one' }, { type: 'two' }]
- },
- template:
- '<div>' +
- '<component v-for="item in list" :key="item.type" :is="item.type"></component>' +
- '</div>',
- components: {
- one: {
- template: '<p>One!</p>'
- },
- two: {
- template: '<div>Two!</div>'
- }
- }
- }).$mount()
- expect(vm.$el.innerHTML).toContain('<p>One!</p><div>Two!</div>')
- vm.list.reverse()
- waitForUpdate(() => {
- expect(vm.$el.innerHTML).toContain('<div>Two!</div><p>One!</p>')
- }).then(done)
- })
- it('should warn component v-for without keys', () => {
- new Vue({
- template: `<div><test v-for="i in 3"></test></div>`,
- components: {
- test: {
- render() {}
- }
- }
- }).$mount()
- expect(
- `<test v-for="i in 3">: component lists rendered with v-for should have explicit keys`
- ).toHaveBeenTipped()
- })
- it('multi nested array reactivity', (done) => {
- const vm = new Vue({
- data: {
- list: [[['foo']]]
- },
- template: `
- <div>
- <div v-for="i in list">
- <div v-for="j in i">
- <div v-for="k in j">
- {{ k }}
- </div>
- </div>
- </div>
- </div>
- `
- }).$mount()
- expect(vm.$el.textContent).toMatch(/\s+foo\s+/)
- vm.list[0][0].push('bar')
- waitForUpdate(() => {
- expect(vm.$el.textContent).toMatch(/\s+foo\s+bar\s+/)
- }).then(done)
- })
- it('should work with strings', (done) => {
- const vm = new Vue({
- data: {
- text: 'foo'
- },
- template: `
- <div>
- <span v-for="letter in text">{{ letter }}.</span>
- </div>
- `
- }).$mount()
- expect(vm.$el.textContent).toMatch('f.o.o.')
- vm.text += 'bar'
- waitForUpdate(() => {
- expect(vm.$el.textContent).toMatch('f.o.o.b.a.r.')
- }).then(done)
- })
- // #7792
- it('should work with multiline expressions', () => {
- const vm = new Vue({
- data: {
- a: [1],
- b: [2]
- },
- template: `
- <div>
- <span v-for="n in (
- a.concat(
- b
- )
- )">{{ n }}</span>
- </div>
- `
- }).$mount()
- expect(vm.$el.textContent).toBe('12')
- })
- // #9181
- it('components with v-for and empty list', (done) => {
- const vm = new Vue({
- template:
- '<div attr>' +
- '<foo v-for="item in list" :key="item">{{ item }}</foo>' +
- '</div>',
- data: {
- list: undefined
- },
- components: {
- foo: {
- template: '<div><slot></slot></div>'
- }
- }
- }).$mount()
- expect(vm.$el.innerHTML).toBe('')
- vm.list = [1, 2, 3]
- waitForUpdate(() => {
- expect(vm.$el.innerHTML).toBe('<div>1</div><div>2</div><div>3</div>')
- }).then(done)
- })
- it('elements with v-for and empty list', (done) => {
- const vm = new Vue({
- template:
- '<div attr>' + '<div v-for="item in list">{{ item }}</div>' + '</div>',
- data: {
- list: undefined
- }
- }).$mount()
- expect(vm.$el.innerHTML).toBe('')
- vm.list = [1, 2, 3]
- waitForUpdate(() => {
- expect(vm.$el.innerHTML).toBe('<div>1</div><div>2</div><div>3</div>')
- }).then(done)
- })
- const supportsDestructuring = (() => {
- try {
- new Function('var { foo } = bar')
- return true
- } catch (e) {}
- })()
- if (supportsDestructuring) {
- it('should support destructuring syntax in alias position (object)', () => {
- const vm = new Vue({
- data: { list: [{ foo: 'hi', bar: 'ho' }] },
- template:
- '<div><div v-for="({ foo, bar }, i) in list">{{ foo }} {{ bar }} {{ i }}</div></div>'
- }).$mount()
- expect(vm.$el.textContent).toBe('hi ho 0')
- })
- it('should support destructuring syntax in alias position (array)', () => {
- const vm = new Vue({
- data: {
- list: [
- [1, 2],
- [3, 4]
- ]
- },
- template:
- '<div><div v-for="([ foo, bar ], i) in list">{{ foo }} {{ bar }} {{ i }}</div></div>'
- }).$mount()
- expect(vm.$el.textContent).toBe('1 2 03 4 1')
- })
- }
- })
|