编程开发 > JAVA > 文章内容

JavaScript知识点:详解在AngularJS的controller外部直接获取$scope

2017-6-29编辑:daibenhua

  以前利用webqq的写过一个自动发消息的脚本,由于那时webqq还直接使用类似jQuery操作DOM的技术,所以脚本很简单就可以实现。

  现如今很多web应用都开始使用AngularJS,MVVM导致的就是无法操作dom而去直接改变数据。所以面对网页版微信,要实现一个自动发送的脚本,就无法再用以前那套DOM的思路了。

  要修改AngularJS中的数据,首先就要获取scope。其实获取scope的方法很简单。

  由于大部分Angular项目需要使用jQuery作为补充。可以在jQuery中通过.scope()方法获取当前选择器内容里继承的域。

  即类似这样的方式:

  ?

1
$('div[ng-controller="listController"]').scope();

  例:完整的例子。

  ?

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
<html lang="en" ng-app="app">
<head>
  <meta charset="UTF-8">
  <title>Get angular's scope in jQuerytitle>
  <script>
    angular.module('app',[])
        .controller('listController',['$scope', function ($scope) {
          $scope.list = [1,2,3,4,5];
          $scope.test = function () {
            console.log('test');
          }
        }])
  script>
  <script>
    $(document).on('ready', function () {
      var controllerScope = $('div[ng-controller="listController"]').scope(); // Get controller's scope
      controllerScope.test(); // log 'test'
      console.log(controllerScope.list); // log [1,2,3,4,5]
      $('button').click(function (e) {
        var scope = $(e.target).scope();
        console.log(scope.item) // log item number
        scope.test(); // log 'test'
      })
    })
  script>
head>
<body>
<div ng-controller="listController">
  <ul>
    <li ng-repeat="item in list"><button>Select {{item}}button>li>
  ul>
div>
body>
html>

  那么打开网页版微信的页面(2016-06-05)选中你需要发消息的人。然后执行如下脚本:

  ?

1
2
3
4
5
6
var controllerScope = $('div[ng-controller="chatSenderController"]').scope();
  // 获取chatSenderController的$scope
controllerScope.editAreaCtn = "星哥,下午好"// 设置需要发送的消息。即设置$scope某个属性的值。
 
// 触发“发送按钮”的点击事件。
$(".action a").trigger("click");

  非常好的“外挂方式”。

  以上就是本文的全部内容,希望对大家的学习有所帮助

JavaScript知识点:angularjs定时任务的设置与清除示例

热点推荐

登录注册
触屏版电脑版网站地图