将变量传递给bootstrap模式

时间:2014-11-29 06:06:04

标签: javascript jquery twitter-bootstrap confirm bootstrap-modal

我有一个javascript确认/取消弹出框,动态取消选中一个复选框,并动态隐藏或显示一个menu_entry,它是表单上显示的列表的一部分,只有当用户在js上选择确定按钮时才会确认弹出框。

我现在正在尝试将js确认更改为bootstrap模式,但我不确定如何将变量传递给bootstrap模态代码并获得js确认弹出框的相同功能。

这是我的工作html代码,它调用了javascript确认弹出框:

{% for id, menu_entry, selected, item_count in menu_entries %}

    <div class="available_resume_details_height">
        <input type="checkbox" 
               style="width:1.5em; height:1.5em;"
               name="selected_items"
               value="{{ id }}"
               {% if selected %}checked="checked"{% endif %}

               onclick="checkboxUpdated(this, {{ item_count }}, '{{ menu_entry.label }}', {{ id }});"
         />

        <span style="cursor: pointer;" 
              rel="popover" 
              data-content="{{ menu_entry.tooltip }}" 
              data-original-title="{{ menu_entry.label }}" 
              {{ menu_entry.label }}
         </span>

    </div>

{% endfor %}

这是我的javascript代码,用于显示确认弹出窗口并取消选中该复选框并显示/隐藏列表条目:

function checkboxUpdated(checkbox, count, label, id) {
    if (checkbox.checked) {
        $('#menu_entry_' + id).show();
     } else {
         if (count > 0) {
             if (! confirm('{% trans "You have '+ count +' saved '+ label +'.\n\nAre you sure you want to delete your ' + count + ' saved ' + label +'?" %}')) {
                 checkbox.checked = true;
                 return;
                }
            }
        $('#menu_entry_' + id).hide();
    }
}

这是调用bootstrap模式的新html代码。这确实使得引导模态出现:

{% for id, menu_entry, selected, item_count in menu_entries %}

    <div class="available_resume_details_height">
        <input type="checkbox" 
               style="width:1.5em; height:1.5em;"
               name="selected_items"
               value="{{ id }}"
               {% if selected %}checked="checked"{% endif %}

               {% if selected %}
                   data-confirm="{% blocktrans with entry_label=menu_entry.label %}Are you sure you want to remove your {{ item_count }} selected {{entry_label}} Resume Details?{% endblocktrans %}"
               {% endif %}

         />

        <span style="cursor: pointer;" 
              rel="popover" 
              data-content="{{ menu_entry.tooltip }}" 
              data-original-title="{{ menu_entry.label }}" 
              {{ menu_entry.label }}
         </span>

    </div>

{% endfor %}

这是我的bootstrap模态代码无法正常工作。我不确定如何传递变量并获得js确认弹出的相同功能:

    $(document).ready(function() {

        $('input[data-confirm]').click(function(ev) {

            var href = $(this).attr('href');

            if (!$('#dataConfirmModal').length) {

                $('body').append('<div id="dataConfirmModal" class="modal modal-confirm-max-width" role="dialog" aria-labelledby="dataConfirmLabel" aria-hidden="true"><div class="modal-header"><button type="button" class="close" data-dismiss="modal" aria-hidden="true"><icon class="icon-remove"></icon></button><h4 class="modal-title" id="dataConfirmLabel">{% trans "Confirm" %} - {{ resume_detail_temp_value }}</h4></div><div class="modal-body"></div><div class="modal-footer"><button class="btn" data-dismiss="modal" aria-hidden="true">{% trans "Cancel" %}</button>&nbsp;&nbsp;<a class="btn-u btn-u-blue" id="dataConfirmOK">{% trans "Confirm" %}</a></div></div>');

            }

            $('#dataConfirmModal').find('.modal-body').html($(this).attr('data-confirm'));

            $('#dataConfirmModal').modal({show:true});

            $('#dataConfirmOK').click(function() {

                // handle checkbox function here.

            });

            return false;
        });

    });

引导模式应显示/隐藏列表条目,并且仅在选中确认按钮时取消选中该复选框。

编辑:添加的复选框代码:

<input type="checkbox" 
       style="width:1.5em; height:1.5em;"
       name="selected_items"
       value="{{ id }}"
       {% if selected %}checked="checked"{% endif %}
       onclick="checkboxUpdated(this, {{ item_count }}, '{{ menu_entry.label }}', {{ id }});"/>

3 个答案:

