Vue之外的杂谈笔记

1、老项目的构建输出为什么臃肿?

引用:(引自http://www.cnblogs.com/linfangshuhellowored/p/5657285.html)

答:因为使用的是require的rjs进行构建打包的,了解rjs的都知道,它会把项目所有依赖都打包在一个文件里,如果项目中有很多页面依赖这个模块,那么rjs并不会把这个模块提取出来作为公共模块,所以就会有很多复制性的内容,所以项目自然臃肿。

解决方案:使用webpack配合相应的loader,来完成模块加载和构建的工作。

为什么呢?

。。。。

学习:

a.浏览器阻塞问题

   现象:

       页面在加载的时候从上往下开始加载和渲染的,当页面有很多分散的JS文件的时候,页面会先加载和解析头部的js文件(同步加载),此时页面渲染就被堵塞了

  resolution:

       我们可以放在底部去加载,把所有JS放在</body>之前去,这样就会解决了游览器堵塞的问题

 b.js依赖问题

    现象:

        如果js文件之间是有相互依赖关系的,那么我们的js文件引入的顺序需要我们一定要注意,依赖性大的文件一定在最后引入,但是当依赖关系非常复杂的时候,代码的编写和维            护就非常复杂了。

    resolution:

   我们可以把所有的JS文件打包成一个JS文件【If,项目小,直接用 grunt 或者 glup 之类的工具,把所有的js代码合并为一个js,每次需要添加新文件的时候,在相关的配置中添加即可;Else,项目大那可以用AMD的方式加载:,也可以用CMD的方式加载:

】,但是依赖性(也就是顺序)我们还是没有办法。[怎么就没办法???在js中async=true/false(异步/同步)不就行了吗???]

    未完待看:https://blog.csdn.net/hao134838/article/details/51834609     http://www.cnblogs.com/linfangshuhellowored/p/5657285.html

 

2. Intellij IDEA 与 Webstorm 的区别是什么,哪个更好?

答:首先,它们都是一个公司的,

    Intellij IDEA : java + 前端(html,css,js)
    Webstorm : 前端(html,css,js)
    phpstorm : php +前端(html,css,js)

  其次,Intellij idea虽然功能最强,其他软件的功能都可以靠装插件在Intellij idea上实现,但是写前端的页面体验是没有webstrom好的,如果想做到和webstorm类似的手感,需要手动配置很多选项。

3.AngularJS父子cntroller之间如何通信?

引用(引自转载自:https://github.com/tiw/angularjs-tutorial/blob/master/event.markdown)

  事件是解耦良器,angularjs提供了很方便的事件机构。 发送事件可以用

  $scope.$emit('name', 'args');

或者是

  $scope.$broadcast('name', 'args');

要了解两者的差别, 首先要了解angularjs controller的scope的定义。 这里就不叙述了, 简单来说 angularjs controller的scope就是一个像是js的基于prototye的对象继承。

看看下面这个例子.

首先我们定义几个嵌套的controller。 (木有嵌套, 基本上也不会用事件, 当然事件也可 有$rootscope发出, 但这个首先慎用, 其次也是下面的一个特例)

<div ng-controller="ParentCtrl">

   <div ng-controller="SelfCtrl">
   
     <a class="btn" ng-click="click()">click me</a>
     <div ng-controller="ChildCtrl"></div>

   </div>
   
   <div ng-controller="BroCtrl"></div>
</div>

这里我们有四个controller, 层级关系如下:

 ParentCtrl
     -> SelfCtrl (*)
         -> ChildCtrl
     -> BroCtrl

所有的事件都是由 SelfCtrl 发出去的.

broadcast

事件发送的方法:

$scope.$broadcast

值得注意的是发送的主语是 $scope, 因为所有的事件其实都是作用在scope上的。

broadcast 是从发送者向他的子scope发送时间的一个方法。 这里就是SelfCtrl发送, SelfCtrl 和 ChildCtrl 会接受到, 而ParentCtrl是不会收到的

事件的接受只有一个方法

$scope.$on

例子如下:

angular.module('TestApp', ['ng'])
.controller('ParentCtrl', function($scope) {
 $scope.$on('to-child', function(e, d) {
   console.log('关我毛事');
 });
})
.controller('SelfCtrl', function($scope) {
  $scope.click = function () {
    $scope.$broadcast('to-child', 'haha');
    $scope.$emit('to-parent', 'hehe');
  }
})
.controller('ChildCtrl', function($scope){
  $scope.$on('to-child', function(e, d) {
    console.log('I\' the child, I got it', d);
  });
})
.controller('BroCtrl', function($scope){
  $scope.$on('to-child', function(e, d) {
    console.log('关我毛事');
  });
});

 

点击clickme后, 在console里是看不到“关我毛事“的, 原因嘛就是 “管他毛事啊”

Emit

了解了broadcast之后, emit可以用以此类推解释了。

angular.module('TestApp', ['ng'])
.controller('ParentCtrl', function($scope) {
 $scope.$on('to-parent', function(e, d) {
    console.log('we are the parent, I got it', d);
 });
})
.controller('SelfCtrl', function($scope) {
  $scope.click = function () {
    $scope.$broadcast('to-child', 'haha');
    $scope.$emit('to-parent', 'hehe');
  }
})
.controller('ChildCtrl', function($scope){
  $scope.$on('to-parent', function(e, d) {
   console.log('关我毛事');
  });
})
.controller('BroCtrl', function($scope){
  $scope.$on('to-parent', function(e, d) {
    console.log('关我毛事');
  });
});

Notes

上面的例子可以看到, 事件和事件发生者的兄弟是没有关系的, 怎样都收不到。

 验证

1.$scope.$broadcast('to-child', 'haha');   的作用
<div ng-app="myApp" ng-controller="ParentCtrl">  
   <div ng-controller="SelfCtrl">
     <a class="btn" ng-click="click()">{{self_click}}</a>
     <div ng-controller="ChildCtrl">
         <div ng-controller="GrandChildCtrl"></div>
     </div>
   </div>
   <div ng-controller="BroCtrl"></div>
</div>
<script>
angular.module('myApp', ['ng'])
.controller('ParentCtrl', function($scope) {
 $scope.$on('to-child', function(e, d) {
   console.log('关我毛事');
 });
    $scope.$on('to-parent',function(e,d){
        console.log('I am the parent',d);
    })
})
.controller('SelfCtrl', function($scope) {
  $scope.self_click="selfClick";
  $scope.click = function () {
    $scope.$broadcast('to-child', 'haha');
    //$scope.$emit('to-parent', 'hehe');
  }
})
.controller('GrandChildCtrl', function($scope){
  $scope.$on('to-child', function(e, d) {
    console.log('I\' the grandChild, I got it', d);
  });
})
.controller('ChildCtrl', function($scope){
  $scope.$on('to-child', function(e, d) {
    console.log('I\' the child, I got it', d);
  });
})
.controller('BroCtrl', function($scope){
  $scope.$on('to-child', function(e, d) {
    console.log('关我毛事');
  });
});
</script>

效果:

说明:selfChild控制器,使用$scope.$broadcast只能将信息向下传递其孩子控制器和孙子控制器,不能向上传给父控制器,也不能传给兄弟控制器;

 

2.$scope.$emit('to-child', 'haha'); 的作用

<div ng-app="myApp" ng-controller="ParentCtrl">  
   <div ng-controller="SelfCtrl">  
     <a class="btn" ng-click="click()">{{self_click}}</a>
     <div ng-controller="ChildCtrl">
         <div ng-controller="GrandChildCtrl"></div>
     </div>
   </div>
   <div ng-controller="BroCtrl"></div>
</div>
<script>
angular.module('myApp', ['ng'])
.controller('ParentCtrl', function($scope) {
 $scope.$on('to-child', function(e, d) {
   console.log('关我毛事');
 });
    $scope.$on('to-parent',function(e,d){
        console.log('I am the parent',d);
    })
})
.controller('SelfCtrl', function($scope) {
  $scope.self_click="selfClick";
  $scope.click = function () {
    //$scope.$broadcast('to-child', 'haha');
    $scope.$emit('to-parent', 'hehe');
  }
})
.controller('ChildCtrl', function($scope){
  $scope.$on('to-child', function(e, d) {
    console.log('I\' the child, I got it', d);
  });
})
.controller('GrandChildCtrl', function($scope){
  $scope.$on('to-child', function(e, d) {
    console.log('I\' the grandChild, I got it', d);
  });
})
.controller('BroCtrl', function($scope){
  $scope.$on('to-child', function(e, d) {
    console.log('关我毛事');
  });
});
</script>

效果:

说明:SelfCtrl控制器,使用$emit()只能将信息向上传递给父控制器,不能传递给子孙控制器,也不能传给兄弟控制器。

实际应用

1.需求:页面加载后,显示SelfCtrl和ParentCtrl的内容,点击SelfCtrl后,使用上述通信原理,将ParentCtrl的默认内容修改为SelfCtrl的。

2.实现:

<div ng-app="myApp" ng-controller="ParentCtrl">  
   <p>父控制器:{{parent_p}}</p>
   <div ng-controller="SelfCtrl">  
     <a class="btn" ng-click="click()">我:{{self_click}}</a>
     <div ng-controller="ChildCtrl">
         <div ng-controller="GrandChildCtrl"></div>
     </div>
   </div>
   <div ng-controller="BroCtrl"></div>
</div>
<script>
angular.module('myApp', ['ng'])
.controller('ParentCtrl', function($scope) {
 $scope.parent_p="parentP";
 $scope.$on('to-child', function(e, d) {
   console.log('关我毛事');
 });
    $scope.$on('to-parent',function(e,d){
        console.log(e);
        $scope.parent_p=e.targetScope.self_click;        
        console.log('I am the parent',d);
    })
})
.controller('SelfCtrl', function($scope) {
  $scope.self_click="selfClick";
  $scope.click = function () {
    //$scope.$broadcast('to-child', 'haha');
    $scope.$emit('to-parent', 'hehe');
  }
})
.controller('ChildCtrl', function($scope){
  $scope.$on('to-child', function(e, d) {
    console.log('I\' the child, I got it', d);
  });
})
.controller('GrandChildCtrl', function($scope){
  $scope.$on('to-child', function(e, d) {
    console.log('I\' the grandChild, I got it', d);
  });
})
.controller('BroCtrl', function($scope){
  $scope.$on('to-child', function(e, d) {
    console.log('关我毛事');
  });
});
</script>

效果:

 

 

 

 

 

 

 

 

posted @ 2018-05-11 01:56  夏小念  阅读(220)  评论(0编辑  收藏  举报