百姓网NeoForm.js关键原理分析

王cb 2017-06-11 12:42:08
百姓网的房源发布等页面用的是一种名NeoForm模块化框架这个框架有一个导出全局构造器,具体实例化方法var form = new NeoForm.NeoForm($('#bxForm'), NEO_CONFIG, NEO_DATASOURCE);,这个框架有个特点是它内部模块实现都在它的内部无法直接访问,好在他有个导出模块函数getPlugins,但是导出的是function类型,不是具体实例化对象,不过没关系,

,下面我们来分析它的具体实现关键部分,源码(具体全部源码可在http://s.baixing.net/w/neoform-fang.b3fbcbd5.js下载全部内容)

var NeoForm = function(t) {
function e(r) {
if (n[r])
return n[r].exports;
var o = n[r] = {
i: r,
l: !1,
exports: {}
};
return t[r].call(o.exports, o, o.exports, e),
o.l = !0,
o.exports
}
var n = {};
return e.m = t,
e.c = n,
e.i = function(t) {
return t
}
,
e.d = function(t, n, r) {
e.o(t, n) || Object.defineProperty(t, n, {
configurable: !1,
enumerable: !0,
get: r
})
}
,
e.n = function(t) {
var n = t && t.__esModule ? function() {
return t["default"]
}
: function() {
return t
}
;
return e.d(n, "a", n),
n
}
,
e.o = function(t, e) {
return Object.prototype.hasOwnProperty.call(t, e)
}
,
e.p = "",
e(e.s = 102)
}([function(t, e, n) {([//function1},function(t, e, n) {([//function2},(中间省略),,,, function(t, e, n) {
//function103
"use strict";
var r = this && this.__extends || function() {
var t = Object.setPrototypeOf || {
__proto__: []
}instanceof Array && function(t, e) {
t.__proto__ = e
}
|| function(t, e) {
for (var n in e)
e.hasOwnProperty(n) && (t[n] = e[n])
}
;
return function(e, n) {
function r() {
this.constructor = e
}
t(e, n),
e.prototype = null === n ? Object.create(n) : (r.prototype = n.prototype,
new r)
}
}();
e.__esModule = !0;
var o = n(4)
, i = n(34)
, a = n(20)
, s = n(42)
, l = n(33)
, u = n(41)
, c = n(16)
, p = n(43)
, h = n(39)
, d = n(29)
, f = n(40)
, m = n(91)
, v = n(56)
, g = n(11)
, y = n(12)
, _ = function(t) {
function e() {
return null !== t && t.apply(this, arguments) || this
}
return r(e, t),
e.prototype.getPlugins = function() {
return [s.PostAuth, i.Contact, a.Relation, v.Fang, l.Area, u.Liuma, m.QualityView, c.HardCode, p.PostTracker, h.AutoGen, d.AutoFill, f.AutoSave]
}
,
e.prototype.getControlFactory = function() {
return g.ControlFactory
}
,
e.prototype.getLayoutManager = function() {
return y.layoutManager
}
,
e
}(o.NeoForm);
e.NeoForm = _
}
]);

NeoForm 的主函数也就是构造函数内部是一个function e(r)这个函数作用是构造模块用的,
NeoForm 的主函数 最后的return里面最后的值是e(e.s = 102),也就是e(102),这个102是什么用的呢,传给主函数
NeoForm的参数是[function(t, e, n){},,,]数组,总共个数 是103个,所以NeoForm默认导出模块就说它,那t,e,n又是什么呢,
仔细看NeoForm里面 function e(r),它的return的 t[r].call(o.exports, o, o.exports, e),
o.l = !0,
o.exports
}这个实际作用就是这个103个function每个都是它的参数r,而t就说传给NeoForm 的参数也就说它自己 t[r].call(o.exports, o, o.exports, e),这句话实际意义就是function(t, e, n)的参数t=o,e=o.exports,n=e(也就说这个关键e),n(41), n(16)---整个js里面这样的用处也就是n(索引)就是调用了e,而e的第一个return:if (n[r])
return n[r].exports;就实现了模块导出,下面我们来分析一下
NeoForm默认导出模块(下面称作默认模块),它里面有个var r,比较简单就说参数为e, n,e为构造函数,n为prototype,然后实例化对象new ()|Object.create(n),
最后关键的_ = function(t),这个t就是
103个function其中的一个(o.NeoForm),o = n(4),也就说第四个模块,实际上这个就是NeoFormd基类,默认模块的内部有个 function e() {
return null !== t && t.apply(this, arguments) || this
},这个实际上就是吧t作为构造函数给他的arguments, apply一下,然后用var r实例化这个t就说new e这个function,(实例化产生的就是基类),给他绑定3个prototype
[
getControlFactory,
getLayoutManager,
getPlugins],这里的里面的this指的就是NeoForm基类也就说绑定基类方法,那之类也就是其他模块是怎么实现的呢?就是在默认模块中使用n(索引)也就是e(索引)实现,
相当于执行每个(function(t, e, n))(),最后说下总结一下NeoForm 的默认模块定义了:
e.NeoForm = _,也就是主函数里面的 o.exports=e,即NeoForm 的主函数返回o.exports=e,所以调用NeoFormd方法就变成new NeoForm.NeoForm(),参数是基类的e, n,也就是在html中看到的结果,分析到这里,这个NeoForm优点是使用嵌套的方式实现自己的子模块,实现方式比较巧妙,缺点是需要导出才能被外部访问,但是内部模块实例化需要在默认模块中主动调用实现
...全文
148 回复 打赏 收藏 转发到动态 举报
写回复
用AI写文章
回复
切换为时间正序
请发表友善的回复…
发表回复
内容概要:本文研究基于粒子群算法(PSO)优化模糊C均值聚类(FCM)的居民用电行为分析方法,提出一种改进的FCM聚类算法,通过引入粒子群优化机制,有效提升聚类性能与收敛效率,克服传统FCM算法易陷入局部最优、对初始聚类中心敏感等缺陷。研究基于Matlab平台实现算法代码,对居民用电负荷数据进行聚类分析,识别不同用户的典型用电模式与行为特征,进而支持电力系统的需求侧精细化管理、用户分群运营、个性化用电服务推荐以及中长期负荷预测。该方法在智能电网与大数据背景下展现出良好的应用前景,特别适用于大规模居民用电数据的行为挖掘与模式识别任务。; 适合人群:具备一定电力系统基础知识、数据挖掘或智能优化算法背景的科研人员及工程技术人员,尤其适合从事智能电网、负荷特性分析、需求响应、用户行为研究等方向的硕士、博士研究生及高校教师。; 使用场景及目标:①实现居民用户用电行为的有效分类与典型负荷曲线提取;②优化电力客户细分策略,支撑差异化电价、需求响应激励政策的设计与实施;③为负荷预测、电网规划、配电台区管理提供数据驱动的决策依据;④作为高水平学术论文(如EI、SCI期刊)的研究基础,用于算法复现、性能对比与创新改进。; 阅读建议:建议读者结合提供的Matlab代码深入理解PSO-FCM算法的具体实现流程,重点关注粒子编码方式、适应度函数构建、聚类有效性评价指标(如轮廓系数、误差平方和)的应用,鼓励在真实用电数据集上进行实验验证,并尝试引入其他优化策略或评估维度以进一步提升模型鲁棒性与实用性。
【重要提示】本资源设置为0积分下载,若非0积分请勿轻易下载 亲爱的CSDN用户: 首先感谢你点进这个资源页面。我需要提前说明一个重要情况: 本资源原本已设置为“0积分下载”,即作者希望完全免费共享。但CSDN平台有时会根据文件的下载热度、文件大小、用户权限等因素,自动将部分资源的积分调整为非0数值(如1积分、2积分、5积分等)。这是平台系统的自动行为,而非作者本人的设定。 因此,如果你当前看到该资源的下载所需积分不是0(例如显示为1、2、3……),请谨慎决定是否下载。 如果你按照非0积分支付并下载后发现资源内容不符合预期、链接失效,或者实际上该资源本应是免费的,作者无法为此承担积分损失或退还操作。强烈建议:仅在页面显示为0积分时进行下载。 另外,本资源描述中并未直接提供具体的下载地址或外部链接,因为它本身是一个通过CSDN官方上传通道提交的文件/内容包。如果你看到描述中没有外部网盘地址,这是正常的——资源文件应通过CSDN内置的“下载”按钮获取。若因平台积分显示异常导致你支付了积分,请优先联系CSDN客服咨询积分退还政策,作者没有权限修改平台自动设定的积分值。 感谢你的理解与支持。技术分享本应开放,但受限于平台规则,特此提醒如上。祝学习进步!
代码转载自:https://pan.quark.cn/s/a1913ccaa47a 在信息技术领域中,图像处理占据着核心地位,特别是在嵌入式系统以及移动设备上,由于受到资源条件的制约,常常需要将高分辨率的图像格式转化为低分辨率的格式,以此来提升显示效能和存储容量。"bmp格式转为rgb565格式图片转换工具"正是为了应对这种需求而研发的。BMP(Bitmap)是一种广泛应用的位图格式,它完整地记录了图像的每一个像素点信息,涵盖了色彩深度、透明度等参数。然而,这种格式在内存消耗和处理速率方面并不具备优势,尤其是在需要高速渲染的情境下。RGB565是一种16位的色彩编码格式,普遍应用于嵌入式系统,例如由微控制器控制的LCD显示屏。它通过分配5位红色、6位绿色以及5位蓝色分量来表现色彩,总共能够呈现2^16 = 65536种色彩,尽管其色彩数量(约1670万种)少于BMP的24位色彩,但足以满足绝大多数显示场景,并且显著降低了数据存储和传输的负担。这种转换工具的运作机制在于读取BMP文件中的每一个像素点,然后依照RGB565的编码规范重新组织色彩信息。在BMP文件中,像素数据一般以行为单位进行存储,遵循从左到右、自下而上的顺序。而在RGB565格式中,每个像素点由两个字节构成,其中红色和蓝色各占5位,绿色占据6位,这样的布局旨在提升内存中的对齐效率。转换流程通常包括以下几个环节:1. 分析BMP文件头部:BMP文件头部包含了图像的宽度、高度、色彩深度等关键数据,这是进行转换的依据。2. 获取像素数据:按照BMP文件的结构读取每一行的像素点信息。3. 色彩转换:将每个24位RGB色彩点转换为16位RGB565格式。4. 输出新格式:将转换后的RGB565数据写入新的...
内容概要:本文系统研究了基于合作博弈理论的综合能源系统利益分配优化调度方法,并配套提供了完整的Matlab代码实现。针对多个能源主体协同运行场景下的利益分配难题,文章构建了严谨的合作博弈模型,结合优化调度算法,在实现系统整体经济效益最大化的同时,确保各参与方之间的利益分配公平合理。研究内容涵盖模型的数学建模、理论推导、求解流程设计及仿真验证全过程,重点突出了Shapley值等经典博弈分配方法在能源系统中的应用,具有较强的理论深度与工程实践价值,适用于致力于高水平学术研究(如EI/SCI论文撰写)的科研人员。; 适合人群:具备电力系统、优化理论及博弈论基础知识,从事综合能源系统调度、分布式能源协同管理、能源互联网经济性分析等方向研究的硕士、博士研究生及高校科研人员。; 使用场景及目标:①用于多主体综合能源系统中利益分配机制的设计与仿真分析;②支撑高质量学术论文的撰写、复现与创新;③为实际能源项目中的协调调度决策与经济性评估提供理论依据与技术工具支持。; 阅读建议:建议读者结合Matlab代码逐模块研读,深入理解合作博弈模型与优化调度算法的耦合逻辑,重点关注Shapley值等分配机制的计算实现,并可通过调整参数或拓展模型结构进行二次开发与对比实验。

87,990

社区成员

发帖
与我相关
我的任务
社区描述
Web 开发 JavaScript
社区管理员
  • JavaScript
  • 无·法
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