全局禁用vuetify组件上的涟漪效应

9avjhtql  于 2023-11-21  发布在  Vue.js
关注(0)|答案(7)|浏览(203)

我在我的应用程序上使用vuetify。设计团队创建了一个平面设计,我想改变vuetify的主题,以匹配模型
我试图找到一个选项来禁用涟漪效应很容易在整个应用程序,但它不存在。
我尝试创建一个组件扩展,以避免在我使用的每个组件上重复:ripple="false"
我将以按钮组件为例。

  1. <v-btn :ripple="false">My Button</v-btn>

字符串
我的应用程序上的每个按钮都需要有ripple=false我的目标是创建这样的组件

  1. <my-button>My Button</my-button>


我尝试在另一个类似这样的组件中扩展v-btn

  1. <template>
  2. <v-btn v-bind="options" :ripple="false"></v-btn>
  3. </template>
  4. <script>
  5. import { VBtn } from 'vuetify';
  6. export default {
  7. name: 'MyButton',
  8. extend: VBtn,
  9. computed: {
  10. options() {
  11. return this.props;
  12. },
  13. },
  14. };
  15. </script>
  16. <style scoped>


我尝试这种方式来避免复制/粘贴v-btn的所有 prop 。
我尝试过的所有解决方案都失败了。

bfhwhh0e

bfhwhh0e1#

您可以在注册后全局修改Vue.js组件。
在这种情况下,您可以简单地这样做:

  1. const VBtn = Vue.component('VBtn')
  2. VBtn.options.props.ripple.default = false

字符串
例如,您可以将其添加到vuetify.js文件中的export default new Vuetify (...)之前。

  • 使用Vuetify 2.1.14进行测试
dgtucam1

dgtucam12#

您可以将完整容器设置为不可见。

  1. .v-ripple__container {
  2. display:none !important;
  3. }

字符串

n6lpvg4x

n6lpvg4x3#

根据Vuetify文档,您可以修改Stylus变量-因此您可以尝试根据自己的喜好重新定义这些变量,例如将其设置为none

  1. $ripple-animation-transition-in := transform .25s $transition.fast-out-slow-in, opacity .1s $transition.fast-out-slow-in
  2. $ripple-animation-transition-out := opacity .3s $transition.fast-out-slow-in
  3. $ripple-animation-visible-opacity := .15

字符串

gk7wooem

gk7wooem4#

在main.js中使用全局mixin的涟漪指令

  1. let overrideRipple = {
  2. directives:{
  3. ripple:{
  4. inserted: ()=> {
  5. console.log("Ripple overrided")
  6. }
  7. }
  8. }
  9. }
  10. Vue.mixin(overrideRipple);

字符串

mdfafbf1

mdfafbf15#

添加一个类到按钮并使用CSS..

  1. <v-btn class="custom-btn">Button</v-btn>
  2. .custom-btn:deep(.v-btn__overlay) {
  3. display: none;
  4. }
  5. .custom-btn:deep(.v-btn__underlay) {
  6. display: none;
  7. }
  8. .custom-btn:deep(.v-ripple__container) {
  9. display: none;
  10. }

字符串

4c8rllxm

4c8rllxm6#

在Vuetify 3.3.22上,prop默认值接受组件键引用,以根据组件层次结构应用样式更改。更多信息请参阅文档
范例:

  1. import { createVuetify } from 'vuetify'
  2. import { VBtn } from 'vuetify/components/VBtn'
  3. export default createVuetify({
  4. defaults: {
  5. VBtn: {
  6. ripple: false,
  7. },
  8. },
  9. })

字符串

uurv41yg

uurv41yg7#

随着Vuetify 2.0的发布,你实际上可以通过修改你的vuetify.js文件来全局关闭ripple。

  1. export default new Vuetify({
  2. global: {
  3. ripples: false
  4. },
  5. icons: {
  6. iconfont: 'mdi',
  7. },
  8. });

字符串

相关问题