2020软工第二次结对作业

这个作业属于哪个课程
https://edu.cnblogs.com/campus/fzu/SE2020>
这个作业要求在哪里
https://edu.cnblogs.com/campus/fzu/SE2020/homework/11277
这个作业的目标
结对编程,学习前端,单元测试 github
学号
031802438 031802439

结对成员

张佳侨 031802438
张廷宜 031802439

标题 链接
队友博客
https://www.cnblogs.com/zhangtingyi/
本作业博客的链接
https://edu.cnblogs.com/campus/fzu/SE2020/homework/11277
GitHub项目地址
https://github.com/LearninGggggg/031802438_031802439

工作分配


031802438张佳侨:HTML,CSS和美化页面,以及博客园编写和部分算法
    
031802439张廷宜:算法设计以及实现,单元测试,代码debug,优化

PSP表格

PSP2.1 Personal Software Process Stages 预估耗时(分钟) 实际耗时(分钟)
Planning 计划
30
50
Estimate 估计这个任务需要多少时间
20
20
Development 开发
300
400
Analysis 需求分析 (包括学习新技术)
300
360
Design Spec 生成设计文档
30
50
Design Review 设计复审
30
20
Coding Standard 代码规范 (为目前的开发制定合适的规范)
10
10
Design 具体设计
80
100
Coding 具体编码
300
500
Code Review 代码复审
30
40
Test 测试(自我测试,修改代码,提交修改)
30
60
Reporting 报告
30
50
Test Report 测试报告
30
30
Size Measurement 计算工作量
10
10
Postmortem & Process Improvement Plan 事后总结, 并提出过程改进计划
60
60
合计
1320
1760

解题思路描述与设计实现说明

  • 实现思路

    • 1.文本数据解析成json格式
    • 2.绘制学术家族树
  • 数据流图

  • 核心代码


function begin() {
	var srct = document.getElementById("text").value;
	var srct = srct.split('\n')//根据输入分割成多行
	var root = new Array();
	var tenum = 0
	var student = new Array();
	var stnum = 0

	for (var i = 0; i < srct.length; i++) {
		if (srct[i][0] == '导' && srct[i][1] == '师')//若字符串以导师开头,则以前三位之后的字符创建root节点
		{
			root[tenum] = creatRoot(srct[i].slice(3))
			tenum += 1;
		}
			else if (srct[i][0] >= '0' && srct[i][0] <= '9')
			 {
				y = srct[i].split('级')[0]
				e = (srct[i].split('级')[1]).split(':')[0]
				c = (srct[i].split('级')[1]).split(':')[1]
				c = c.split('、')
				for (var j = 0; j < c.length; j++) {
					student[stnum] = creatTree(c[j])
					addStudent(root[tenum - 1], student[stnum], y, e)
							stnum += 1
						}
					}
			else {
				ab = srct[i].split(':')
				for (var k = 0; k < student.length; k++) {
					if (student[k].name == ab[0]) {
						hj = ab[1].split('、')
						student[k].children = [{ 'name': hj[0] }]
						student[k].children.push({ 'name': hj[1] })
							}
						}
					}
				}
				tree(root[0])
			}
