【Python】使用混合类(Mixin)多重继承反直觉的一面与正确的使用方式

原标题:Mixins and Python
原文链接 🔗

counter intuitive; Mixin; 多重继承

Overview



Python 支持一种简单类型的多重继承,它允许创建 Mixins。
Mixins 是一种类,用于将额外的属性和方法“混合(mix in)”到一个类中。
这允许您以组合风格创建类。

Mixins 是一个非常棒的概念,但我经常发现人们错误地使用它们会导致一些错误。
我经常看到像下面这样使用 Mixin:

class Mixin1(object):
    def test(self):
        print "Mixin1"

class Mixin2(object):
    def test(self):
        print "Mixin2"

class MyClass(BaseClass, Mixin1, Mixin2):
    pass

但是,在 Python 中,类层次结构是从右到左定义的,因此在这种情况下 Mixin2 类是基类,由 Mixin1 扩展,最后由 BaseClass 扩展。

这通常很好,因为很多时候 mixin 类不会覆盖彼此或基类的方法。

但是如果你在你的 mixin 中重写了方法或属性,这可能会导致意想不到的结果,因为方法的解析优先级是从左到右。

>>> obj = MyClass()
>>> obj.test()
Mixin1

使用 mixin 的正确方法是相反的顺序:

class MyClass(Mixin2, Mixin1, BaseClass):
    pass

这种类型起初看起来有悖常理(counter intuitive),因为大多数人会从左到右读取自上而下的类层次结构
但是如果你以程序运行的思维考虑这个正在定义的类,则可以正确读取类层次结构(MyClass => Mixin2 => Mixin1 => BaseClass。
如果你以这种方式定义你的类,你将不会有很多冲突,也不会遇到太多错误。

>>> obj = MyClass()
>>> obj.test()
Mixin2

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在 Sass 中,可以使用 mixin 来实现的复用。Mixin 是一种将一组 CSS 规则集合封装为一个函数,并在需要的地方调用的方式。具体步骤如下: 1. 定义 mixin 在 Sass 中,可以使用 @mixin 关键字来定义一个 mixin,例如: ```scss @mixin button($bg-color, $text-color) { background-color: $bg-color; color: $text-color; border: none; border-radius: 4px; padding: 8px 16px; cursor: pointer; } ``` 在上面的例子中,定义了一个名为 button 的 mixin,它接受两个参数:$bg-color 和 $text-color。在 mixin 中定义了一组 CSS 规则,用于设置按钮的样式。 2. 调用 mixin 在 Sass 中,可以使用 @include 关键字来调用 mixin,例如: ```scss .primary-button { @include button(#007aff, #fff); } ``` 在上面的例子中,使用 @include 关键字来调用 button mixin,并传入两个参数:#007aff 和 #fff。这样,.primary-button 就会继承 button mixin 中定义的 CSS 规则。 需要注意的是,mixin 可以带有参数,也可以不带参数。如果 mixin 不带参数,那么调用时就不需要传递任何参数。另外,mixin 还可以接受默认参数值,例如: ```scss @mixin button($bg-color: #007aff, $text-color: #fff) { background-color: $bg-color; color: $text-color; border: none; border-radius: 4px; padding: 8px 16px; cursor: pointer; } ``` 在上面的例子中,定义了一个名为 button 的 mixin,并为 $bg-color 和 $text-color 参数设置了默认值。如果在调用时不传递参数,那么 mixin 就会使用默认值来设置样式。 使用 mixin 可以提高代码的复用性和可维护性,减少代码的冗余,同时也可以使样式更加清晰、简洁。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值