在 clojurescript 中实现 ajax 调用
Posted
技术标签:
【中文标题】在 clojurescript 中实现 ajax 调用【英文标题】:Implementing an ajax call in clojurescript 【发布时间】:2012-01-23 04:40:07 【问题描述】:我是 clojurescript 的新手,想通过纯粹在 clojurescript 中实现以前编写的应用程序来进行更深入的研究,但在实现 ajax 调用方面不知所措。谁能给我指一个在线示例或提供一两个代码 sn-p 吗?
【问题讨论】:
【参考方案1】:2016 年 1 月 22 日更新
虽然它仍然有效,但最初的答案是在普遍缺乏具有超过 1 个贡献者的 ClojureScript 解决方案的时候。与其直接利用 XhrIo,不如考虑使用维护良好、功能丰富的解决方案,而不是像 cljs-ajax 那样包装它,如下面的 Mikhail D 建议的那样!
好的,鉴于 Clojurescript 利用了 Google 的 Closure javascript 库,快速搜索 Closure 文档发现 xhrIo 作为生成 AJAX 调用的正确方法:
Example using Closure's Asynchronous XMLHttpRequests with XhrIo
goog.net.XhrIo.send(url, opt_callback, opt_method, opt_content,
opt_headers, opt_timeoutInterval)
快速查看 Clojurescript 源代码发现了以下功能:
From src/cljs/clojure/browser/net.cljs in clojure / clojurescript
(defn xhr-connection
"Returns an XhrIo connection"
[]
(goog.net.XhrIo.))
因此,与此类似的东西应该有预期的结果:
(def xhr xhr-connection)
(defn myCallback [replyValue]
... Do Something with replyValue
... for example: (someJsonFunc (.getResponseJson (.target replyValue))))
(defn ajax-json [url]
(.send xhr url myCallback))
对于 JSONP,您可以使用 goog.net.Jsonp 执行类似的操作。详情见链接:
JSONP Closure API
希望有人觉得这很有帮助!
【讨论】:
我有点困惑:为什么(.send xhr url myCallback)
有效?据我所知,xhr-connection
是一个返回新的goog.net.XhrIo
的函数,那么为什么.send
可以使用它呢?
goog.net.XhrIo 上的尾随点。使其等同于new goog.net.XhrIo()
【参考方案2】:
另一个可行的选择可能是https://github.com/JulianBirch/cljs-ajax
由于它是为 ClojureScript 设计的,因此语法看起来更清晰、更简单。它还支持很多开箱即用的功能(例如:transit
、edn
和 json
格式)。
自述文件中的一些示例:
(ns foo
(:require [ajax.core :refer [GET POST]]))
...
(GET "/hello" :handler handler
:error-handler error-handler)
(POST "/send-message"
:params :message "Hello World"
:user "Bob"
:handler handler
:error-handler error-handler)
【讨论】:
【参考方案3】:我的做法略有不同。我不知道为什么马克在他的回答中建议的方式对我不起作用。希望这也有用。
我直接使用了goog.net.XhrIo
,而不是xhr-connection
包装器。
(defn callback [reply]
(let [v (js->clj (.getResponseJson (.-target reply)))] ;v is a Clojure data structure
(your-function-here v)))
(.send goog.net.XhrIo url callback)
我可以看到的主要区别是我使用.-target
来获取JSON 对象的属性,而不是调用target
。
值得注意的是,v
中从 JSON 对象创建的映射由字符串而非关键字作为键。
【讨论】:
以上是关于在 clojurescript 中实现 ajax 调用的主要内容,如果未能解决你的问题,请参考以下文章
ClojureScript + React-Native - 嵌入视频
在 ajax 调用 Mvc-4 应用程序中实现验证时出现错误
如何使用 express.js 在 Ajax 调用中实现 CSRF 保护(寻找完整示例)?