Yii2使用Bootbox插件实现自定义弹窗


Posted in Javascript onApril 02, 2015

本次尝试了一个新的小插件"bootbox"。

Yii2中使用了Bootstarp,让界面更美观,可是美中不足的是,在Gridview表格的Action里,删除功能的弹窗实在有点与Bootstrap违和,网上找到了一种解决方案,分享下使用此插件的过程。

Bootbox.js,是一个小型的JavaScript库用来创建简单的可编程对话框,基于Bootstrap的Modal(模态框)来创建。

官方说明

http://bootboxjs.com/v3.x/index.html

Bootbox.js下载

我们可以在GitHub上找到开源的bootbox.js下载

https://github.com/makeusabrew/bootbox

如何使用此插件?

结合Yii2的GridView,我们来自定义Bootbox样式的弹窗:

一、覆盖yii.js模块

Yii2自带的yii.js中定义了生成confirm对话框,以及执行action操作。

我们可以用过覆盖js方法来达到目的。

在@app/web/js/路径下创建一个javascript文件,比如main.js。

代码如下:

yii.allowAction = function ($e) {
  var message = $e.data('confirm');
  return message === undefined || yii.confirm(message, $e);
};
// --- Delete action (bootbox) ---
yii.confirm = function (message, ok, cancel) {

  bootbox.confirm(
    {
      message: message,
      buttons: {
        confirm: {
          label: "OK"
        },
        cancel: {
          label: "Cancel"
        }
      },
      callback: function (confirmed) {
        if (confirmed) {
          !ok || ok();
        } else {
          !cancel || cancel();
        }
      }
    }
  );
  // confirm will always return false on the first call
  // to cancel click handler
  return false;
}

二、注册你的资源包

需要注册bootbox.js和main.js文件。

修改文件:@app/assets/Assets.php

代码如下:

namespace backend\assets;

use yii\web\AssetBundle;

class AppAsset extends AssetBundle
{
  public $basePath = '@webroot';
  public $baseUrl = '@web';
  public $css = ['css/site.css'];
  // 注册js资源
  public $js = ['js/bootbox.js', 'js/main.js'];
  public $depends = [
    'yii\web\YiiAsset',
    'yii\bootstrap\BootstrapAsset',
  ];
}

三、自定义Modal框

了解下bootbox.js源码,可以知道bootbox.js使用的是bootstarp的modal框,我们可以根据需求

修改bootbox.js源码中的"templates"变量,自定义Modal样式。

看下对比结果:

修改前:

Yii2使用Bootbox插件实现自定义弹窗

修改后:

Yii2使用Bootbox插件实现自定义弹窗

瞬间舒服多了,弹窗功能变的不再那么违和。类似这样的弹窗插件有很多,我想可以用同样的方法来实现使用其他的插件。

以上所述就是本文的全部内容了,希望大家能够喜欢。

Javascript 相关文章推荐
javascript-TreeView父子联动效果保持节点状态一致
Aug 12 Javascript
神奇的代码 通杀各种网站-可随意修改复制页面内容
Jul 17 Javascript
qTip 基于JQuery的Tooltip插件[兼容性好]
Sep 01 Javascript
JQUERY 获取IFrame中对象及获取其父窗口中对象示例
Aug 19 Javascript
php+js实现倒计时功能
Jun 02 Javascript
让IE8浏览器支持function.bind()方法
Oct 16 Javascript
JS仿Windows开机启动Loading进度条的方法
Feb 26 Javascript
javascript学习笔记_浅谈基础语法,类型,变量
Sep 19 Javascript
使用socket.io实现简单聊天室案例
Jan 02 Javascript
Angular2整合其他插件的方法
Jan 20 Javascript
angular2组件中定时刷新并清除定时器的实例讲解
Aug 31 Javascript
JS实现获取当前所在周的周六、周日示例分析
May 11 Javascript
jquery制作多功能轮播图插件
Apr 02 #Javascript
Javascript中3个需要注意的运算符
Apr 02 #Javascript
原生JS实现响应式瀑布流布局
Apr 02 #Javascript
Javascript变量的作用域和作用域链详解
Apr 02 #Javascript
JavaScript中连接操作Oracle数据库实例
Apr 02 #Javascript
JavaScript中操作Mysql数据库实例
Apr 02 #Javascript
JavaScript使用ActiveXObject访问Access和SQL Server数据库
Apr 02 #Javascript
You might like
从C/C++迁移到PHP——判断字符类型的函数
2006/10/09 PHP
php DOS攻击实现代码(附如何防范)
2012/05/29 PHP
用PHP即时捕捉PHP中的错误并发送email通知的实现代码
2013/01/19 PHP
php获取文件内容最后一行示例
2014/01/09 PHP
PHP序列化操作方法分析
2016/09/28 PHP
PHP递归遍历指定文件夹内的文件实现方法
2016/11/15 PHP
javascript深入理解js闭包
2010/07/03 Javascript
cookie的secure属性详解
2015/04/08 Javascript
整理JavaScript创建对象的八种方法
2015/11/03 Javascript
JQuery的常用选择器、过滤器、方法全面介绍
2016/05/25 Javascript
教大家轻松制作Bootstrap漂亮表格(table)
2016/12/13 Javascript
javascript实现右下角广告框效果
2017/02/01 Javascript
手把手教你把nodejs部署到linux上跑出hello world
2017/06/19 NodeJs
vue组件创建的三种方式小结
2020/02/03 Javascript
Vue路由切换页面不更新问题解决方案
2020/07/10 Javascript
[01:07:19]DOTA2-DPC中国联赛 正赛 CDEC vs XG BO3 第一场 1月19日
2021/03/11 DOTA
Python抓取电影天堂电影信息的代码
2016/04/07 Python
Python爬取京东的商品分类与链接
2016/08/26 Python
Django日志模块logging的配置详解
2017/02/14 Python
Python错误提示:[Errno 24] Too many open files的分析与解决
2017/02/16 Python
微信跳一跳python辅助脚本(总结)
2018/01/11 Python
python实现周期方波信号频谱图
2018/07/21 Python
Pygame的程序开始示例代码
2020/05/07 Python
美国知名的摄影器材销售网站:Adorama
2017/02/01 全球购物
全球工业:Global Industrial
2020/02/01 全球购物
澳大利亚家用电器在线商店:Billy Guyatts
2020/05/05 全球购物
教育实习生的自我评价分享
2013/11/21 职场文书
财务会计人员岗位职责
2013/11/30 职场文书
英文导游欢迎词
2014/01/11 职场文书
《郑和远航》教学反思
2014/04/16 职场文书
小学领导班子对照材料
2014/08/23 职场文书
毕业生代领毕业材料的授权委托书
2014/09/29 职场文书
2014年班级工作总结范文
2014/12/23 职场文书
CSS3实现的水平标题菜单
2021/04/14 HTML / CSS
python操作xlsx格式文件并读取
2021/06/02 Python
Netty客户端接入流程NioSocketChannel创建解析
2022/03/25 Java/Android