在使用Fast这个对象之前,首先需要注意的是这个对象只适用于使用了RequireJS进行模块加载的JS脚本中,当然后台开发肯定是完全可以用的,但前台开发时特别注意下。
Fast
RequireJS
后台全局JS脚本中、插件Bootstrap.js、控制器对应的JS均可使用,前台必须使用RequireJS加载模块时才可以使用
Fast这个变量是渲染到全局的,因此在任何位置均可使用,甚至在HTML中也可以(不建议)。这里需要注意的是因为FastAdmin后台使用的是iframe嵌套的网页,因此如果在跨页面调用时务必注意当前的位置,比如需要调用顶层的Fast时,务必加上top,比如top.Fast.api.open,如果需要调用父级窗口的Fast时,务必加上parent,比如parent.Fast.api.open。
iframe
top
top.Fast.api.open
parent
parent.Fast.api.open
方法:
Fast.api.ajax(options, success, error);
参数:
方法示例:Fast.api.ajax常常需要配合后端使用$this->success("操作成功", "", $data)或$this->error("操作失败", "", $data)返回操作状态。
Fast.api.ajax
$this->success("操作成功", "", $data)
$this->error("操作失败", "", $data)
//发送一个Ajax请求,并根据后台返回的状态值进行提示 Fast.api.ajax("ajax/test"); //发送一个Ajax请求,并手动处理成功的事件 Fast.api.ajax("ajax/test", function(data, ret){ //data为使用$this->success("操作成功", "", $data);中$data的值 //ret为{"code":1 "data":$data, "msg":"操作成功"} }); //发送一个Ajax请求,并禁用提示 Fast.api.ajax("ajax/test", function(data, ret){ //返回false时将不再有右上角的操作成功的提示 return false; }); //发送一个POST请求,并附带参数`name`和`age` Fast.api.ajax({ url: "ajax/test", data: {"name":"李四", "age":"30"} }, function(data, ret){ //成功的回调 });
温馨提示:Fast.api.ajax在发送Ajax请求时会自动补全URL地址,因此我们在请求是写相应的地址即可,比如
//正确的写法 Fast.api.ajax("ajax/test"); //错误的写法 Fast.api.ajax("/admin/ajax/test"); //正确的写法,以/addons/开头表示插件的URL比较特殊 Fast.api.ajax("/addons/example/index/test");
Fast.api.fixurl(url);
方法示例:
Fast.api.fixurl("ajax/test"); //返回:/admin/ajax/test
Fast.api.cdnurl(url);
//返回:http://cdn.yoursite.com/uploads/aa.png Fast.api.cdnurl("/uploads/aa.png"); //返回:http://cdn.yoursite.com/uploads/aa.png Fast.api.cdnurl("http://cdn.yoursite.com/uploads/aa.png");
温馨提示:如果未启用云储存插件,此方法可能会始终返回相对地址,此时可以修改application/extra/upload.php中的cdnurl,将此改为你的域名即可。
application/extra/upload.php
cdnurl
Fast.api.open(url, title, options);
// 使用弹窗打开test/detail页面 Fast.api.open("test/detail", "测试"); // 使用全屏的方法打开test/detail页面 Fast.api.open("test/detail", "全屏测试", {area:["100%", "100%"]}); // 打开弹窗,并进行回调处理 Fast.api.open("test/detail", "回调测试", { callback: function(data){ //data值为test/detail页面中使用Fast.api.close(data)回调的值 } }); // 在顶层打开弹窗 top.Fast.api.open("test/detail", "回调测试");
温馨提示:此方法务必注意一下,如果打开的页面中存在类名为layer-footer的元素,其中的元素将会被渲染在弹窗底部,比如我们在后台经常看到的确定和重置都是因为打开的页面中存在layer-footer元素,如果你想扩展你的功能,你可以把你的按钮放置在此区域。
layer-footer
确定
重置
Fast.api.close(data);
// 使用弹窗关闭test/detail页面 Fast.api.close("test"); // 使用全屏的方法关闭test/detail页面 Fast.api.close({name:"李四"});
温馨提示:此方法必须配合Fast.api.open("url", "标题", {callback:function(data)})才可以正常发送回调,否则只能关闭弹窗。
Fast.api.open("url", "标题", {callback:function(data)})