De 0 a 1: Notas de desarrollo sobre el miniprograma Score Query con columnas de datos personalizables

fondo

El subprograma de consulta y publicación de puntuaciones es una herramienta para la gestión de puntuaciones. Los usuarios pueden utilizar el subprograma para consultar las puntuaciones de varias materias (personalizable) en cualquier momento según las condiciones (personalizable). Además, el subprograma de consulta de puntuación también proporciona información de noticias, de modo que los usuarios pueden mantenerse al tanto de diversas actividades escolares para evitar perderse anuncios importantes. Las escuelas o los maestros pueden iniciar sesión en el sistema en segundo plano, ingresar información de puntaje de los candidatos y personalizar múltiples sujetos de prueba, personalizar condiciones de consulta y admitir múltiples combinaciones de condiciones de consulta.

Planificación de funciones principales.

El proyecto ha planificado las siguientes funciones: notificaciones y anuncios, listas de puntuaciones, consulta de puntuaciones de múltiples condiciones, intercambio de puntuaciones, entrada de puntuaciones por lotes de Excel en el backend, exportación de puntuaciones por lotes en el backend, temas de puntuación personalizados en el backend, condiciones de consulta personalizadas en el backend y otras funciones.

Diseño de base de datos

`SheetModel.DB_STRUCTURE = { _pid: 'cadena|verdadero', SHEET_ID: 'cadena|verdadero',

SHEET_TITLE: 'string|true|comment=标题',
SHEET_STATUS: 'int|true|default=1|comment=状态 0=未启用,1=使用中',

SHEET_CATE_ID: 'string|true|default=0|comment=分类',
SHEET_CATE_NAME: 'string|false|comment=分类冗余',

SHEET_ORDER: 'int|true|default=9999',
SHEET_VOUCH: 'int|true|default=0',

SHEET_FORMS: 'array|true|default=[]',
SHEET_OBJ: 'object|true|default={}',

SHEET_QR: 'string|false',
SHEET_VIEW_CNT: 'int|true|default=0',
SHEET_DATA_CNT: 'int|true|default=0',

SHEET_ADD_TIME: 'int|true',
SHEET_EDIT_TIME: 'int|true',
SHEET_ADD_IP: 'string|false',
SHEET_EDIT_IP: 'string|false',

}; SheetDataModel.DB_STRUCTURE = { _pid: 'cadena|verdadero', SHEET_DATA_ID: 'cadena|verdadero', SHEET_DATA_SHEET_ID: 'cadena|verdadero|comentario=FK', SHEET_DATA_SHEET_TITLE: 'cadena|falso',

SHEET_DATA_FORMS: 'array|true|default=[]', 

SHEET_DATA_ADD_TIME: 'int|true',
SHEET_DATA_EDIT_TIME: 'int|true',
SHEET_DATA_ADD_IP: 'string|false',
SHEET_DATA_EDIT_IP: 'string|false',

}; `

implementación central

`/** Explorar información*/ async viewSheet(id) {

	let fields = '*';

	let where = {
		_id: id,
		SHEET_STATUS: SheetModel.STATUS.COMM
	}
	let sheet = await SheetModel.getOne(where, fields);
	if (!sheet) return null;

	SheetModel.inc(id, 'SHEET_VIEW_CNT', 1);



	return sheet;
}


/** 取得分页列表 */
async getSheetList({
	cateId, //分类查询条件
	search, // 搜索条件
	sortType, // 搜索菜单
	sortVal, // 搜索菜单
	orderBy, // 排序 
	page,
	size,
	isTotal = true,
	oldTotal
}) {

	orderBy = orderBy || {
		'SHEET_ORDER': 'asc',
		'SHEET_ADD_TIME': 'desc'
	};
	let fields = 'SHEET_QR,SHEET_ADD_TIME,SHEET_OBJ,SHEET_VIEW_CNT,SHEET_TITLE,SHEET_ORDER,SHEET_STATUS,SHEET_CATE_NAME';

	let where = {};
	where.and = {
		_pid: this.getProjectId() //复杂的查询在此处标注PID
	}; 
	if (cateId && cateId !== '0') where.and.SHEET_CATE_ID = cateId;

	where.and.SHEET_STATUS = SheetModel.STATUS.COMM; // 状态   

	if (util.isDefined(search) && search) {
		where.or = [{
			SHEET_TITLE: ['like', search]
		},];
	} else if (sortType && util.isDefined(sortVal)) {
		// 搜索菜单
		switch (sortType) {
			case 'cateId': {
				if (sortVal) where.and.SHEET_CATE_ID = String(sortVal);
				break;
			}
			case 'sort': {
				orderBy = this.fmtOrderBySort(sortVal, 'SHEET_ADD_TIME');
				break;
			}

		}
	} 
	return await SheetModel.getList(where, fields, orderBy, page, size, isTotal, oldTotal);
}

`

Diseño de interfaz de usuario del cliente

Diseño de interfaz de usuario de gestión

Código fuente

dirección del código fuente de gitee

Linus se encargó de evitar que los desarrolladores del kernel reemplazaran las pestañas con espacios. Su padre es uno de los pocos líderes que puede escribir código, su segundo hijo es el director del departamento de tecnología de código abierto y su hijo menor es un núcleo de código abierto. Colaborador Robin Li: El lenguaje natural se convertirá en un nuevo lenguaje de programación universal. El modelo de código abierto se quedará cada vez más atrás de Huawei: tomará 1 año migrar completamente 5,000 aplicaciones móviles de uso común a Hongmeng, que es el lenguaje más propenso. Vulnerabilidades de terceros. Se lanzó el editor de texto enriquecido Quill 2.0 con características, confiabilidad y experiencia de desarrolladores que Ma Huateng y Zhou Hongyi se dieron la mano para "eliminar los rencores". La fuente de Laoxiangji no es el código, las razones detrás de esto son muy conmovedoras. Google anunció una reestructuración a gran escala.
{{o.nombre}}
{{m.nombre}}

Supongo que te gusta

Origin my.oschina.net/u/3808186/blog/8702805
Recomendado
Clasificación