javascript - Yesod:在 AJAX 调用中使用类型安全的 URL

标签 javascript ajax haskell yesod

在我的 Yesod 项目中,我有以下路线:

/api/hide/thread/#Text/#Int      ApiHideThreadR   GET

我想用 javascript 在客户端请求它:

function hideThreadCompletely(threadId, board) {
    $.getJSON("/api/hide/thread/"+board+"/"+threadId, function(data) {
        $('#thread-'+threadId).hide();
    });
}

但我不能使用 @{ApiHideTHreadR} 因为 Yesod 需要它在编译时的参数。如果我希望 API URL 看起来像 api/board/1/1 而不是 api/board?bid=1&tid=1,那么正确的解决方案是什么?继续使用手动定义的 URL,例如 "/api/hide/thread/"+board+"/"+threadId?

最佳答案

经过一番搜索,我找到了这个 discussion ,建议您将 url 作为“data-url”属性添加到某个元素。然后从元素加载 url。 像这样:

<div id="thread-1" data-hide-url=@{ApiHideTHreadR}>

var url = $("#thread-1").data("hide-url")

关于javascript - Yesod:在 AJAX 调用中使用类型安全的 URL,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19046988/

相关文章:

javascript - 如何将 Lodash orderby 与自定义函数一起使用?

javascript - 如果没有任何参数,super() 会做什么?

javascript - promise .catch() : how to identify the differences between operational rejects and programmatical throws

javascript - CSS jQuery - 展示图像(淡入淡出)

ajax - 自动完成+建议搜索栏搜索nodejsexpress框架,使用mongodb数据库

jquery - 每秒执行一次 Ajax 请求

php - 在一页中绘制多个 flot

haskell - `flip id` 是如何工作的?

haskell - 无法将预期类型 ‘Int -> [Char]’ 与实际类型 ‘Int’ 匹配 可能的原因 : ‘mod’ is applied to too many arguments

postgresql - 对 Hasql 查询的参数列表进行编码