thinkphp,外部JS如何获取模板绑定的变量值
我是一只前端,最近初学thinkphp,刚遇到一个问题,觉得值得分享一下。欢迎吐槽 ~
场景是这样的:
我要用JS调用Controller里面的某个方法获取json数据,我便使用thinkphp的U方法,发现一直报错。
首先,我们先弄清楚thinkphp的U方法。
thinkphp函数详解-U方法
代码是这样的:
//common.js里ajax获取远程数据remote: '{:U(\'Equipment/a\')}?q=%QUERY '
报错是这个:
很明显是{:U()} 这个方式不能被正确解析。为什么呢?
thinkphp官网的截图是这么说的:
如果要在模板中调用,就采用 {:U( )}的方式。
我排查很久,终于明白,原来是因为外部JS不能直接获取模板绑定的变量值。上面中U方法详解中有讲到,在模板中(即view)采用{:U( )}的方式,但是,前端的编码规范是把JS/CSS独立出来,尽量不要放在HTML代码里(HTML代码在view里),于是我就放在public里。然后便出现了上述出现的问题。模板只是display了那个HTML,不包括我的外部文件,外部JS没有被渲染,thinkphp目前也没有机制去解决这个引入外部文件渲染问题。
可以用这种方法来解决。
我在view模板里,用一个隐藏的input,然后value里面设置我要的参数
然后在JS里面获取改input的value,然在组装好自己需要跳转的URL
var aUrl = $('# a').val(); var aUrlP = aUrl + "?q=%QUERY"; remote: aUrlP;
这样就好了。可以实现外部JS获取模板中绑定的变量值。
我觉得方法虽然行得通,但是还是会出现代码冗余,期待有更好版本的TP出现。
实属原创,如有错误,敬请指教!!
关键字:JavaScript, thinkphp
版权声明
本文来自互联网用户投稿,文章观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处。如若内容有涉嫌抄袭侵权/违法违规/事实不符,请点击 举报 进行投诉反馈!