首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Python 绑定方法与非绑定方法

(绑定给类的应该有类来调用, 但对象其实也可以使用, 只不过自动传入的仍然是类)   @staticmethod  ---------  加入到定义的非绑定方法函数上(但是无论谁来调用, 都没有任何自动传值的效果...绑定方法 特性: 绑定给谁就应该由谁来调用, 谁来调用就会将谁当作第一个参数自动传入> 绑定方法分为两类:   1....绑定给对象方法:     在类内部定义的函数(没有被任何装饰器修饰的), 默认就是绑定给对象用的   2.绑定给类的方法:     在类内部定义的函数如果被装饰器@classmethod装饰, 那么则是绑定给类的...非绑定方法 类中定义的函数如果被装饰器@staticmethod装饰, 那么该函数就变成非绑定方法 既不与类绑定, 又不与对象绑定, 意味着类与对象都可以来调用 但是无论谁来调用, 都没有任何自动传值的效果..., 就是一个普通函数 3.应用 如果函数体代码需要用外部传入的类, 则应该将该函数定义成绑定给类的方法 如果函数体代码需要用外部传入的对象, 则应该将该函数定义成绑定给对象的方法 如果函数体代码既不需要外部传入的类也不需要外部传入的对象

84220
您找到你想要的搜索结果了吗?
是的
没有找到

详解类方法绑定方法与非绑定方法

我们之前说过,我们一般用实例调用方法,既然我们说了是一般,那么就说明还有其他调用方法的方式,今天我们就来说一下「绑定方法和非绑定方法」。...绑定方法和非绑定方法 在 Python 中除了特殊方法以外,类中的其他普通方法也是经常用到的,所以对于普通的方法也要进行研究,下面我们来看一个例子: >>> class Sample: ......下面就要逐渐接近 “绑定方法” 和 “非绑定方法” 的概念本质了。...所以综上,我们可以认为:当通过类来获取方法的时候,得到的是非绑定方法对象;当通过实例来获取方法的时候,得到的是绑定方法对象。...写在之后 绑定方法和非绑定方法到这就结束了,类的方法可分为不少,除了绑定方法和非绑定方法以外,还有静态方法和类方法等,我会在接下来依次的进行介绍,敬请期待。

33120

强大的JS方法Object.defineProperty详解及VUE.JS双向绑定原理

Object.defineProperty是一个很了不起的方法。vue.js之所以能够实现双向绑定便是拜它所赐!...defineProperty直接翻译过来即是“定义属性”,不过该方法可不仅仅是定义属性这么简单,咱们还可以通过它来对属性进行拦截设置! 我们知道对象是由多个键/值对组成的无序集合。...var obj={};//或obj=new Object; // 添加属性(描述) obj.userName="laotie";//或 obj["userName"]="laotie" // 添加方法(...行为) obj.run=function(){};//或 obj["run"]=function(){}; 为对象增加属性的方法除了上面的方式外,咱们还可以通过Object.defineProperty...接下来,咱们可以通过defineProperty模拟下VUE.JS的双向绑定

1.1K20

JS 实现双向数据绑定

近几年前端技术栈真是发展的太迅速了,从以前的针对dom操作的框架如jquery,ext.js等框架逐步过渡到当前的mvvm模式,让前端开发者将注意力从dom操作逐渐解脱出来,专注于逻辑的实现,个人认为开发效率至少提升了...什么是数据的双向绑定? ?...双向数据绑定 上面说的是在vue框架中数据双向绑定的应用,个人认为这个特性很赞,是大幅提升开发效率的关键,那如果脱离mvvm的框架,我也想实现这种数据的双向绑定,可不可以实现了,该如何实现了?...用原生js模拟数据双向绑定 为了实现这个功能我们需要用到js的一个方法Object.defineProperty 1. 属性介绍 ? 属性介绍 2. 方法介绍 ?...方法介绍 大概的介绍了defineProperty核心的两个方法,看到这里,你就知道可以利用这两个内置方法搞事情了,看下面利用该方法实现数据双向绑定的一个例子 ?

2.5K10

JS原生数据绑定原理

用过vue的人都知道,vue有一个特别好用的数据绑定,只要绑定了,你只要改变了这个数据,页面也会跟着渲染。其实原生的JS也是可以做到的,vue其实就是用了原生的原理。...descriptor) obj:就是一个对象; prop:就是你要监听的obj里面的某个数据; descriptor:目标属性所拥有的特性; 这三个都是必须的,前两个都好理解,第三个,说简单点就是这个方法自带的几个特性...,数据绑定的主要方法。...只要调用obj.hello,就会触发get方法,这时候打印出来的obj.hello一直等于3,因为我们return的就是3,所以这边应该返回改变的值。...就像obj.hello = 999;那么页面的值就会是999;感兴趣的可以复制代码的方法,一个一个方法调用,就很容易明白原生JS的双向绑定

