AngularJs项目中多个页面共用一个创建或编辑页面

功能类似的项目会有类似的操作,比如:创建,编辑,删除等等。比如a页面需要创建,b页面也需要创建,c页面也需要创建,那么每个页面都写一个创建页面的html,会使代码冗余。
优化方法:
在a页面的js上:

        $scope.add = function() {
            $scope.model.errorMessage = undefined;
            $scope.model.mode = 'create';
            _internalCreateModel ({
                scope:$scope,
                template:'create.html?version='+new Date().getTime(),
                show:true
            },$model,$scope);
        };

最重要的是在让它进入创建页面之前,先给一个mode = ‘create’ ,
在创建页面:

    <h2 class="modal-title" ng-if="model.mode == 'create'">
        {{'创建' | translate}}
    </h2>
    <h2 class="modal-title" ng-if="model.mode == 'edit'">
        {{'编辑' | translate}}
    </h2>
    <button ng-if="model.mode == 'create" 
        type="button"
        ng-click="create();">
        {{'确定' | translate}}
    </button>
    <button ng-if="model.mode == 'edit" 
        type="button"
        ng-click="edit();">
        {{'确定' | translate}}
    </button>

也就是在哪个页面需要使用的,就给它 ng-if 设置一下,用到的就是在大页面设置的mode
(注:这里需要写在新的controller)
在点击确定之后,如果请求失败,就会弹出错误信息,若请求成功,就会关闭页面,并且把错误信息清空。

创建页面的逻辑代码

            $http{method:'POST',url:自己的路径,data:data}.
                success(function(data,status,headers,config) {
                    $scope.loadUsers();
                    $scope.model.loading = false;
                    $scope.$hide();
                }).
                error(function(data,status,headers,config) {
                    $scope.model.loading = false;
                    $scope.errorMessage(data.message);
                });
        };

这样即可优化完毕。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值