Modal widget in Magento 2

Magento 2 自带模态的应用

使用magento 2 的自带模态组件,以下代码只供参考使用。

1,DOM 》模态块与触发元素

.pthml

<!-- 模态DOM -->
<div id="modal-content" hidden="hidden" data-goodsid=""> <?php if ($block->isLogin()): ?>
<!-- fixme view data-->
<!-- Add list CSS @var todo $mcsize_list Mc_Size::css/account/mcsize_list.css -->
<link rel="stylesheet" href="<?php echo $this->getViewFileUrl('Mc_Size::css/account/mcsize_list.css'); ?>"> <!-- Add list DOM-->
<div id="account-mcsize-lists">
<span class="base page-title">Select size</span>
<hr>
<div>
<span class="btn-xs cursor" id="tape">Tape </span>
<span> | </span>
<span class="btn-xs cursor" id="shirt">Shirt </span>
</div>
<br>
<!-- fixme tape-->
<div id="class_tape" class="measurement-profiles"> <?php $list_data = $block->getTapeList(); ?>
<?php foreach ($list_data as $news) { ?>
<div class="measurement-profile c-24 c-m-24" data-id="<?php echo $news['tape_id'] ?>" data-type="tape">
<div>
<div class="icon">
<!--fixme img icon-->
<!--fixme edit--> <img src="<?php echo $this->getViewFileUrl('Mc_Size::images/tape-measure.svg'); ?>"
alt=""> </div>
<div class="summary">
<span class="name"><?php echo $news['name']; ?></span><br>
<span class="type">Body measurements - <?php echo $news['created_at']; ?></span>
</div> <div class="actions">
<a class="primaryButton mini"
href="/mcsize/index/tape?id=<?php echo $news['tape_id'] ?>">Edit</a>
</div>
</div>
</div>
<?php } ?>
</div>
<!-- end--> </div>
<?php else: ?>
<!-- fixme view message-->
<div class="col-md-12">Go to <a href="/customer/account/login" class="">Login</a> now !</div>
<?php endif ?>
</div> <!-- 触发元素-->
<div id="__modal-button-<?php echo $_item->getId(); ?>" style="cursor: pointer;" data-mage-init='{"example-modal": {"target": "#modal-content"}}' class="btn-xs btn-primary"> Binding size</div>

  

2,配置模块名》目录自动加载

/app/code/vendor_name/module_name/view/frontend/requirejs-config.js

var config = {
map: {
'*': {
'example-modal': '<vendor_name>_<module_name>/js/example-modal'
}
}
};

3,调用模态》用于触发的 js 代码

example-modal.js ——  注意:ExampleModal 对象对模块绑定函数

