响应函数 handlers

(1) 响应函数
响应函数可以理解为视图函数,对应于一个访问请求。
可以是任何一个可调用的程序,但至少有一个request实例作为参数(有请求才会有响应),并返回一个HTTPResponse 实例或者一个执行其他操作的协同程序,说起来可能有些难以理解,实际上是区分了同步和异步的响应函数,同步响应函数直接返回Resonse实例,异步就要返回一个未来才能返回的函数。

响应函数就是对请求进行响应,一般这里就是承载业务处理逻辑的地方。

实际工作中,可能需要使用基于类的视图进行封装,之后会详细介绍。

#req.py
from sanic.response import text
from sanic import Sanic

app = Sanic("handlers")
@app.get("/")
async def foo_handler(request):
      string = " test"
      return text(string)

(2)  同步和异步

在sanic 架构中,使用同步函数是完全可行的。

@app.get("/sync")
def sync_handler(request):
    time.sleep(0.1)
    return text("done")

@app.get("/async")
async def async_handler(request):
    await asyncio.sleep(0.1)
    return text("done")

上面两个实现都可以运行,但通过测试工具测试表明,异步方式的性能要远大于同步方式。
(3) 响应函数支持注释
 

from sanic.response import HTTPResponse, text
from sanic.request import Request

@app.get("/typed")
async def typed_handler(request: Request) -> HTTPResponse:
    return text("Done.")


 

h5 window.webkit.messageHandlers是指在H5页面中使用webkit内核浏览器的window对象下的messageHandlers属性。该属性用于在H5页面和原生应用之间进行消息传递和通信。 在H5页面中,可以使用window.webkit.messageHandlers向原生应用发送消息,并接收原生应用的响应。通过这种方式,H5页面可以与原生应用进行交互,实现一些原生应用特有的功能或者获取原生应用的数据。 为了实现消息的传递和通信,需要在H5页面和原生应用中进行相应的配置和处理。在H5页面中,可以使用window.webkit.messageHandlers.messageName.postMessage(messageBody)来向原生应用发送消息,其中messageName是消息的名称,messageBody是要发送的消息内容。原生应用可以通过相应的方式,在收到消息后进行处理,并通过回调函数或者其他方式向H5页面发送响应。 使用window.webkit.messageHandlers可以实现H5和原生应用之间的双向通信,通过发送不同的消息和数据,可以实现各种功能需求。例如,可以通过发送消息来实现原生应用的登录认证、分享功能、调用原生摄像头拍照或者调用其他原生设备等操作。 总之,h5 window.webkit.messageHandlers是H5页面中与原生应用进行消息传递和通信的一种机制,通过这种机制可以实现H5页面与原生应用的交互和功能扩展。使用该机制时需要进行相应的配置和处理,以便实现正常的消息传递和通信。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值