视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
AngularJswatch监听inputvalue并请求数据的方法
2020-11-27 20:01:44 责编:小采
文档


本文主要和大家分享AngularJs watch监听input value并请求数据的方法,希望能帮助到大家。


1、html input菜单和隐藏的控件

<p class="form-pider"></p>
<p class="form-item form-remark">
 <p class="item-title"><span class="adError">*</span> 投放产品</p>
 <input name="app" ng-model="chance.appName" type="text" class="item-select" placeholder="请填写产品名称">
</p>
<p ng-if="ishaveName==true" class="margin-top-1 adError">
 该应用已被商务"{{haveName}}"录入国,可保持沟通
</p>

2、watch开始使用

1、JS 必须初始化$watch控件 ,ng-model="chance.appName"

$scope.chance={
 appName:null};

2、开始watch代码

1、一定注意是$watch,前面有美元符。里面是变量,变量前面没有$scope

2、在没有获取到值的情况下,提示控件,应该不显示。所以设置了变量$scope.ishaveName= false,注意JS头部初始化为false,只有当true的时候才会显示提示控件

3、在进入$watch的时候,就将上面2中的$scope.ishaveName设置为false


$scope.chance={
 appName:null};$scope.ishaveName= false;

$scope.$watch('chance.appName',function () {
 $scope.ishaveName= false; if($scope.chance.appName!=null&&$scope.chance.appName!=undefined&&$scope.chance.appName!=''){ $http.get(ctx+'/chance/findAdminByAppName?appName='+$scope.chance.appName)
 .success(function (data,status) {
 if(data.result!=null){ $scope.haveName= data.result.name; $scope.ishaveName= true;

 }
 })
 }

});

3、后端代码


1、controller


@Controller@RequestMapping("chance")@ResourceFolder(folder = "module/chance/")public class ChanceController {


 @GetMapping("findAdminByAppName") @ResponseBody
 public ResponseBean findAdminByAppName(String appName){ try { return ResponseBean.buildSuccess(customerChanceService.findAdminByAppName(appName));
 }catch (AppException e){ return ResponseBean.buildFailure(e.getMessage());
 }
 }
}

2、service,当如果为登录人员自己设置的产品的时候,不需要提示自己,尽可能的提示其他人(傻子知道)。


//根据产品名字 ,查看是否有商务经理已经添加了该产品,选则一个不是自己的产品经理@Overridepublic SysAdminUser findAdminByAppName(String appName) { if("".equals(appName)||appName==null){ return null;
 }
 Long adminId = CasConfig.RemoteUserUtil.getRemoteUserId();

 List<SysAdminUser> sysAdminUsers = customerMapper.findAdminByAppName(appName); //有可能会出现多个人,那么首先如果是自己创建的话,就排除掉
 if(sysAdminUsers.size()>0){ if(adminId.compareTo(sysAdminUsers.get(0).getId())==0){
 sysAdminUsers.remove(0);
 } if(sysAdminUsers.size()>0){ return sysAdminUsers.get(0);
 }
 } return null;
}

3、mapper

1、首先应该明确,我们这里获取的是管理人,所以要以管理人为核心。


<!--根据产品,名字,看出是否已经有商务经理在维护了,根据产品名字 ,查看是否有商务经理已经添加了该产品,如果前台传入的参数我空,则通过java判断,不能进入本sql,`否则会出错`-->
 <select id="findAdminByAppName" resultType="com.duodian.admore.entity.db.admin.SysAdminUser"> SELECT s.* FROM `sys_admin_user` s
 left JOIN crm_customer_chance c on c.adminId = s.id where c.isVisible = 1 and c.adminId is not NULL
 <if test="_parameter != null and _parameter!= ''"> and c.appName = #{_parameter}
 </if> GROUP by id
 </select>

</mapper>

下载本文
显示全文
专题