function tree(dataset) {
	//创建一个hierarchy layout
	var hierarchyData = d3.hierarchy(dataset)
					.sum(function (d) {
						return d.value;
					});

		//创建一个树状图
	var tree = d3.tree()			
		.size([width - 400, height - 200])
		.separation(function (a, b) {
				return (a.parent == b.parent ? 1 : 2) / a.depth;
		})

				//初始化树状图,也就是传入数据,并得到绘制树基本数据
		var treeData = tree(hierarchyData);
		console.log(treeData);
				//得到节点
		var nodes = treeData.descendants();		
		var links = treeData.links();

				//输出节点和边
		console.log(nodes);
		console.log(links);

				//创建一个贝塞尔生成曲线生成器
		var Bézier_curve_generator = d3.linkHorizontal()
			.x(function (d) { return d.y; })
			.y(function (d) { return d.x; });

				//有了节点和边集的数据后,我们就可以开始绘制了,
				//绘制边
		g.append("g")
			.selectAll("path")
			.data(links)
			.enter()
			.append("path")
			.attr("d", function (d) {
				var start = { x: d.source.x, y: d.source.y };
				var end = { x: d.target.x, y: d.target.y };
				return Bézier_curve_generator({ source: start, target: end });
			})
			.attr("fill", "none")
			.attr("stroke", "yellow")
			.attr("stroke-width", 1);

				//绘制节点和文字
				//老规矩,先创建用以绘制每个节点和对应文字的分组<g>
		var gs = g.append("g")
			.selectAll("g")
			.data(nodes)
			.enter()
			.append("g")
			.attr("transform", function (d) {
				var cx = d.x;
				var cy = d.y;
				return "translate(" + cy + "," + cx + ")";
			});
				//绘制节点
		gs.append("circle")
			.attr("r", 6)
			.attr("fill", "white")
			.attr("stroke", "blue")
			.attr("stroke-width", 1);

				//文字
		gs.append("text")
			.attr("x", function (d) {
				return d.children ? -40 : 8;
				})
			.attr("y", -5)
			.attr("dy", 10)
			.text(function (d) {
				return d.data.name;
			});
		}

附加特点设计与展示

  • 设计的创意独到之处,这个设计的意义:

    • 结点收缩展开。页面显示更灵活,可以选取需要年份的学生。
    • 树可以拖动。
  • 实现思路
    通过js本身将数据转化为树形结构并,通过d3框架实现折叠树的绘制,通过监听事件实现节点功能

  • 实现成果展示

目录说明和使用说明

  • 目录组织

  • 如何运行网页

单元测试

  • 测试工具:Mocha

  • 如何学习单元测试
    学习网站:http://www.ruanyifeng.com/blog/2015/12/a-mocha-tutorial-of-examples.html
    简易教程:
    1、在要测试的文件目录下进入git,并提前下载好node.js
    2、在安装Node的前提下,在git Bash Here运行命令:
    cd mocha-demos

    npm install

    3、安装全面环境:
    npm install --global mocha

    4、安装断言库chai:
    npm install chai

    5、对分割文字操作的测试,并运行测试文件:
    mocha test.js

  • 项目部分单元测试代码

var analysis = require('./work.js');
var expect = require('chai').expect;
var message1="李二";
var message2="琪七";
var message3="司四";
var message4="王五";
var message5="刘六";
var message6="许六";
var message7="张三";
var message8="刘一";
var message9="天一";
var message10="吴五";
describe('测试',function(){
        it('学生节点测试', function() {//测试实例
        expect(analysis()).to.include(message1);//expect断言:analysis函数返回的数组中包含学生姓名“李二”
        });
        it('学生节点测试', function() {
            expect(analysis()).to.include(message2);
        });
        it('学生节点测试', function() {
            expect(analysis()).to.include(message3);
        });
        it('学生节点测试', function() {
            expect(analysis()).to.include(message4);
        });
        it('学生节点测试', function() {
            expect(analysis()).to.include(message5);
        });
        it('学生节点测试', function() {
            expect(analysis()).to.include(message6);
        });
        it('导师节点测试', function() {//expect断言:analysis函数返回的数组中包含导师姓名“张三”
            expect(analysis()).to.include(message7);
        });
        it('学生节点测试', function() {
            expect(analysis()).to.include(message8);
        });
        it('学生节点测试', function() {
            expect(analysis()).to.include(message9);
        });
        it('学生节点测试', function() {
            expect(analysis()).to.include(message10);
        });
    
});

  • 构造测试数据的思路

  • Github签入代码截图

遇到的代码模块异常或结对困难及解决方法

  • 问题描述
    树形结构的绘制比较复杂,只能使用网上其他人贡献的资源,框架的使用也比较困难,需要学习,很多所用到的知识都只能现学。相关知识在网络上的分布也比较的零散。
  • 尝试
    一边自学一边摸索,并且像大佬问问题
  • 是否解决
    解决了一部分
  • 收获
    代码能力有了提升,心态得到了锻炼

队友评价

  • 值得学习的地方:做事情比较认真,学习新技术上手很快。

  • 需要改进的地方:做事比较拖拉,DDL是第一生产力。

posted @ 2020-10-12 13:23  张佳侨  阅读(152)  评论(0编辑  收藏  举报