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 sort排序使用方法
Oct 17 Javascript
js Date概念详细介绍
Nov 22 Javascript
JS小功能(列表页面隔行变色)简单实现
Nov 28 Javascript
jQuery中DOM树操作之复制元素的方法
Jan 23 Javascript
全面解析Bootstrap弹窗的实现方法
Dec 01 Javascript
Bootstrap表单组件教程详解
Apr 26 Javascript
JS提示:Uncaught SyntaxError: Unexpected token ILLEGAL错误的解决方法
Aug 19 Javascript
Knockout结合Bootstrap创建动态UI实现产品列表管理
Sep 14 Javascript
JS+HTML5实现的前端购物车功能插件实例【附demo源码下载】
Oct 17 Javascript
jquery mobile实现可折叠的导航按钮
Mar 11 Javascript
vue项目打包后打开页面空白解决办法
Jun 29 Javascript
使用Mock.js生成前端测试数据
Dec 13 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和MySql中计算时间差的方法详解
2015/03/27 PHP
PHP实现的简单分页类及用法示例
2016/05/06 PHP
PHP数组编码gbk与utf8互相转换的两种方法
2016/09/01 PHP
PHP与SQL语句写一句话木马总结
2019/10/11 PHP
asp.net下利用js实现返回上一页的实现方法小集
2009/11/24 Javascript
在html页面上拖放移动标签
2010/01/08 Javascript
javascript返回顶部效果(自写代码)
2013/01/06 Javascript
一个判断抢购时间是否到达的简单的js函数
2014/06/23 Javascript
JavaScript点击按钮后弹出透明浮动层的方法
2015/05/11 Javascript
AngularJS 工作原理详解
2016/08/18 Javascript
JavaScript异步加载问题总结
2018/02/17 Javascript
Javascript操作select控件代码实例
2020/02/14 Javascript
VUE页面中通过双击实现复制表格中内容的示例代码
2020/06/11 Javascript
解决vuex数据页面刷新后初始化操作
2020/07/26 Javascript
openlayers实现图标拖动获取坐标
2020/09/25 Javascript
js属性对象的hasOwnProperty方法的使用
2021/02/05 Javascript
python使用xauth方式登录饭否网然后发消息
2014/04/11 Python
Django rest framework实现分页的示例
2018/05/24 Python
在python中利用KNN实现对iris进行分类的方法
2018/12/11 Python
简单了解python 邮件模块的使用方法
2019/07/24 Python
Django如何使用第三方服务发送电子邮件
2019/08/14 Python
python实现证件照换底功能
2019/08/20 Python
Django使用uwsgi部署时的配置以及django日志文件的处理方法
2019/08/30 Python
UI自动化定位常用实现方法代码示例
2020/10/27 Python
css3 media 响应式布局的简单实例
2016/08/03 HTML / CSS
css3 实现滚动条美化效果的实例代码
2021/01/06 HTML / CSS
HTML5之多线程(Web Worker)
2019/01/02 HTML / CSS
韩国知名的家庭购物网站:CJmall
2016/08/01 全球购物
医学毕业生自荐信
2013/10/11 职场文书
网络技术专业求职信
2014/02/18 职场文书
计算机售后服务承诺书
2014/05/30 职场文书
2014国庆黄金周超市促销活动方案
2014/09/21 职场文书
乡镇领导班子四风对照检查材料
2014/09/27 职场文书
师范生小学见习总结
2015/06/23 职场文书
2019幼儿教师求职信(3篇)
2019/09/20 职场文书
vue backtop组件的实现完整代码
2021/04/07 Vue.js