使用jQuery添加ng-click事件

Sup*_*nja 4 angularjs

作为Angularjs的新手,我需要对此问题提供一些帮助.我正在尝试将ng-click ="getGallery(57)"添加到模态选项卡.通过jQuery添加不是问题,但我意识到当我这样做时,Angular没有编译新添加的ng-click.我有一个简单的控制器

function imageGalleryCtrl ($scope, $http) {

    //get gallery info on click
    $scope.getGallery = function(id)
    {
        $http.post('/beta/images/get_images',{'id': id}).success(function(data)
    {
        $scope.images = data.thisGal_images;
        $scope.images.galID = id;
    });
    };

}
Run Code Online (Sandbox Code Playgroud)

我使用jQuery将ng-click添加到元素中

//Edit image tab to use angularjs
$('#image_edit a').attr('ng-click','getGallery(' + settings.id + ')');
Run Code Online (Sandbox Code Playgroud)

如何强制Angular编译这个新添加的ng-click?

谢谢!

HTML模式:

这是单击图库名称时调用的模态.

<div class="modal fade hide modal-creator" id="imageUploader" tabindex="-1" data-focus-on="input:first">
    <div class="modal-header">
        <button type="button" class="close" data-dismiss="modal"></button>
        <h3>Create New Gallery</h3>
    </div>
    <div class="modal-body">
            <ul id="myTab" class="nav nav-tabs">
                <li id="image_home" class="">
                    <a href="#home" data-toggle="tab">Home</a>
                </li>
                <li id="image_upload" class="">
                    <a href="#upload" data-toggle="tab">Upload Image Gallery</a>
                </li>
                <li id="image_edit" class="">
                    <a href="#edit" data-toggle="tab">Edit Image Gallery</a>
                </li>
            </ul>

            <div id="myTabContent" class="tab-content">

                <div class="tab-pane fade in" id="home">
                    <?php include('create.php'); ?>
                </div>

                <div class="tab-pane fade" id="upload">
                    <?php include('upload.php'); ?>
                </div>

                <div class="tab-pane fade" id="edit">
                    <div class="span9">
                <ul id="imageSort" class="gallery-container">
                <li ng-repeat="image in images">
                <img ng-src="http://images.onlinealbumproofing.com/imageGallery/{{image.galleryID}}/{{image.imageName}}" alt="">
                {{image.orgName}}
                </li>
                 </ul>
               </div><!-- /span9 -->
                </div><!-- /row -->
                </div>

            </div>

    </div><!-- /modal-body -->

    <div class="modal-footer">
        <a href="javascript:;" class="btn" data-dismiss="modal">Close</a>
        <a href="javascript:;" id="next" class="btn btn-primary">Next</a>
    </div>

</div>
Run Code Online (Sandbox Code Playgroud)

更新

所以真的试图以Angular的方式做到这一点,经过一些研究,我就在这里.控制器与上面相同,我已更新模式上的选项卡,如下所示.

<div class="modal-body">
            <ul id="myTab" class="nav nav-tabs">
                <li id="image_home" class="">
                    <a href="#home" data-toggle="tab">Home</a>
                </li>
                <li id="image_upload" class="">
                    <a href="#upload" data-toggle="tab">Upload Image Gallery</a>
                </li>
                <li id="image_edit" class="">
                    <a ng-click="getGallery(57)" href="#edit" data-toggle="tab">Edit Image Gallery</a>
                </li>
            </ul>
Run Code Online (Sandbox Code Playgroud)

如果我像上面那样硬编码ng-click,则选项卡会按预期更新.我想要做的是,当调用模态时,(#image_edit a)得到一个定义的ng-click ="getGallery(id).我需要告诉Angular再次查看ng-click的id.

Syl*_*ain 15

虽然我也认为你应该尝试找到另一种方法,但你的问题的答案

如何强制Angular编译这个新添加的ng-click?

// remove and reinsert the element to force angular
// to forget about the current element
$('#button1').replaceWith($('#button1'));

// change ng-click
$('#button1').attr('ng-click','exec2()');

// compile the element
$compile($('#button1'))($scope);
Run Code Online (Sandbox Code Playgroud)

请参阅此工作示例:http://plnkr.co/edit/SgvQzaY0TyFHD1Mf0c3F?p = preview

  • 如果$('#button1')有jquery事件监听器会在这个过程中被擦除吗? (2认同)