1.8K30

Python类的绑定方法和非绑定方法实例解析

一、绑定方法   1.对象的绑定方法   首先我们明确一个知识点,凡是类中的方法或函数,默认情况下都是绑定给对象使用的。下面,我们通过实例,来慢慢解析绑定方法的应用。...3.如果类想调用绑定方法,就必须遵循函数的参数规则,有几个参数,就必须传递几个参数。   聪明的你,可能会问,既然类中的方法都是绑定给对象使用的,那么有没有方法绑定给类使用的呢?   ...2.类的绑定方法    既然类中的方法,默认都是绑定给对象使用,那么,我们要采取一点措施,将类中的绑定方法解除对象绑定关系,进而绑定到类上。    ...在python中,引入了@classmethod方法,将类中的方法绑定到类身上。...二、非绑定方法   上面说了,类中的方法要么是绑定给对象使用,要么是绑定给类使用,那么有没有不绑定给两者使用的函数?

95510

Knockout.Js官网学习(event绑定、submit绑定

event绑定 event绑定在DOM元素上添加指定的事件句柄以便元素被触发的时候执行定义的JavaScript 函数。大部分情况下是用在keypress,mouseover和mouseout上。...Details <script type="text/javascript" src="~/Scripts/knockout-2.3.0.debug.<em>js</em>...submit<em>绑定</em>  submit<em>绑定</em>在form表单上添加指定的事件句柄以便该form被提交的时候执行定义的JavaScript 函数。只能用在表单form元素上。  ...当你使用submit<em>绑定</em>的时候, Knockout会阻止form表单默认的submit动作。换句话说,浏览器会执行你定义的<em>绑定</em>函数而不会提交这个form表单到服务器上。...总共有两个元素一个是录入框,另一个是submit提交按钮 在form上,你可以使用click<em>绑定</em>代替submit<em>绑定</em>。

2.6K10

Knockout.Js官网学习(html绑定、css绑定

Html绑定 html绑定到DOM元素上,使得该元素显示的HTML值为你绑定的参数。如果在你的view model里声明HTML标记并且render的话,那非常有用。...关于HTML encoding  因为该绑定设置元素的innerHTML,你应该注意不要使用不安全的HTML代码,因为有可能引起脚本注入攻击。...如果你不确信是否安全(比如显示用户输入的内容),那你应该使用text绑定,因为这个绑定只是设置元素的text 值innerText和textContent。...Css绑定  css绑定是添加或删除一个或多个CSS class到DOM元素上。 非常有用,比如当数字变成负数时高亮显示。...(注:如果你不想应用CSS class而是想引用style属性的话,请参考style绑定。)

2.4K30

Knockout.Js官网学习(selectedOptions绑定、uniqueName 绑定

selectedOptions绑定 selectedOptions绑定用于控制multi-select列表已经被选择的元素,用在使用options绑定的元素上。...这种方式是2-way绑定。 注:控制single-select下拉菜单选择项,你可以使用value绑定。...multiple="true"> <script type="text/javascript" src="~/Scripts/knockout-2.3.0.debug.<em>js</em>...如果参数是依赖监控属性observable数组,那元素的已选择项selected options项将根据参数值的变化(通过push,pop,或其它observable数组<em>方法</em>)而更新,如果不是,那元素的已选择项...uniqueName<em>绑定</em>  uniqueName<em>绑定</em>确保所<em>绑定</em>的元素有一个非空的name属性。如果该元素没有name属性,那<em>绑定</em>会给它设置一个unique的字符串值作为name属性。

2.1K10

js绑定事件代理的坑

js通过事件代理的方式绑定跳转事件,我这里的逻辑是把click事件绑定在最外层container上面,如果e.target包含我已经写好的class,则执行跳转逻辑。...但是这种方式好像只能是在点击的元素的上面,也就是最内层的元素上面有相应的class才能跳转,在外层加同样的class不生效,说明是我对于事件代理的理解不够深刻,其实事件代理的作用就是为了把目标元素的事件绑定在外层做代理...document.querySelector('#container').addEventListener('click', function (e) { console.log(e.currentTarget) //获得当前绑定监听事件的元素...) } },false) document.getElementById("container").classList.add('jumpUrl');//写在后面也可以绑定成功...注意:内层元素,即点击的目标元素必须是点击时真正的目标元素,而不是外面一层; currentTarget绑定相应想要点击的class的时候必须是做代理的即做事件监听的元素。

4.9K20
领券