const { ID, V_FOR, SET_DATA, isVar, getForEl, processForKey, updateForEleId, traverseNode } = require('./util') const { isComponent } = require('../util') const { parseIf, parseFor, parseText, parseDirs, parseAttrs, parseProps, parseBinding } = require('./parser/base-parser') const parseEvent = require('./parser/event-parser') const parseBlock = require('./parser/block-parser') const basePreTransformNode = require('./pre-transform-node') const optimize = require('./optimizer') function createGenVar (id) { return function genVar (name, value) { return `${SET_DATA}(${id},'${name}',${value})` } } function parseKey (el) { // add default key if (processForKey(el)) { el = el.children[0] // 当 template 下仅文本时,处理第一个动态文本 } if (!el.key || el.key.indexOf(SET_DATA) === 0) { return } const forEl = getForEl(el) if (!forEl) { isVar(el.key) && (el.key = createGenVar(el.attrsMap[ID])('a-key', el.key)) } if (!isVar(forEl.for)) { return } const forId = forEl.forId const it = forEl.iterator2 const genVar = createGenVar(forId) if (forEl === el) { // el.key = genVar(V_FOR, `{forIndex:${it},key:${el.key}}`) } else { // const keyIndex = forEl.children.indexOf(el) el.key = genVar(V_FOR, `{forIndex:${it},keyIndex:${keyIndex},key:${el.key}}`) } } function transformNode (el, parent, state) { if (el.type === 3) { return } parseBlock(el) parseEvent(el) updateForEleId(el, state) if (el.type === 2) { return parseText(el, parent, { index: 0, service: true, // {{content}} genVar: createGenVar(parent.attrsMap[ID]) }) } const genVar = createGenVar(el.attrsMap[ID]) parseFor(el, createGenVar) parseKey(el) parseIf(el, createGenVar) parseBinding(el, genVar) parseDirs(el, genVar) if (!isComponent(el.tag)) { parseAttrs(el, genVar) } parseProps(el, genVar) } function postTransformNode (el, options) { if (!el.parent) { // 从根节点开始递归处理 traverseNode(el, false, { forIteratorId: 0, transformNode }) optimize(el, options) } } function parseTag (el) { if (el.tag === 'input' || el.tag === 'textarea') { el.tag = `c-${el.tag.substr(0, 1)}` // 返回一个自定义组件标签,保证 v-model } } function genData (el) { delete el.$parentIterator3 if (el.model) { el.model.callback = `function ($$v) {}` } return '' } module.exports = { preTransformNode: function (el, options) { parseTag(el) return basePreTransformNode(el, options) }, postTransformNode, genData }