1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071 |
- <template>
- <view :class="utils.bem('tabbar-item', { active }) + ' custom-class'" :style="'color: ' + (active ? activeColor : inactiveColor)" @tap="onClick">
- <view class="van-tabbar-item__icon">
- <van-icon v-if="icon" :name="icon" custom-class="van-tabbar-item__icon__inner" />
- <block v-else>
- <slot v-if="active" name="icon-active" />
- <slot v-else name="icon" />
- </block>
- <van-info :dot="dot" :info="info" custom-class="van-tabbar-item__info" />
- </view>
- <view class="van-tabbar-item__text">
- <slot />
- </view>
- </view>
- </template>
- <script module="utils" lang="wxs" src="@/node_modules/@vant/weapp/lib/wxs/utils.wxs"></script>
- <script>
- 'use strict';
- Object.defineProperty(exports, '__esModule', {
- value: true
- });
- var component_1 = require('../common/component');
- component_1.VantComponent({
- props: {
- info: null,
- name: null,
- icon: String,
- dot: Boolean
- },
- relation: {
- name: 'tabbar',
- type: 'ancestor',
- current: 'tabbar-item'
- },
- data: {
- active: false
- },
- methods: {
- onClick: function () {
- if (this.parent) {
- this.parent.onChange(this);
- }
- this.$emit('click');
- },
- updateFromParent: function () {
- var parent = this.parent;
- if (!parent) {
- return;
- }
- var index = parent.children.indexOf(this);
- var parentData = parent.data;
- var data = this;
- var active = (data.name || index) === parentData.active;
- var patch = {};
- if (active !== data.active) {
- patch.active = active;
- }
- if (parentData.activeColor !== data.activeColor) {
- patch.activeColor = parentData.activeColor;
- }
- if (parentData.inactiveColor !== data.inactiveColor) {
- patch.inactiveColor = parentData.inactiveColor;
- }
- return Object.keys(patch).length > 0 ? this.set(patch) : Promise.resolve();
- }
- }
- });
- </script>
- <style>
- @import './index.css';
- </style>
|