• 关于

    挂钩子是什么

    的搜索结果

回答

钩子函数、注册函数、回调函数,他们的概念其实是一样的。 钩子函数,顾名思义,就是把我们自己实现的hook函数在某一时刻挂接到目标挂载点上。 hook函数,就是我们自己实现的函数,函数类型与挂载点匹配(返回值,参数列表) 挂接,也就是hook或者叫注册(register),使得hook函数对目标可用 目标挂载点,也就是挂我们hook函数的地方(我们想在这个目标点实现我们自己的功能) 先看一张图: hook hook的概念在windows的消息响应机制里面体现的尤为明显。可能我们大家有写过windows桌面相关的程序(像MFC),里面有各种消息监听响应机制。比如,要监听鼠标左键是否按下这个事件,我们要去实现一个onLeftKeyDown()之类的方法,该方法可以称为钩子函数。同时,我们还要去注册钩子函数,MFC中是通过一组宏来实现的。这样当鼠标左键按下后,就能调到我们定义的方法了。 ** 为什么需要钩子 ** 大家思考一下上面这个例子,左键按下方法具体的逻辑是由框架自身去实现,还是由我们用户(调用者)去实现呢?显然应该由我们自己去实现。要提供通用的框架能力,框架自身去实现该方法功能,是没有意义的,所以框架给提供一个挂载的point,把具体逻辑的实现交给用户就好了,灵活可用。 ** 钩子使用 ** hook是一个编程机制,与语言无关。这里给个python的简单例子,帮助大家理解: import time class LazyPerson(object): def __init__(self, name): self.name = name self.watch_tv_func = None self.have_dinner_func = None def get_up(self): print("%s get up at:%s" % (self.name, time.time())) def go_to_sleep(self): print("%s go to sleep at:%s" % (self.name, time.time())) def register_tv_hook(self, watch_tv_func): self.watch_tv_func = watch_tv_func def register_dinner_hook(self, have_dinner_func): self.have_dinner_func = have_dinner_func def enjoy_a_lazy_day(self): # get up self.get_up() time.sleep(3) # watch tv # check the watch_tv_func(hooked or unhooked) # hooked if self.watch_tv_func is not None: self.watch_tv_func(self.name) # unhooked else: print("no tv to watch") time.sleep(3) # have dinner # check the have_dinner_func(hooked or unhooked) # hooked if self.have_dinner_func is not None: self.have_dinner_func(self.name) # unhooked else: print("nothing to eat at dinner") time.sleep(3) self.go_to_sleep() def watch_daydayup(name): print("%s : The program ---day day up--- is funny!!!" % name) def watch_happyfamily(name): print("%s : The program ---happy family--- is boring!!!" % name) def eat_meat(name): print("%s : The meat is nice!!!" % name) def eat_hamburger(name): print("%s : The hamburger is not so bad!!!" % name) if name == "__main__": lazy_tom = LazyPerson("Tom") lazy_jerry = LazyPerson("Jerry") # register hook lazy_tom.register_tv_hook(watch_daydayup) lazy_tom.register_dinner_hook(eat_meat) lazy_jerry.register_tv_hook(watch_happyfamily) lazy_jerry.register_dinner_hook(eat_hamburger) # enjoy a day lazy_tom.enjoy_a_lazy_day() lazy_jerry.enjoy_a_lazy_day() 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071代码运行结果: Tom get up at:1509246940.32Tom : The program ---day day up--- is funny!!!Tom : The meat is nice!!!Tom go to sleep at:1509246949.34Jerry get up at:1509246949.34Jerry : The program ---happy family--- is boring!!!Jerry : The hamburger is not so bad!!!Jerry go to sleep at:1509246958.37
xuning715 2019-12-02 01:10:23 0 浏览量 回答数 0

回答

为什么css选择器钩子大多数用class?这个问题可仅从css的方面出发来回答:1、相对于class选择器,id选择器的权重实在太重了(100),这在一些项目中会造成灾难性的样式污染,以及权重陷阱。2、id在文档内必须是唯一的,而样式很多具有复用性。当然,使用id也意味着你的css选择器完全不需要嵌套:body #a{color:red} // 不必要的写法,除了额外增加选择器权重没有任何必要。a{color:red} // 这样即可至于为什么大多数js使用id作为钩子,主要因为js通过id查询dom的速度是最快的。id是不是一定会和js挂钩,这个是未必的,以下情况可能必须使用class:循环插入若干组件,不同组件内绑定dom相同Function时。
杨冬芳 2019-12-02 02:31:50 0 浏览量 回答数 0

回答

为什么css选择器钩子大多数用class?这个问题可仅从css的方面出发来回答:1、相对于class选择器,id选择器的权重实在太重了(100),这在一些项目中会造成灾难性的样式污染,以及权重陷阱。 2、id在文档内必须是唯一的,而样式很多具有复用性。当然,使用id也意味着你的css选择器完全不需要嵌套: body #a{color:red} // 不必要的写法,除了额外增加选择器权重没有任何必要。 #a{color:red} // 这样即可至于为什么大多数js使用id作为钩子,主要因为js通过id查询dom的速度是最快的。id是不是一定会和js挂钩,这个是未必的,以下情况可能必须使用class:循环插入若干组件,不同组件内绑定dom相同Function时。
a123456678 2019-12-02 02:24:40 0 浏览量 回答数 0

云产品推荐

上海奇点人才服务相关的云产品 小程序定制 上海微企信息技术相关的云产品 国内短信套餐包 ECS云服务器安全配置相关的云产品 开发者问答 阿里云建站 自然场景识别相关的云产品 万网 小程序开发制作 视频内容分析 视频集锦 代理记账服务