主要是javascript中消除字符串空格,比较两种方式的不同
//面向对象,消除字符串两边空格
String.prototype.trim = function()
{
return this.replace(/(^\s*)|(\s*$)/g, "");
};
//去左右空格的函数;
function trim(s){
return s.replace(/(^\s*)|(\s*$)/g, "");
}
调用消除空格的两种方式。
var defualtPhone = defualtDeliveryArray[0].getElementsByTagName("td")[4].textContent.trim();
var defualtPhone = trim(defualtDeliveryArray[0].getElementsByTagName("td")[4].textContent);
就是' abcd '.tirm()和trim(' abcd ')的区别。
由于现在编程的都是智能编辑器,在使用面向对象的时候方法作为对象的一个属性,在对象的命名空间下,很容易自动补全弹出来。
面向对象把某些方法几种赋予给某一类的对象,无论在调用还是编辑器自动补全的时候优点太多了。
在python中,函数式编程和oop编程调用的区别是,假如有两种类型
对object1类型的东西,需要传给两个函数处理。;
def fun1a(object1,*args,**kwargs):
pass
def fun1b(object1,*args,**kwargs):
pass
对object2类型的东西,需要传给两个函数处理。;
def fun2a(object2,*args,**kwargs):
pass
def fun2b(object2,*args,**kwargs):
pass
调用的时候,使用 fun1a(object1,*args,**kwargs) fun1b(object1,*args,**kwargs) , fun2a(object2,*args,**kwargs) fun2b(object2,*args,**kwargs)
传函数的时候一定不要传错了,不能把object2类型的传给fun1a 和fun1b这两个函数处理,会出错。
面向对象的时候,调用方式是:
a = A(*args,**kwargs)
a.fun1()
a.fun2()
b = B(*args,**kwargs)
b.fun3()
b.fun4()
b.fun5()
从调用来看,方法越多,面向对象实例化后可以少传一些参数的次数。面向过程时候,如果fun4需要利用fun3的处理结果,还需要在fun3中各种return,同理还有fun6 fun7什么的,各种return不太好。为了保持多个函数处理同一个变量,还不得不使用一些global全局变量。
当使用面向对象时候,由于编辑器有智能补全功能,肯定不会出现b.fun1()这种乱调用的低级错误了,在获取结果的时候,可以使用object2.xxx的方式获得,不用到处去return和弄全局变量。
python里面的内置类型的方法,如果都改成由函数来处理,每个类型几十种方法,那我们需要记住几百种常见函数,记住什么函数能处理什么类型的对象,脑袋简直要爆炸了。但是调用方法就简单了,对象后面打个.号,就能自动显示出对象有哪些属性,有哪些方法,这些不用记得很清楚就行。python中只有一些很少的函数是各种对象通用的,比如字符串长度 列表长度 集合长度,统一传给len()函数就能得出结果了,也可以使用str1.__len__()和list1.__len()__这种方式得出长度结果。
oop的优点不仅是从代码组织上,更体现在调用上。那么多第三方库在调用时候能用的那么爽,那是三方库中用了大量oop,如果人家全用函数,在调用时候,体验会大幅下降不爽。
此篇仅从js和py中的函数/方法调用形式,来浅显说明oop的优点。
反对极端面向过程编程思维方式,喜欢面向对象和设计模式的解读,喜欢对比极端面向过程编程和oop编程消耗代码代码行数的区别和原因。致力于使用oop和36种设计模式写出最高可复用的框架级代码和使用最少的代码行数完成任务,致力于使用oop和设计模式来使部分代码减少90%行,使绝大部分py文件最低减少50%-80%行的写法。