define([
"jquery", "Magento_Ui/js/modal/modal", 'Mc_Size/plugins/sweetalert.min'
], function ($) { var p = "#account-mcsize-lists";
var f = ".measurement-profile";
var ac = 'active'; $(p).find(f).on('click', clickSize); function clickSize(e) {
e.stopPropagation();
var me = $(this);
me.addClass(ac); me.siblings().removeClass('active');
} /**
*
* @param name
* @returns {*|jQuery.fn.init|n.fn.init|m.fn.init|jQuery|HTMLElement}
*/
function getobj(name) {
return $(name);
} $('#tape').on('click', function () {//todo click tape var s = '#class_shirt';
var t = '#class_tape';
var t_html = $(t).clone(true);
var s_html = $(s).clone(true); $(t).remove();
$(s).remove(); $(p).append(t_html);
$('#shirt_dom').append(s_html);
}); $('#shirt').on('click', function () {//todo click shirt var s = '#class_shirt';
var t = '#class_tape';
var t_html = $(t).clone(true);
var s_html = $(s).clone(true); $(t).remove();
$(s).remove(); $('#shirt_dom').append(t_html);
$(p).append(s_html); $(p).find(f).on('click', clickSize);
}); // fixme modal
var ExampleModal = {
initModal: function (config, element) {
$target = $(config.target);
$element = $(element);
$target.modal({
closed: function () {
// Do some action when modal closed
var tape_id = $(p).find('.active').data('id');
var type = $(p).find('.active').data('type');
if (!tape_id) {
$target.modal('openModal');//open modal
return;
} var active = '#cart-' + ac;
$(active).attr({'data-id': tape_id,'data-type':type}).text('Already bound').addClass('btn-danger');
$(p).find(f).removeClass(ac);
$(active).attr('id', '');//remove id
}
}); $element.click(function () {
var dataid = $(this).attr('data-id');
var datatype = $(this).attr('data-type'); $(this).attr('id', 'cart-' + ac);//add id //data-type is shirt
if(datatype === 'shirt'){
$('#shirt').trigger('click');//event trigger
}else if(datatype === 'tape'){
$('#tape').trigger('click');//event trigger
} if (dataid) {
$(p).find('div[data-id=' + dataid + ']').addClass(ac);
}else{
// ..
} $target.modal('openModal');//open modal }); }
};
return {
'example-modal': ExampleModal.initModal
};
}
);

@其它——直接在页面使用

<script>
require(
["jquery", "Magento_Ui/js/modal/modal", 'Mc_Size/plugins/sweetalert.min']
, function ($,modal,swal) { var options = {
'type': 'popup',
'title': 'Select Gender',
'responsive': true,
'innerScroll': true,
}; var popup = modal(options, $('#modal-content'));
$('#modal-content').modal('openModal');//open modal
})
</script>

  

Magento 2 自带模态的应用的更多相关文章

  1. [转]解决Magento批量导入带图片的商品的问题

    本文转自:http://www.phpstudio.info/show-121-791-1.html 一般来说,Magento后台管理里的CSV批量导入,可以解决我们商品批量上传的大部分问题,我们只要 ...

  2. magento安装

    最近在做一个Magento 1.7.0.2的站,在安装环节Magento一直报错Database server does not support the InnoDB storage engine. ...

  3. Magento给新产品页面添加分页

    本文介绍如何让magento创建一个带分页功能的新到产品页面,方便我们在首页或者其它CMS Page调用和展示新到产品. 在Magento我们经常有的做法是建立一个可以调用新产品的block,然后通过 ...

  4. magento数据库备份导入还原

    Magento数据库备份.移植终极解决方案+3 分类:Magento教程 标签:magento搬家.magento数据库备份.magento更换域名.magento移植 4,355人浏览 作为电子商务 ...

  5. magneto创建运费模板

    Magento系统自带了大概7种运费方式:平价.运费表.免运费.ups.usps.fedex.dhl等.不过这些依然无法满足我们的需求,这时候就需要创建一个shipping module 来实现了.创 ...

  6. 测试报告$\alpha$

    pytorch可视化编程网站VisualPytorch NAG \(\alpha\)版本发布了!点击网址访问:VisualPytorch 一.测试查虫(bug detection) 测试贯穿了开发.集 ...

  7. QT模态对话框用法(在UI文件中设置Widget背景图,这个图是一个带阴影边框的图片——酷)

    QT弹出模态对话框做法: 1.新建UI文件时,一定要选择基类是QDialog的,我的选择是:Dialog without Buttons(),如下图: 2.然后在使用的时候: MyDialog dlg ...

  8. Bootstrap 模态框(Modal)带参数传值实例

    模态框(Modal)是覆盖在父窗体上的子窗体.通常,目的是显示来自一个单独的源的内容,可以在不离开父窗体的情况下有一些互动.子窗体可提供信息.交互等. 为了实现父窗体与其的交互,通常需要向其传值,实现 ...

  9. bootstrap如何去除自带的样式----导航栏中的菜单实现平滑的过渡到对应的菜单区域-------动态跟换模态框中的内容

    问题1:如何去除bootstap中css中自带的overflow:hidden这个样式 今天遇见在bootstap中轮播图上的  附带图  片不能够显示出来,图片始终有一部分的高度  被隐藏了 后来通 ...

随机推荐

  1. Flutter 即学即用系列博客——09 MethodChannel 实现原生与 Flutter 通信(二)

    前言 上一篇我们讲解了如何通过 EventChannel 实现 Android -> Flutter 的通信. 并且也看到了 Flutter 内部 EventChannel 源码也是对 Meth ...

  2. 26 , CSS 构造表单

    1. 表单标签使用 2. 下拉菜单背景 3. 滚动条的使用 4. 结构化表单布局 1 1 1 1. . . . 表单标签的使用 <label for=”name”>姓名: <inpu ...

  3. C# E店宝格格家接口对接

    一.实现图片 二.实现通用方法 /// <summary> /// 调用通用方法 /// </summary> /// <param name="strURL& ...

  4. 性能测试 基于Python结合InfluxDB及Grafana图表实时监控Android系统和应用进程

    基于Python结合InfluxDB及Grafana图表实时监控Android系统和应用进程   By: 授客 QQ:1033553122     1. 测试环境 2. 实现功能 3. 使用前提 4. ...

  5. 使用 phpstudy 搭建本地测试环境

    最近在为另一个部门配置一个多语言的网站,因为之前他们已经做过 英文和中文两种语言,这次帮他们添加其它几种语言,从GitLab 上拉下来的代码,是php环境做的,需要在本地跑起来,做完测试通过后再一次性 ...

  6. C盘突然报警,空间不足,显示成红色了

    1.清理系统垃圾文件 将如下命令保存到一个bat文件中,执行,删除垃圾文件 @echo off net share c$ /del net share d$ /del net share e$ /de ...

  7. mysql7笔记----存储过程实例

    mysql创建存储过程 DROP PROCEDURE IF EXISTS getCreateTimes /*前面要写DELIMITER $$ 或DELIMITER // */ DELIMITER $$ ...

  8. Linux(CentOS7)下如何配置多个JDK环境变量

    一.Linux版本 二.复制粘贴多个JDK出来,如下 cp -R jdk1.7.0_80/ jdk1.7.0_80-2 cp -R jdk1.7.0_80/ jdk1.7.0_80-3 三.配置多个J ...

  9. AI-2048 注释

    针对2048游戏,有人实现了一个AI程序,可以以较大概率(高于90%)赢得游戏,并且作者在 stackoverflow上简要介绍了AI的算法框架和实现思路. 有博客介绍了其中涉及的算法,讲的很好 其中 ...

  10. ERROR:"org.apache.zookeeper.KeeperException$NoAuthException: KeeperErrorCode = NoAuth for /config/topics/test" when creating or deleting Kafka operations authorized through the Ranger policies

    PROBLEM DESCRIPTION When creating or deleting topics in Kafka, they cannot be authorized through the ...