答案 0 :(得分:1)

<强>更新

http://jsfiddle.net/n0ypwceo/3/

**HTML**

<div class="available_resume_details_height">
    <input type="checkbox" data-confirm='Are you sure you want to remove? [1] ' value="id1" /> <span style="cursor: pointer;">Checkbox</span>

    <br/>
    <input type="checkbox" data-confirm='Are you sure you want to remove? [2]' value="id2" /> <span style="cursor: pointer;">Checkbox</span>

</div>

<div id="dataConfirmModal" class="modal modal-confirm-max-width" role="dialog" aria-labelledby="dataConfirmLabel" aria-hidden="true"><div class="modal-header"><button type="button" class="close" data-dismiss="modal" aria-hidden="true"><icon class="icon-remove"></icon></button><h4 class="modal-title" id="dataConfirmLabel">Confirm?</h4></div><div class="modal-body"></div><div class="modal-footer"><button class="btn" data-dismiss="modal" aria-hidden="true">"Cancel"</button>&nbsp;&nbsp;<a class="btn-u btn-u-blue" id="dataConfirmOK">"Confirm"</a></div></div>

<div id="menu_entry_id1" style="display:none">menu entry id 1</div>
<div id="menu_entry_id2" style="display:none">menu entry id 2</div>

<强> JQ:

 // global vars
 //checkbox that is clicked
 var $checkboxClicked;
 //If the confirm button is clicked
 var confirm=false;

$(document).ready(function () {

    $('input[data-confirm]').click(function (ev) {

        //box that is clicked placed in a variable
        $checkboxClicked = $(this);
        //get and store confirm text
        var dataConfirmTxt=$checkboxClicked.attr('data-confirm')

        confirm = false;

        //var href = $(this).attr('href');

        //append confirm text
        $('#dataConfirmModal').find('.modal-body').html(dataConfirmTxt);
        //show moadl
        $('#dataConfirmModal').modal('show')
        //if confirm button selected
        $('#dataConfirmOK').click(function () {

            // the confirm button is clicked
            confirm=true;

            // hide modal
            $('#dataConfirmModal').modal('hide')

        });

        return false;
    });

    //modal event: before hide    
    $('#dataConfirmModal').on('hidden.bs.modal', function (e) {

        //get menu id
        var id=$checkboxClicked.val();
        //alert(id+'/'+confirm);        
        if(confirm==true)     
        {
             // check checkbox
            $checkboxClicked.prop('checked', true);
            // show menu entry
            $('#menu_entry_' + id).show();
        }
        else
        {
            // uncheck checkbox
            $checkboxClicked.prop('checked', false);
            // hide menu entry
            $('#menu_entry_' + id).hide();
        }
     })

});

答案 1 :(得分:1)

数据属性可以帮助您以无缝方式传递函数中所需的数据,还可以帮助您避免维护不友好的内联JavaScript。按如下方式设置三个事件侦听器:

function checkboxUpdated(checkbox, count, label, id) {
    var checkbox = this,
        count = $(checkbox).data('count'),
        label = $(checkbox).data('label'),
        id = checkbox.value;
    if(checkbox.checked) {
        $('#menu_entry_' + id).show();
    } else {
        if (count > 0) {
            $('#confirm_modal').data('element', checkbox).find('div.modal-body p:first')
            .html( 'You have ' + count + ' saved ' + label + '. Are you sure you want to delete your ' + count + ' saved ' + label + '?' ).end()
            .modal('show');
            return;
        }
        $('#menu_entry_' + id).hide();
    }
}
$(function() {
    $(':checkbox').on('change', checkboxUpdated).change();
    $('.confirm-no').on('click', function() {
        var element = $('#confirm_modal').data('element');
        element.checked = true;
    });
    $('.confirm-yes').on('click', function() {
        var element = $('#confirm_modal').data('element'),
            id = element.value;
        $('#menu_entry_' + id).hide();
    });
});

DEMO

答案 2 :(得分:0)

我希望这可以帮到你。您可以在此处http://jsfiddle.net/p0mpv9e0/3/查看我的代码。

为什么您的代码无效是因为您忘记了将属性&#39;数据确认&#39;输入元素。它应该是:

<input type="checkbox" data-confirm ... />

我不确定pas变量是什么意思,但是如果你想获得存储在input元素中的数据,你可以使用变量&#34;这个&#34;在事件回调中。

$('input[data-confirm]').click(function() {
    var self = this; // it's object that store data from input element
});