`
huangyongxing310
  • 浏览: 498489 次
  • 性别: Icon_minigender_1
  • 来自: 广州
文章分类
社区版块
存档分类
最新评论

dataViewCommonJs

 
阅读更多
// var _elementIdToDataMap={};


var commonDebugFlag = true;

//视图数据改变通用处理(更新数据对象里的值)
function commonOnchangeFun(elementId) {
	commonDebug(elementId, "commonOnchangeFun elementId");
	var value = getElementVal("#" + elementId);
	commonDebug(value, "commonOnchangeFun value");
	var data = dataViewCommonJs.elementIdToDataMap[elementId].data;
	commonDebug(data, "commonOnchangeFun data");
	var field = dataViewCommonJs.elementIdToDataMap[elementId].field;
	commonDebug(field, "commonOnchangeFun field");

	//更新数据对象里的值
	data[field]=value;
}


// var initDataPage = {
// 	defaultFormValue:data,
// 	formValue:{},
// 	modelId:"app",
// 	formFieldDes:{}
// };
// formDataInit(initDataPage);


function commonFormDataInit(initData) {
	// var defaultFormValue=deepClone(initData.defaultFormValue);
	var formValue=deepClone(initData.defaultFormValue);
	initData.formValue=formValue;
	observe(initData.formValue,initData,initData.modelId);
	//
	//初始值进行一次赋值
	// objToObjByField(defaultFormValue,initData.formValue);

	commonDebug(dataViewCommonJs.elementIdToDataMap, "formDataInit elementIdToDataMap");
	commonDebug(initData.formValue, "formDataInit data");
};

//
function observe(data,initData,modelId) {
	if (!data || typeof data !== 'object') {
		return;
	}
	// 取出所有属性遍历
	var keys= Object.keys(data);
	commonDebug(keys, "observe keys");

	for(var i=0 ;i<keys.length;i++){
		var key = keys[i];
		var  modelIdTemp = modelId + "_" + key;
		commonDebug(modelIdTemp, "observe modelIdTemp");
		//=====================
		if (data._fieldInfoObject === undefined) {
			data._fieldInfoObject = {};
		}
		data._fieldInfoObject[key] = {
			// _initData:initData,
			fieldToElementId:modelIdTemp,
			formFieldDes:initData.formFieldDes,
		};

		//=====================Watch
		if (data._fieldWatchObject === undefined) {
			data._fieldWatchObject = {};
		}
		data._fieldWatchObject[key] = {
			// _initData:initData,
			// fieldToElementId:modelIdTemp,
			// formFieldDes:initData.formFieldDes,
			watchFunList:[],
		};
		//=====================

		//=====================
		if(dataViewCommonJs.elementIdToDataMap[modelIdTemp]!=undefined){
			throw modelIdTemp+"已经存在!"
		}

		dataViewCommonJs.elementIdToDataMap[modelIdTemp] = {data:data,field:key};

		//=====================

		defineReactive(data, key, data[key],initData,modelIdTemp);
	}
};

function defineReactive(data, key, val,initData,modelId) {
	observe(val,initData,modelId); // 监听子属性
	Object.defineProperty(data, key, {
		enumerable : true, // 可枚举
		configurable : false, // 不能再define
		get : function () {
			commonDebug("key = " + key + ",val = " + val, "defineReactive get");
			return val;
		},
		set : function (newVal) {
			commonDebug("key = " + key + ",newVal = " + newVal, "defineReactive set");
			var oldVal =val;
			val = newVal;
			//============
			commonFieldWatchDeal(key,data,newVal,oldVal);
			//============
			commonUpdateView(key,data);
		}
	});
}


function commonFieldWatchDeal(key,data,newVal,oldVal) {
	// commonDebug(field, "updateView field");


	var watchFunList = data._fieldWatchObject[key].watchFunList;

	if(watchFunList.length==0){
		return;
	}

	// commonDebug(key, "commonFieldWatchDeal key");

	for(var i=0 ;i<watchFunList.length;i++){
		commonDebug(key, "commonFieldWatchDeal key");
		watchFunList[i](newVal,oldVal);
	}
}


function commonUpdateView(field,data) {
	commonDebug(field, "updateView field");
	commonDebug(data, "updateView data");

	var fieldInfoObject = data._fieldInfoObject[field];
	var fieldToElementId = fieldInfoObject.fieldToElementId;
	// var ElementId = fieldToElementIdMap[field];
	// setElementVal('#' + fieldToElementId, data[field]);

	commonUpdateViewDeal(fieldToElementId,field,data);
}

function commonUpdateViewDeal(elementId,field,data) {
	setElementVal('#' + elementId, data[field]);
}


function commonAddWatch(fieldString,initData,fun) {
	var fieldStringTemp = replaceAll(fieldString,"\\.","_");
	var key = initData.modelId  +"_"  + fieldStringTemp;
	if(dataViewCommonJs.elementIdToDataMap[key]==undefined){
		throw "请先调用commonFormDataInit进行初始化"
	}
	var data = dataViewCommonJs.elementIdToDataMap[key].data;
	commonDebug(data, "commonAddWatch data");
	var field = dataViewCommonJs.elementIdToDataMap[key].field;
	commonDebug(field, "commonAddWatch field");
	if(data._fieldWatchObject[field]==undefined){
		throw "请先调用commonFormDataInit进行初始化"
	}
	var watchFunList = data._fieldWatchObject[field].watchFunList;
	commonDebug(watchFunList, "commonAddWatch watchFunList");
	if(watchFunList==undefined){
		throw "请先调用commonFormDataInit进行初始化"
	}
	if(fun){
		watchFunList.push(fun)
	}else{
		throw "请先输入正确的回调函数"
	}
}



var dataViewCommonJs={
	//全部存放id对应的数据对象和字段名,commonOnchangeFun里进行使用
	elementIdToDataMap:{},
	commonOnchangeFun:commonOnchangeFun,
	commonFormDataInit:commonFormDataInit,
	commonAddWatch:commonAddWatch,


}









<!DOCTYPE html>
<html lang="en">
<head>
	<meta charset="UTF-8">
	<title>Title</title>
	<script src="../../miniui/scripts/jquery-1.11.1.min.js" type="text/javascript"></script>
	<script src="../commonJs.js" type="text/javascript"></script>
	<script src="../jqCommonJs.js" type="text/javascript"></script>
	<script src="./dataViewCommonJs.js" type="text/javascript"></script>
<!--	dataViewCommonJs-->

	<style>

	</style>


</head>
<body>

<div id="app">
	<input type="text" id="app_name" onchange="dataViewCommonJs.commonOnchangeFun(this.id)">

	<input type="text" id="app_test_id" onchange="dataViewCommonJs.commonOnchangeFun(this.id)">
	<p id="show-txt"></p>
</div>

</body>

</html>
<script type="text/javascript">

	// var modelDataIdMap = {
	// 	app_name : {
	// 		id : "app_name",
	// 		modelDataField : "name",
	// 		type : 'input',
	// 		modelData : data,
	// 	}
	//
	// }

	//全部存放id对应的数据对象和字段名,commonOnchangeFun里进行使用
	// var _elementIdToDataMap={};


	// //视图数据改变通用处理(更新数据对象里的值)
	// function commonOnchangeFun(elementId) {
	// 	commonDebug(elementId, "commonOnchangeFun elementId");
	// 	var value = getElementVal("#" + elementId);
	// 	commonDebug(value, "commonOnchangeFun value");
	// 	var data = _elementIdToDataMap[elementId].data;
	// 	commonDebug(data, "commonOnchangeFun data");
	// 	var field = _elementIdToDataMap[elementId].field;
	// 	commonDebug(field, "commonOnchangeFun field");
	//
	// 	//更新数据对象里的值
	// 	data[field]=value;
	// }

	var ss =[];
	commonDebug(ss, "commonAddWatch ss");

	ss.push(function () {

	})
	var data = {
		name : 'kindeng',
		test : {id : '22'},
		fsize : '4545'
	};

	var initDataPage = {
		defaultFormValue:data,
		formValue:data,
		modelId:"app",
		formFieldDes:{}
	};

	dataViewCommonJs.commonFormDataInit(initDataPage);

	initDataPage.formValue.name="shdjfh";

	// var applyINfoData = {
	// 	app : {
	// 		modelKey : 'app',
	// 		modelDataDes : {},
	// 		modelData : data,
	// 	}
	//
	// }

	// dataViewCommonJs.commonAddWatch('name',initDataPage,function (newVal,oldVal) {
	// 	commonConsole(newVal, "commonAddWatch newVal");
	// 	commonConsole(oldVal, "commonAddWatch oldVal");
	//
	// 	initDataPage.formValue.fsize = 'aadd';
	// })

	dataViewCommonJs.commonAddWatch('test.id',initDataPage,function (newVal,oldVal) {
		commonConsole(newVal, "commonAddWatch newVal");
		commonConsole(oldVal, "commonAddWatch oldVal");

		initDataPage.formValue.name = 'aadd';
	})

	// dataViewCommonJs.commonAddWatch('fsize',initDataPage,function (newVal,oldVal) {
	// 	commonConsole(newVal, "commonAddWatch newVal");
	// 	commonConsole(oldVal, "commonAddWatch oldVal");
	//
	// 	// initDataPage.formValue.name = 'aaddsdasdas';
	// })




	// formDataInit(initDataPage);
	//
	// function formDataInit(initData) {
	//
	// 	observe(initData.formValue,initData,initData.modelId);
	// 	commonDebug(_elementIdToDataMap, "_elementIdToDataMap");
	// 	//
	// 	// commonDebug(initData.formValue, "initData.formValue");
	// 	commonDebug(initData.formValue, "initData.formValue");
	// };
	//
	//
	// function observe(data,initData,modelId) {
	// 	if (!data || typeof data !== 'object') {
	// 		return;
	// 	}
	// 	// 取出所有属性遍历
	// 	var keys= Object.keys(data);
	// 	commonDebug(keys, "keys");
	//
	// 	for(var i=0 ;i<keys.length;i++){
	// 		var key = keys[i];
	// 	// for(var key in data){
	// 	// 	if (initData.watchFunList === undefined) {
	// 	// 		initData.watchFunList = {};
	// 	// 	}
	// 	// 	initData.watchFunList[key] = function ( key,data,initData) {
	// 	// 		commonDebug("sub", "sub");
	// 	// 	}
	//
	// 		// for(var key in data){
	// 		var  modelIdTemp = modelId + "_" + key;
	//
	// 		//=====================
	// 			if (data._fieldInfoObject === undefined) {
	// 				data._fieldInfoObject = {};
	// 			}
	// 			data._fieldInfoObject[key] = {
	// 				// _initData:initData,
	// 				fieldToElementId:modelIdTemp,
	// 				formFieldDes:initData.formFieldDes,
	// 			};
	//
	// 		//=====================
	// 		// if (initData._fieldToElementIdMap === undefined) {
	// 		// 	initData._fieldToElementIdMap = {};
	// 		// }
	// 		//
	// 		// // var  modelIdTemp = modelId + "_" + key;
	// 		// initData._fieldToElementIdMap[key] = modelIdTemp;
	// 		//=====================
	// 		_elementIdToDataMap[modelIdTemp] = {data:data,field:key};
	//
	// 		defineReactive(data, key, data[key],initData,modelIdTemp);
	// 	}
	//
	//
	// 	// Object.keys(data).forEach(function (key,initData) {
	// 	// 	if (data.watchFunList === undefined) {
	// 	// 		data.watchFunList = {};
	// 	// 	}
	// 	// 	data.watchFunList[key] = function ( key,data,initData) {
	// 	// 		commonDebug("sub", "sub");
	// 	// 	}
	// 	//
	// 	// 	if (data.fieldToElementIdMap === undefined) {
	// 	// 		data.fieldToElementIdMap = {};
	// 	// 	}
	// 	// 	data.fieldToElementIdMap[key] = initData.modelId + "_" + key;
	// 	//
	// 	// 	defineReactive(data, key, data[key],initData);
	// 	// });
	// };
	//
	// function defineReactive(data, key, val,initData,modelId) {
	// 	observe(val,initData,modelId); // 监听子属性
	// 	Object.defineProperty(data, key, {
	// 		enumerable : true, // 可枚举
	// 		configurable : false, // 不能再define
	// 		get : function () {
	// 			commonDebug("key = " + key + ",val = " + val, "defineProperty get");
	// 			return val;
	// 		},
	// 		set : function (newVal) {
	// 			commonDebug("key = " + key + ",newVal = " + newVal, "defineProperty set");
	// 			val = newVal;
	//
	// 			updateView(key,data);
	// 		}
	// 	});
	// }
	//
	// function updateView(field,data) {
	// 	commonDebug(field, "updateView field");
	// 	commonDebug(data, "updateView data");
	//
	// 	var fieldInfoObject = data._fieldInfoObject[field];
	// 	var fieldToElementId = fieldInfoObject.fieldToElementId;
	// 	// var ElementId = fieldToElementIdMap[field];
	//
	// 	setElementVal('#' + fieldToElementId, data[field]);
	// }
	//
	// function Dep() {
	// 	this.subs = [];
	// }
	//
	// Dep.prototype = {
	// 	addSub : function (sub) {
	// 		this.subs.push(sub);
	// 	},
	// 	notify : function () {
	// 		this.subs.forEach(function (sub) {
	// 			sub.update();
	// 		});
	// 	}
	// };




	// commonDebug(data, "data");
	// observe(data);
	// data.name = 'dmq'; // 哈哈哈,监听到值变化了 kindeng --> dmq
	// data.name = 'dmq2'; // 哈哈哈,监听到值变化了 kindeng --> dmq
	// data.name = 'dmq3'; // 哈哈哈,监听到值变化了 kindeng --> dmq
	// data.name = 'dmq4'; // 哈哈哈,监听到值变化了 kindeng --> dmq
	// data.name = 'dmq5'; // 哈哈哈,监听到值变化了 kindeng --> dmq
	// var dd = data.name;
	// commonDebug(dd, "dd");
	//
	// data.name = 'aadd'; // 哈哈哈,监听到值变化了 kindeng --> dmq
	// var dd = data.name;
	// commonDebug(dd, "dd");
	// commonDebug(data, "data");



	// var obj = {}
	// Object.defineProperty(obj, 'txt', {
	// 	get: function () {
	// 		return obj
	// 	},
	// 	set: function (newValue) {
	// 		document.getElementById('txt').value = newValue
	// 		document.getElementById('show-txt').innerHTML = newValue
	// 	}
	// })
	// document.addEventListener('keyup', function (e) {
	// 	obj.txt = e.target.value
	// })

</script>
















// var _elementIdToDataMap={};


var commonDebugFlag = true;

//视图数据改变通用处理(更新数据对象里的值)
function commonOnchangeFun(elementId) {
	commonDebug(elementId, "commonOnchangeFun elementId");
	var value = getElementVal("#" + elementId);
	commonDebug(value, "commonOnchangeFun value");
	var data = dataViewCommonJs.elementIdToDataMap[elementId].data;
	commonDebug(data, "commonOnchangeFun data");
	var field = dataViewCommonJs.elementIdToDataMap[elementId].field;
	commonDebug(field, "commonOnchangeFun field");

	//更新数据对象里的值
	data[field]=value;
}


// var initDataPage = {
// 	defaultFormValue:data,
// 	formValue:{},
// 	modelId:"app",
// 	formFieldDes:{}
// };
// formDataInit(initDataPage);


function commonFormDataInit(initData) {
	// var defaultFormValue=deepClone(initData.defaultFormValue);
	var formValue=deepClone(initData.defaultFormValue);
	initData.formValue=formValue;
	observe(initData.formValue,initData,initData.modelId,initData.formFieldDes);
	//
	//初始值进行一次赋值
	// objToObjByField(defaultFormValue,initData.formValue);

	commonDebug(dataViewCommonJs.elementIdToDataMap, "formDataInit elementIdToDataMap");
	commonDebug(initData.formValue, "formDataInit data");
};

//
function observe(data,initData,modelId,formFieldDes) {
	if (!data || typeof data !== 'object') {
		return;
	}
	// 取出所有属性遍历
	var keys= Object.keys(data);
	commonDebug(keys, "observe keys");

	for(var i=0 ;i<keys.length;i++){
		var key = keys[i];
		var  modelIdTemp = modelId + "_" + key;
		commonDebug(modelIdTemp, "observe modelIdTemp");
		//=====================
		if (data._fieldInfoObject === undefined) {
			data._fieldInfoObject = {};
		}
		data._fieldInfoObject[key] = {
			// _initData:initData,
			fieldToElementId:modelIdTemp,
			formFieldDes:initData.formFieldDes,
		};

		//=====================Watch
		if (data._fieldWatchObject === undefined) {
			data._fieldWatchObject = {};
		}
		data._fieldWatchObject[key] = {
			// _initData:initData,
			// fieldToElementId:modelIdTemp,
			// formFieldDes:initData.formFieldDes,
			watchFunList:[],
		};
		//=====================

		//=====================
		if(dataViewCommonJs.elementIdToDataMap[modelIdTemp]!=undefined){
			throw modelIdTemp+"已经存在!"
		}

		var aa = formFieldDes[key];
		var bb = formFieldDes.id;
		dataViewCommonJs.elementIdToDataMap[modelIdTemp] = {data:data,field:key,dataFieldDes:formFieldDes[key]};

		//=====================

		defineReactive(data, key, data[key],initData,modelIdTemp,formFieldDes[key].formFieldDes);
	}
};

function defineReactive(data, key, val,initData,modelId,formFieldDes) {
	observe(val,initData,modelId,formFieldDes); // 监听子属性
	Object.defineProperty(data, key, {
		enumerable : true, // 可枚举
		configurable : false, // 不能再define
		get : function () {
			commonDebug("key = " + key + ",val = " + val, "defineReactive get");
			return val;
		},
		set : function (newVal) {
			commonDebug("key = " + key + ",newVal = " + newVal, "defineReactive set");
			var oldVal =val;
			val = newVal;
			//============
			commonFieldWatchDeal(key,data,newVal,oldVal);
			//============
			commonUpdateView(key,data);
		}
	});
}


function commonFieldWatchDeal(key,data,newVal,oldVal) {
	// commonDebug(field, "updateView field");


	var watchFunList = data._fieldWatchObject[key].watchFunList;

	if(watchFunList.length==0){
		return;
	}

	// commonDebug(key, "commonFieldWatchDeal key");

	for(var i=0 ;i<watchFunList.length;i++){
		commonDebug(key, "commonFieldWatchDeal key");
		watchFunList[i](newVal,oldVal);
	}
}


function commonUpdateView(field,data) {
	commonDebug(field, "updateView field");
	commonDebug(data, "updateView data");

	// var fieldInfoObject = data._fieldInfoObject[field];
	// var fieldToElementId = fieldInfoObject.fieldToElementId;
	// // var ElementId = fieldToElementIdMap[field];
	// // setElementVal('#' + fieldToElementId, data[field]);
	//
	// commonUpdateViewDeal(fieldToElementId,field,data);

	dataViewCommonJs.viewUpdateFlag=true;
}

function commonUpdateViewDeal(elementId,field,data) {
	setElementVal('#' + elementId, data[field]);
}


function commonAddWatch(fieldString,initData,fun) {
	var fieldStringTemp = replaceAll(fieldString,"\\.","_");
	var key = initData.modelId  +"_"  + fieldStringTemp;
	if(dataViewCommonJs.elementIdToDataMap[key]==undefined){
		throw "请先调用commonFormDataInit进行初始化"
	}
	var data = dataViewCommonJs.elementIdToDataMap[key].data;
	commonDebug(data, "commonAddWatch data");
	var field = dataViewCommonJs.elementIdToDataMap[key].field;
	commonDebug(field, "commonAddWatch field");
	if(data._fieldWatchObject[field]==undefined){
		throw "请先调用commonFormDataInit进行初始化"
	}
	var watchFunList = data._fieldWatchObject[field].watchFunList;
	commonDebug(watchFunList, "commonAddWatch watchFunList");
	if(watchFunList==undefined){
		throw "请先调用commonFormDataInit进行初始化"
	}
	if(fun){
		watchFunList.push(fun)
	}else{
		throw "请先输入正确的回调函数"
	}
}

function viewUpdateDealFun() {
	var keys = Object.keys(dataViewCommonJs.elementIdToDataMap);

	for(var i=0 ;i<keys.length;i++){
		var key = keys[i];
		var data = dataViewCommonJs.elementIdToDataMap[key].data;
		commonDebug(data, "commonAddWatch data");
		var field = dataViewCommonJs.elementIdToDataMap[key].field;
		commonDebug(field, "commonAddWatch data");
		// var field = dataViewCommonJs.elementIdToDataMap[key].field;
		// commonDebug(field, "commonAddWatch data");
		var fieldToElementId = key;
		commonUpdateViewDeal(fieldToElementId,field,data);
	}
}

function viewUpdateTimeoutFun() {
	// commonDebug("", "viewUpdateTimeoutFun");
	if(dataViewCommonJs.viewUpdateFlag==true){
		viewUpdateDealFun();
		dataViewCommonJs.viewUpdateFlag=false;
	}
	window.setTimeout(viewUpdateTimeoutFun, 300);
}



var dataViewCommonJs={
	viewUpdateFlag:false,//视图更新标志,true时才会进行视图数据更新
	viewUpdateTimeout:window.setTimeout(viewUpdateTimeoutFun, 300),
	//全部存放id对应的数据对象和字段名,commonOnchangeFun里进行使用
	elementIdToDataMap:{},
	commonOnchangeFun:commonOnchangeFun,
	commonFormDataInit:commonFormDataInit,
	commonAddWatch:commonAddWatch,


}








<!DOCTYPE html>
<html lang="en">
<head>
	<meta charset="UTF-8">
	<title>Title</title>
	<script src="../../miniui/scripts/jquery-1.11.1.min.js" type="text/javascript"></script>
	<script src="../commonJs.js" type="text/javascript"></script>
	<script src="../jqCommonJs.js" type="text/javascript"></script>
	<script src="./dataViewCommonJs.js" type="text/javascript"></script>
	<!--	dataViewCommonJs-->

	<style>

	</style>


</head>
<body>

<div id="app">
	<input type="text" id="app_name" onchange="dataViewCommonJs.commonOnchangeFun(this.id)">

	<input type="text" id="app_test_id" onchange="dataViewCommonJs.commonOnchangeFun(this.id)">
	<p id="show-txt"></p>
</div>

</body>

</html>
<script type="text/javascript">

	// var modelDataIdMap = {
	// 	app_name : {
	// 		id : "app_name",
	// 		modelDataField : "name",
	// 		type : 'input',
	// 		modelData : data,
	// 	}
	//
	// }

	//全部存放id对应的数据对象和字段名,commonOnchangeFun里进行使用
	// var _elementIdToDataMap={};

	// //视图数据改变通用处理(更新数据对象里的值)
	// function commonOnchangeFun(elementId) {
	// 	commonDebug(elementId, "commonOnchangeFun elementId");
	// 	var value = getElementVal("#" + elementId);
	// 	commonDebug(value, "commonOnchangeFun value");
	// 	var data = _elementIdToDataMap[elementId].data;
	// 	commonDebug(data, "commonOnchangeFun data");
	// 	var field = _elementIdToDataMap[elementId].field;
	// 	commonDebug(field, "commonOnchangeFun field");
	//
	// 	//更新数据对象里的值
	// 	data[field]=value;
	// }

	var ss = [];
	commonDebug(ss, "commonAddWatch ss");

	ss.push(function () {

	})
	var data = {
		name : 'kindeng',
		test : {
			id : '22',
			trt : 'sdsf'
		},
		fsize : '4545'
	};

	var initDataPage = {
		defaultFormValue : data,
		formValue : data,
		modelId : "app",
		formFieldDes : {
			name : {type : 'input'},
			fsize : {type : 'input_num'},
			test : {
				formFieldDes : {
					id : {type : 'tefst'},
					trt : {type : 'trt'}
				}
			},
		}
	};

	dataViewCommonJs.commonFormDataInit(initDataPage);

	initDataPage.formValue.name = "shdjfh";

	// var applyINfoData = {
	// 	app : {
	// 		modelKey : 'app',
	// 		modelDataDes : {},
	// 		modelData : data,
	// 	}
	//
	// }

	// dataViewCommonJs.commonAddWatch('name',initDataPage,function (newVal,oldVal) {
	// 	commonConsole(newVal, "commonAddWatch newVal");
	// 	commonConsole(oldVal, "commonAddWatch oldVal");
	//
	// 	initDataPage.formValue.fsize = 'aadd';
	// })

	dataViewCommonJs.commonAddWatch('test.id', initDataPage, function (newVal, oldVal) {
		commonConsole(newVal, "commonAddWatch newVal");
		commonConsole(oldVal, "commonAddWatch oldVal");

		initDataPage.formValue.name = 'aadd';
	})

	// dataViewCommonJs.commonAddWatch('fsize',initDataPage,function (newVal,oldVal) {
	// 	commonConsole(newVal, "commonAddWatch newVal");
	// 	commonConsole(oldVal, "commonAddWatch oldVal");
	//
	// 	// initDataPage.formValue.name = 'aaddsdasdas';
	// })


</script>




























分享到:
评论

相关推荐

    基于纯verilogFPGA的双线性差值视频缩放 功能:利用双线性差值算法,pc端HDMI输入视频缩小或放大,然后再通过HDMI输出显示,可以任意缩放 缩放模块仅含有ddr ip,手写了 ram,f

    基于纯verilogFPGA的双线性差值视频缩放 功能:利用双线性差值算法,pc端HDMI输入视频缩小或放大,然后再通过HDMI输出显示,可以任意缩放。 缩放模块仅含有ddr ip,手写了 ram,fifo 代码,可以较为轻松地移植到其他平台。 硬件平台:易灵思 ti60f225 EDA平台:efinity

    【java毕业设计】智慧社区智慧社区管理员密码修改与重置系统(源代码+论文+PPT模板).zip

    zip里包含源码+论文+PPT,有java环境就可以运行起来 ,功能说明: 文档开篇阐述了随着计算机技术、通信技术和网络技术的快速发展,智慧社区门户网站的建设成为了可能,并被视为21世纪信息产业的主要发展方向之一 强调了网络信息管理技术、数字化处理技术和数字式信息资源建设在国际竞争中的重要性。 指出了智慧社区门户网站系统的编程语言为Java,数据库为MYSQL,并实现了新闻资讯、社区共享、在线影院等功能。 系统设计与功能: 文档详细描述了系统的后台管理功能,包括系统管理模块、新闻资讯管理模块、公告管理模块、社区影院管理模块、会员上传下载管理模块以及留言管理模块。 系统管理模块:允许管理员重新设置密码,记录登录日志,确保系统安全。 新闻资讯管理模块:实现新闻资讯的添加、删除、修改,确保主页新闻部分始终显示最新的文章。 公告管理模块:类似于新闻资讯管理,但专注于主页公告的后台管理。 社区影院管理模块:管理所有视频的添加、删除、修改,包括影片名、导演、主演、片长等信息。 会员上传下载管理模块:审核与删除会员上传的文件。 留言管理模块:回复与删除所有留言,确保系统内的留言得到及时处理。

    基于51单片机的一个智能密码锁设计.7z

    基于51单片机的一个智能密码锁设计.7z

    《STM32单片机+2x180-SG90+2x360-SG90+OLED屏幕》源代码

    《基于STM32的舵机控制系统设计》毕业设计项目 1.STM32单片机+2x180_SG90+2x360_SG90+OLED屏幕 2.OLED屏幕显示舵机的方向、速度、角度各项数据 3.按键1:控制180度舵机正向转动角度      4.按键2:控制180度舵机反向转动角度 5.按键3:控制360度舵机正向转动并且控制舵机速度      6.按键4:控制360度舵机反向转动并且控制舵机速度 7.代码里面含有注释 8.硬件实物接上线就能直接运行

    pyside6-qml-modern-uiapp

    Pyside6+Qml+QtCreator做的桌面app

    基于深度堆叠卷积神经网络的图像融合详细文档+全部资料+优秀项目+源码.zip

    【资源说明】 基于深度堆叠卷积神经网络的图像融合详细文档+全部资料+优秀项目+源码.zip 【备注】 1、该项目是个人高分项目源码,已获导师指导认可通过,答辩评审分达到95分 2、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用! 3、本项目适合计算机相关专业(人工智能、通信工程、自动化、电子信息、物联网等)的在校学生、老师或者企业员工下载使用,也可作为毕业设计、课程设计、作业、项目初期立项演示等,当然也适合小白学习进阶。 4、如果基础还行,可以在此代码基础上进行修改,以实现其他功能,也可直接用于毕设、课设、作业等。 欢迎下载,沟通交流,互相学习,共同进步!

    基于卷积神经网络的语音识别声学模型的研究详细文档+全部资料+优秀项目+源码.zip

    【资源说明】 基于卷积神经网络的语音识别声学模型的研究详细文档+全部资料+优秀项目+源码.zip 【备注】 1、该项目是个人高分项目源码,已获导师指导认可通过,答辩评审分达到95分 2、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用! 3、本项目适合计算机相关专业(人工智能、通信工程、自动化、电子信息、物联网等)的在校学生、老师或者企业员工下载使用,也可作为毕业设计、课程设计、作业、项目初期立项演示等,当然也适合小白学习进阶。 4、如果基础还行,可以在此代码基础上进行修改,以实现其他功能,也可直接用于毕设、课设、作业等。 欢迎下载,沟通交流,互相学习,共同进步!

    IndexOutOfBoundsException(解决方案).md

    IndexOutOfBoundsException(解决方案)

    Mini-Imagenet数据集文件

    Mini-Imagenet数据集文件

    时间转换工具(BD时、GPS时、UTC时、北京时间相互转换,可计算日期)

    时间转换工具(BD时、GPS时、UTC时、北京时间相互转换,可计算日期)

    基于CNN神经网络实现的正方教务系统的验证码识别资料齐全+高分项目+文档+源码.zip

    【资源说明】 基于CNN神经网络实现的正方教务系统的验证码识别资料齐全+高分项目+文档+源码.zip 【备注】 1、该项目是个人高分项目源码,已获导师指导认可通过,答辩评审分达到95分 2、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用! 3、本项目适合计算机相关专业(人工智能、通信工程、自动化、电子信息、物联网等)的在校学生、老师或者企业员工下载使用,也可作为毕业设计、课程设计、作业、项目初期立项演示等,当然也适合小白学习进阶。 4、如果基础还行,可以在此代码基础上进行修改,以实现其他功能,也可直接用于毕设、课设、作业等。 欢迎下载,沟通交流,互相学习,共同进步!

    西北工业大学 人工智能程序设计 Python NOJ程序源代码.zip

    西北工业大学 人工智能程序设计 Python NOJ程序源代码.zip

    车辆、飞机、船检测12-YOLO(v5至v11)、COCO、CreateML、TFRecord、VOC数据集合集.rar

    车辆、飞机、船检测12-YOLO(v5至v11)、COCO、CreateML、TFRecord、VOC数据集合集.rar对象检测分配-V2 2024-03-10 7:04 pm ============================= *与您的团队在计算机视觉项目上合作 *收集和组织图像 *了解和搜索非结构化图像数据 *注释,创建数据集 *导出,训练和部署计算机视觉模型 *使用主动学习随着时间的推移改善数据集 对于最先进的计算机视觉培训笔记本,您可以与此数据集一起使用 该数据集包括2992张图像。 以可可格式注释船舶飞机。 将以下预处理应用于每个图像: *像素数据的自动取向(带有Exif-Arientation剥离) *调整大小为640x640(拉伸) 没有应用图像增强技术。

    基于SpringBoot2/3+Sa-Token+Mybatis-Plus和Vue3+Ant Design Vue+Uni-App+Uni-UI,并以高质量代码为核心,简洁、高效、安全的快速开发平台

    SmartAdmin以「高质量代码」为核心,「简洁、高效、安全」的快速开发平台;基于SpringBoot2/3+Sa-Token+Mybatis-Plus和Vue3 +Ant Design Vue+UniApp (提供JavaScript和TypeScript双版本、Java8和java17双版本);满足三级等保、网络安全、数据安全等功能要求。并重磅开源千余家企业在使用的《高质量代码规范》等

    计算机语言学中并查集数据结构的C++实现

    欢迎下载

    jsp基于WEB操作系统课程教学网站的设计与实现(源代码+论文)(2024i6).7z

    1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于计算机科学与技术等相关专业,更为适合;

    基于常规波束形成的时间窗方法以及基于卷积神经网络的时间窗方法水下目标方位估计算法详细文档+全部资料+优秀项目+源码.zip

    【资源说明】 基于常规波束形成的时间窗方法以及基于卷积神经网络的时间窗方法水下目标方位估计算法详细文档+全部资料+优秀项目+源码.zip 【备注】 1、该项目是个人高分项目源码,已获导师指导认可通过,答辩评审分达到95分 2、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用! 3、本项目适合计算机相关专业(人工智能、通信工程、自动化、电子信息、物联网等)的在校学生、老师或者企业员工下载使用,也可作为毕业设计、课程设计、作业、项目初期立项演示等,当然也适合小白学习进阶。 4、如果基础还行,可以在此代码基础上进行修改,以实现其他功能,也可直接用于毕设、课设、作业等。 欢迎下载,沟通交流,互相学习,共同进步!

    html+css网页设计 美食 蛋糕美食7个页面

    预览地址:https://blog.csdn.net/qq_42431718/article/details/144633992 html+css网页设计 美食 蛋糕美食7个页面

    Python&OpenCV手势识别系统(完整源码&自定义UI操作界面&视频教程)

    Python高分毕设——Python&Opencv手势识别系统(完整源码&自定义UI操作界面&视频教程) Python高分毕设——Python&Opencv手势识别系统(完整源码&自定义UI操作界面&视频教程) 使用了OpenCV的视频采集, 图像色域转换, 颜色通道分割, 高斯滤波, OSTU自动阈值, 凸点检测, 边缘检测, 余弦定理计算手势等功能. 准备工作 安装 Python-OpenCV 库 pip install opencv-python -i https://mirrors.ustc.edu.cn/pypi/web/simple 利用 -i 为pip指令镜像源, 这里使用电子科技大学的源, 速度比官方源更快. 安装 Numpy 科学计算库 pip install numpy -i https://mirrors.ustc.edu.cn/pypi/web/simple 安装 PyAutogui 库 pip install pyautogui -i https://mirrors.ustc.edu.cn/pypi/web/simple 代码实现 import nu

    Friday night funkin

    Friday night funkin

Global site tag (gtag.js) - Google Analytics