功能类似的项目会有类似的操作,比如:创建,编辑,删除等等。比如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);
});
};
这样即可优化完毕。