1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798 |
- <template>
- <view>
- <!--判断是否是标签节点-->
- <block v-if="node.node == 'element'">
- <block v-if="node.tag == 'button'">
- <button type="default" size="mini">
- <block v-for="(node, index) of node.nodes" :key="index">
- <wx-parse-template :node="node" />
- </block>
- </button>
- </block>
- <!--li类型-->
- <block v-else-if="node.tag == 'li'">
- <view :class="node.classStr" :style="node.styleStr">
- <block v-for="(node, index) of node.nodes" :key="index">
- <wx-parse-template :node="node" />
- </block>
- </view>
- </block>
- <!--video类型-->
- <block v-else-if="node.tag == 'video'">
- <wx-parse-video :node="node" />
- </block>
- <!--audio类型-->
- <block v-else-if="node.tag == 'audio'">
- <wx-parse-audio :node="node" />
- </block>
- <!--img类型-->
- <block v-else-if="node.tag == 'img'">
- <wx-parse-img :node="node" />
- </block>
- <!--a类型-->
- <block v-else-if="node.tag == 'a'">
- <view @click="wxParseATap" :class="node.classStr" :data-href="node.attr.href" :style="node.styleStr">
- <block v-for="(node, index) of node.nodes" :key="index">
- <wx-parse-template :node="node" />
- </block>
- </view>
- </block>
- <!--br类型-->
- <block v-else-if="node.tag == 'br'">
- <text>\n</text>
- </block>
- <!--其他标签-->
- <block v-else>
- <view :class="node.classStr" :style="node.styleStr">
- <block v-for="(node, index) of node.nodes" :key="index">
- <wx-parse-template :node="node" />
- </block>
- </view>
- </block>
- </block>
- <!--判断是否是文本节点-->
- <block v-else-if="node.node == 'text'">{{node.text}}</block>
- </view>
- </template>
- <script>
- import wxParseTemplate from './wxParseTemplate3';
- import wxParseImg from './wxParseImg';
- import wxParseVideo from './wxParseVideo';
- import wxParseAudio from './wxParseAudio';
- export default {
- name: 'wxParseTemplate2',
- props: {
- node: {},
- },
- components: {
- wxParseTemplate,
- wxParseImg,
- wxParseVideo,
- wxParseAudio,
- },
- methods: {
- wxParseATap(e) {
- const {
- href
- } = e.currentTarget.dataset;
- if (!href) return;
- let parent = this.$parent;
- while(!parent.preview || typeof parent.preview !== 'function') {
- parent = parent.$parent;
- }
- parent.navigate(href, e);
- },
- },
- };
- </script>
|