有问题就有答案
Q1:新手求解,js组合继承模式
p {
line-height:20px;
}
ul{ list-style-type:none;}
li{ list-style-type:none;}
Q2:怎么快速上手JavaScript中的ES6,ES6中的解构,运算符,类,继承模块化 有什么简单的理解?
模块化在项目中十分的重要,一个复杂的项目肯定有很多相似的功能模块,如果每次都需要重新编写模块肯定既费时又耗力。但是引用别人编写模块的前提是要有统一的“打开姿势”,如果每个人有各自的写法,那么肯定会乱套,下面介绍几种JS的模块化的规范。一:模块化进程一:script标签这是最原始的 JavaScript 文件加载方式,如果把每一个文件看做是一个模块,那么他们的接口通常是暴露在全局作用域下,也就是定义在 window 对象中,不同模块的接口调用都是一个作用域中,一些复杂的框架,会使用命名空间的概念来组织这些模块的接口。缺点:1、污染全局作用域2、开发人员必须主观解决模块和代码库的依赖关系3、文件只能按照script标签的书写顺序进行加载4、在大型项目中各种资源难以管理,长期积累的问题导致代码库混乱不堪二:模块化进程二:CommonJS规范该规范的核心思想是允许模块通过require方法来同步加载所要依赖的其他模块,然后通过 exports 或 mole.exports 来导出需要暴露的接口。require("mole");require("../file.js");exports.doStuff = function(){};mole.exports = someValue;优点:1、简单并容易使用2、服务器端模块便于重用缺点:1、同步的模块加载方式不适合在浏览器环境中,同步意味着阻塞加载,浏览器资源是异步加载的2、不能非阻塞的并行加载多个模块mole.exports与exports的区别1、exports 是指向的 mole.exports 的引用2、mole.exports 初始值为一个空对象 {},所以 exports 初始值也是 {}3、require() 返回的是 mole.exports 而不是 exportsexports示例://app.jsvar circle = require("./circle");console.log(circle.area(4));//circle.jsexports.area = function(r){return r * r * Math.PI;}mole.exports示例://app.jsvar area = require("./area");console.log(area(4));//area.jsmole.exports = function(r){return r * r * Math.PI;}错误的情况://app.jsvar area = require("./area");console.log(area(4));//area.jsexports = function(r){return r * r * Math.PI;}其实是对 exports 进行了覆盖,也就是说 exports 指向了一块新的内存(内容为一个计算圆面积的函数),也就是说 exports 和 mole.exports 不再指向同一块内存,也就是说此时 exports 和 mole.exports 毫无联系,也就是说 mole.exports 指向的那块内存并没有做任何改变,仍然为一个空对象{},也就是说area.js导出了一个空对象,所以我们在 app.js 中调用 area(4) 会报 TypeError: object is not a function 的错误。总结:当我们想让模块导出的是一个对象时, exports 和 mole.exports 均可使用(但 exports 也不能重新覆盖为一个新的对象),而当我们想导出非对象接口时,就必须也只能覆盖 mole.exports 。三:模块化进程三:AMD规范由于浏览器端的模块不能采用同步的方式加载,会影响后续模块的加载执行,因此AMD(Asynchronous Mole Definition异步模块定义)规范诞生了。AMD标准中定义了以下两个API1、require([mole], callback);2、define(id, [depends], callback);require接口用来加载一系列模块,define接口用来定义并暴露一个模块。示例:define("mole", ["dep1", "dep2"], function(d1, d2){return someExportedValue;});require(["mole", "../file"], function(mole, file){ /* ... */});优点:1、适合在浏览器环境中异步加载模块2、可以并行加载多个模块缺点:1、提高了开发成本,代码的阅读和书写比较困难,模块定义方式的语义不顺畅2、不符合通用的模块化思维方式,是一种妥协的实现四:模块化进程四:CMD规范CMD(Common Mole Definition)规范和AMD很相似,尽量保持简单,并与CommonJS和Node.js的 Moles 规范保持了很大的兼容性。在CMD规范中,一个模块就是一个文件。示例:define(function(require, exports, mole){var $ = require("jquery");var Spinning = require("./spinning");exports.doSomething = ...mole.exports = ...})优点:1、依赖就近,延迟执行2、可以很容易在 Node.js 中运行缺点:1、依赖 SPM 打包,模块的加载逻辑偏重AMD和CMD的区别AMD和CMD起来很相似,但是还是有一些细微的差别,让我们来看一下他们的区别在哪里:1、对于依赖的模块,AMD是提前执行,CMD是延迟执行。2、AMD推崇依赖前置;CMD推崇依赖就近,只有在用到某个模块的时候再去require。看代码://AMDdefine(["./a", "./b"], function(a, b){ //依赖必须一开始就写好a.doSomething()//此处略去 100 行b.doSomething()...});//CMDdefine(function(require, exports, mole){var a = require("./a")a.doSomething()//此处略去 100 行var b = require("./b")//依赖可以就近书写b.doSomething()//...});3、AMD 的 API 默认是一个当多个用,CMD 的 API 严格区分,推崇职责单一。五:模块化进程五:ES6模块化EcmaScript6标准增加了JavaScript语言层面的模块体系定义。ES6 模块的设计思想,是尽量的静态化,使得编译时就能确定模块的依赖关系,以及输入和输出的变量。CommonJS和AMD模块,都只能在运行时确定这些东西。在 ES6 中,我们使用export关键字来导出模块,使用import关键字引用模块。需要说明的是,ES6的这套标准和目前的标准没有直接关系,目前也很少有JS引擎能直接支持。因此Babel的做法实际上是将不被支持的import翻译成目前已被支持的require。尽管目前使用import和require的区别不大(本质上是一回事),但依然强烈推荐使用import关键字,因为一旦JS引擎能够解析ES6的import关键字,整个实现方式就会和目前发生比较大的变化。如果目前就开始使用import关键字,将来代码的改动会非常小。示例:import "jquery";export functiondoStuff(){}mole "localMole" {}优点:1、容易进行静态分析2、面向未来的 EcmaScript 标准缺点:1、原生浏览器端还没有实现该标准2、全新的命令字,新版的 Node.js才支持
Q3:C++继承与组合部分的作业题,求高手帮忙
#include using namespace std; class Sofa {public: void WatchTV() { cout<<"I am watching TV in sofa"<<endl; }};class Bed {public: void Sleep() { cout<<"I am sleeping TV on bed"<<endl; } void SetWeight(int weight) { m_weight = weight; } int getWeight() const { return m_weight; }private: int m_weight;};class SofaBed :public Sofa, Bed { public: void Sleep() { cout<<"I am sleeping TV on sofabed"<<endl; } void SetWeight(int weight) { m_weight = weight; } void FoldOut() { } void WatchTV() { cout<<"I am watching TV in sofabed"<Sleep(); delete pBed; pSofa = new SofaBed(); pSofa->WatchTV(); delete pSofa; return 0;}
Q4:JS组合继承中的constructor属性问题
为了覆盖,原型里面是什么都没有的,你想让自己写的东西成为原型里面的并且被之后的继承着都可以使用那么就需要覆盖原型里面的方法进行重写
Q5:有个难题, 重新组合家庭的遗产继承问题
继父的子女没有不动产权。那套共有的房子不会按照你说的比例分割。
Q6:组合家庭的财产分配继承问题
按照新修订的婚姻法的规定,判断夫妻共同财产的标准就是以办理结婚登记手续为时间标准.即婚前取得的财产为个人财产,婚后取得的财产为夫妻共同财产. 象你所说的,你妈妈婚前有栋房子,那么,该房屋在变卖以后所得的款项同样也是属于婚前财产.至于你说的继父的房子,如果也是继父在婚前取得,是不能作为夫妻共同财产来认定的,但这并不等于当你继父不在时你母亲不享有继承权啊.在你继父没有留下遗嘱的情况下,他的遗产(包括该房屋)由其第一顺序的法定继承人平均继承,即由你继父的配偶,父母,子女平均继承.从你讲的情况看,继父只有二个女儿,因此,如果发生法定继承时,你妈妈与继承的二个女儿共同继承你继父的遗产,其中的房屋是各占三分之一的.至于说你妈妈的那笔钱,是否要拿出来共同使用,可以由她自己来决定,因为这是你妈妈婚前个人财产,她享有完全的处分权,想怎么用都可以的.既然你这么担心,可以要你妈妈将该笔款项保存起来,以便今后急用.如还有不明之处,可发消息进一步询问.