| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105 |
- var textParser = require('../../../../src/parse/text')
- var config = require('../../../../src/config')
- var Vue = require('../../../../src/vue')
- var testCases = [
- {
- // no tags
- text: 'haha',
- expected: null
- },
- {
- // basic
- text: 'a {{ a }} c',
- expected: [
- { value: 'a ' },
- { tag: true, value: 'a', html: false, oneTime: false },
- { value: ' c' }
- ]
- },
- {
- // html
- text: '{{ text }} and {{{ html }}}',
- expected: [
- { tag: true, value: 'text', html: false, oneTime: false },
- { value: ' and ' },
- { tag: true, value: 'html', html: true, oneTime: false },
- ]
- },
- {
- // one time
- text: '{{* text }} and {{{* html }}}',
- expected: [
- { tag: true, value: 'text', html: false, oneTime: true },
- { value: ' and ' },
- { tag: true, value: 'html', html: true, oneTime: true },
- ]
- },
- {
- // partial
- text: '{{> hello }} and {{>hello}}',
- expected: [
- { tag: true, value: 'hello', html: false, oneTime: false, partial: true },
- { value: ' and ' },
- { tag: true, value: 'hello', html: false, oneTime: false, partial: true }
- ]
- }
- ]
- function assertParse (test) {
- var res = textParser.parse(test.text)
- var exp = test.expected
- if (!Array.isArray(exp)) {
- expect(res).toBe(exp)
- } else {
- expect(res.length).toBe(exp.length)
- res.forEach(function (r, i) {
- var e = exp[i]
- for (var key in e) {
- expect(e[key]).toEqual(r[key])
- }
- })
- }
- }
- describe('Text Parser', function () {
- it('parse', function () {
- testCases.forEach(assertParse)
- })
- it('cache', function () {
- var res1 = textParser.parse('{{a}}')
- var res2 = textParser.parse('{{a}}')
- expect(res1).toBe(res2)
- })
- it('custom delimiters', function () {
- config.delimiters = ['[%', '%]']
- assertParse({
- text: '[%* text %] and [[% html %]]',
- expected: [
- { tag: true, value: 'text', html: false, oneTime: true },
- { value: ' and ' },
- { tag: true, value: 'html', html: true, oneTime: false },
- ]
- })
- config.delimiters = ['{{', '}}']
- })
- it('tokens to expression', function () {
- var tokens = textParser.parse('view-{{test}}-test-{{ok}}')
- var exp = textParser.tokensToExp(tokens)
- expect(exp).toBe('"view-"+test+"-test-"+ok')
- })
- it('tokens to expression with oneTime tags & vm', function () {
- var vm = new Vue({
- data: { test: 'a', ok: 'b' }
- })
- var tokens = textParser.parse('view-{{*test}}-test-{{ok}}')
- var exp = textParser.tokensToExp(tokens, vm)
- expect(exp).toBe('"view-"+"a"+"-test-"+ok')
- })
- })
|