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 相关文章推荐
JS弹出对话框返回值代码(asp.net后台)
Dec 28 Javascript
原生js制作简单的数字键盘
Apr 24 Javascript
jQuery插件zepto.js简单实现tab切换
Jun 16 Javascript
详解Document.Cookie
Dec 25 Javascript
BootstrapTable+KnockoutJS自定义T4模板快速生成增删改查页面
Aug 01 Javascript
Sublime Text新建.vue模板并高亮(图文教程)
Oct 26 Javascript
JS实现快递单打印功能【推荐】
Jun 21 Javascript
使用vue的transition完成滑动过渡的示例代码
Jun 25 Javascript
websocket4.0+typescript 实现热更新的方法
Aug 14 Javascript
js实现带箭头的进度流程
Mar 26 Javascript
JavaScript中使用Spread运算符的八种方法总结
Jun 18 Javascript
vue 图片裁剪上传组件的实现
Nov 12 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
PHP中for与foreach的区别分析
2011/03/09 PHP
一个完整的PHP类包含的七种语法说明
2015/06/04 PHP
Laravel 关联模型-关联新增和关联更新的方法
2019/10/10 PHP
Laravel框架Eloquent ORM简介、模型建立及查询数据操作详解
2019/12/04 PHP
jQuery技巧大放送 学习jquery的朋友可以看下
2009/10/14 Javascript
再谈ie和firefox下的document.all属性
2009/10/21 Javascript
IE6已终止操作问题的2种情况及解决
2014/04/23 Javascript
Javascript实现简单的富文本编辑器附演示
2014/06/16 Javascript
javascript学习笔记(五)原型和原型链详解
2014/10/08 Javascript
jQuery的Read()方法代替原生JS详解
2016/11/08 Javascript
vue-router单页面路由
2017/06/17 Javascript
Node.js实现文件上传的示例
2017/06/28 Javascript
Vue实现日历小插件
2019/06/26 Javascript
laydate只显示时分 不显示秒的功能实现方法
2019/09/28 Javascript
node后端服务保活的实现
2019/11/10 Javascript
jQuery操作元素追加内容示例
2020/01/10 jQuery
JavaScript实现简单日历效果
2020/09/11 Javascript
[02:30]联想杯DOTA2完美世界全国高校联赛—北京站现场
2015/11/16 DOTA
[24:42]VP vs TNC Supermajor小组赛B组 BO3 第三场 6.2
2018/06/03 DOTA
python 提取文件的小程序
2009/07/29 Python
python3图片转换二进制存入mysql
2013/12/06 Python
Python警察与小偷的实现之一客户端与服务端通信实例
2014/10/09 Python
Python计算回文数的方法
2015/03/11 Python
在Python的Flask框架中使用模版的入门教程
2015/04/20 Python
Python简单检测文本类型的2种方法【基于文件头及cchardet库】
2016/09/18 Python
python 输入一个数n,求n个数求乘或求和的实例
2018/11/13 Python
Matplotlib中文乱码的3种解决方案
2018/11/15 Python
Python推导式简单示例【列表推导式、字典推导式与集合推导式】
2018/12/04 Python
初中音乐教学反思
2014/01/12 职场文书
初中英语教学反思
2014/01/25 职场文书
单位法定代表人授权委托书
2014/09/20 职场文书
服务整改报告
2014/11/06 职场文书
公务员政审材料
2014/12/23 职场文书
团员个人年度总结
2015/02/26 职场文书
员工升职自荐信
2015/03/27 职场文书
Python源码解析之List
2021/05/21 Python