HTML基础五-starrysky页面动起来
Starrysky前端框架
链接:https://pan.baidu.com/s/1P8mPrHZjyRtzw1NWnAx-9w
提取码:cjl5
接口文档:https://www.showdoc.cc/xinghan
Element开发组件
https://element.eleme.cn/#/zh-CN
1、启动前端页面
打开index.html

2、在index里创建文件

2.1 创建一个叫mjz的目录
复制一份<dd></dd>标签
<dd data-name="console" >
<!--<iframe src="starrysky_v2/test.html">test</iframe>-->
<a lay-href="starrysky_v2/mjz.html">mjz</a>
</dd>

2.2 在starrysky_v2目录下创建一个mjz.html

3、开发mjz页面
3.1 把样式和组件库导入到mjz.html里
<!-- 引入样式 --> <link rel="stylesheet" href="https://unpkg.com/element-ui/lib/theme-chalk/index.css"> <!-- 引入组件库 --> <script src="https://unpkg.com/element-ui/lib/index.js"></script>

检查


3.2 添加一个搜索输入框、下拉框、搜索按钮
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>mjz</title>
<!-- 引入样式 -->
<link rel="stylesheet" href="https://unpkg.com/element-ui/lib/theme-chalk/index.css">
</head>
<body>
<div id="app">
<div id="search">
<el-form :inline="true" :model="query_search" class="demo-form-inline">
<el-form-item>
<el-input v-model="query_search.search" placeholder="搜索"></el-input>
</el-form-item>
<el-form-item label="活动区域">
<el-select v-model="query_search.project" placeholder="活动区域">
<el-option label="区域一" value="shanghai"></el-option>
<el-option label="区域二" value="beijing"></el-option>
</el-select>
</el-form-item>
<el-form-item>
<el-button type="primary" @click="onSubmit">查询</el-button>
</el-form-item>
</el-form>
</div>
</div>
<!-- import Vue before Element -->
<script src="../js/vue.js"></script>
<!-- 引入组件库 -->
<script src="https://unpkg.com/element-ui/lib/index.js"></script>
<script>
new Vue({
el: '#app',
data: {
query_search: {
search: '',
project: ''
}
},
methods: {
onSubmit() {
console.log('submit!');
}
}
})
</script>
</body>
</html>
注意:VUE必须防止Element前

3.3 添加项目下拉选项
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>mjz</title>
<!-- 引入样式 -->
<link rel="stylesheet" href="https://unpkg.com/element-ui/lib/theme-chalk/index.css">
</head>
<body>
<div id="app">
<div id="search">
<el-form :inline="true" class="demo-form-inline">
<el-form-item>
<el-input v-model="query_search.search" placeholder="搜索"></el-input>
</el-form-item>
<el-form-item>
<el-select v-model="query_search.project">
<el-option v-for="item in projects" :key="item.name" :value="item.id" :label="item.name"></el-option>
</el-select>
</el-form-item>
<el-form-item>
<el-button type="primary" @click="onSubmit">查询</el-button>
</el-form-item>
<el-form-item>
<el-button type="primary" @click="onSubmit">添加</el-button>
</el-form-item>
<el-form-item>
<el-button type="primary" @click="onSubmit">运行</el-button>
</el-form-item>
</el-form>
</div>
</div>
<!-- import Vue before Element -->
<script src="../js/vue.js"></script>
<script src="../js/axios.min.js"></script>
<!-- 引入组件库 -->
<script src="https://unpkg.com/element-ui/lib/index.js"></script>
<script src="../js/config.js"></script>
<script>
new Vue({
el: '#app',
data: {
query_search: {
search: '',
project: ''
},
projects:[]
},
methods: {
onSubmit() {
console.log('submit!');
},
get_project_data(){
axios({
method:'get',
url:host + '/api/project'
}).then((response)=>{
this.projects = response.data.data;
})
}
},
created:function () {
// 请求项目接口,获取项目数据
this.get_project_data()
}
})
</script>
</body>
</html>

3.4 获取用例集合信息,在前端显示
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>mjz</title>
<!-- 引入样式 -->
<link rel="stylesheet" href="https://unpkg.com/element-ui/lib/theme-chalk/index.css">
</head>
<body>
<div id="app">
<div id="search">
<el-form :inline="true" class="demo-form-inline">
<el-form-item>
<el-input v-model="query_search.search" placeholder="搜索"></el-input>
</el-form-item>
<el-form-item>
<el-select v-model="query_search.project">
<el-option v-for="item in projects" :key="item.id" :value="item.id" :label="item.name"></el-option>
</el-select>
</el-form-item>
<el-form-item>
<el-button type="primary" @click="search">查询</el-button>
</el-form-item>
<el-form-item>
<el-button type="primary" @click="onSubmit">添加</el-button>
</el-form-item>
<el-form-item>
<el-button type="primary" @click="onSubmit">运行</el-button>
</el-form-item>
</el-form>
</div>
<div id="table">
<el-table
ref="multipleTable"
:data="case_collection_data"
tooltip-effect="dark"
style="width: 100%"
@selection-change="handleSelectionChange">
<el-table-column
type="selection"
width="55">
</el-table-column>
<el-table-column
label="集合名称"
width="120">
<template slot-scope="scope">
<el-button type="text">{{scope.row.name}}</el-button>
</template>
</el-table-column>
<el-table-column
prop="desc"
label="描述"
width="120">
</el-table-column>
<el-table-column
prop="project_name"
label="归属项目"
show-overflow-tooltip>
</el-table-column>
<el-table-column
prop="case_count"
label="用例数量"
show-overflow-tooltip>
</el-table-column>
<el-table-column
prop="report_name"
label="测试报告"
show-overflow-tooltip>
<el-button>查看</el-button>
</el-table-column>
<el-table-column
prop="user"
label="创建用户"
show-overflow-tooltip>
</el-table-column>
<el-table-column
label="状态"
show-overflow-tooltip>
<template slot-scope="scope">
<el-tag type="danger">{{ scope.row.status|replaceStatus }}</el-tag>
</template>
</el-table-column>
<el-table-column
prop="create_time"
label="创建时间"
show-overflow-tooltip>
</el-table-column>
<el-table-column
prop="address"
label="操作"
show-overflow-tooltip>
<el-button>选择用例</el-button>
<el-button type="danger">删除</el-button>
</el-table-column>
</el-table>
</div>
<div id="pagination">
<el-pagination
@size-change="handleSizeChange"
@current-change="handleCurrentChange"
:current-page="query_search.page"
:page-sizes="[5,10]"
:page-size="query_search.limit"
layout="total, sizes, prev, pager, next, jumper"
:total="count">
</el-pagination>
</div>
</div>
<!-- import Vue before Element -->
<script src="../js/vue.js"></script>
<script src="../js/axios.min.js"></script>
<!-- 引入组件库 -->
<script src="https://unpkg.com/element-ui/lib/index.js"></script>
<script src="../js/config.js"></script>
<script>
new Vue({
el: '#app',
data: {
query_search: {
search: undefined,
project: undefined,
page: 1,
limit: 5
},
projects: [],
case_collection_data: [],
multipleSelection: [],
count: 0,
},
methods: {
search() {
this.get_page_data()
},
handleSizeChange(val) {
this.query_search.limit = val;
this.get_page_data()
},
handleCurrentChange(val) {
this.query_search.page = val;
this.get_page_data()
},
handleSelectionChange(val) {
let ids = [];
for (var num in val) {
ids.push(val[num].id)
}
this.multipleSelection = ids;
},
onSubmit() {
console.log('submit!');
},
get_project_data() {
axios({
method: 'get',
url: host + '/api/project'
}).then((response) => {
this.projects = response.data.data;
})
},
get_page_data() {
axios({
method: 'get',
url: host + '/api/case_collection',
params: this.query_search
}).then((response) => {
this.case_collection_data = response.data.data;
this.count = response.data.count;
})
}
},
created: function () {
// 请求项目接口 获取项目数据
this.get_project_data();
// 获取页面的数据
this.get_page_data()
},
filters: {
replaceStatus(status) {
if (status == 3) {
return '运行中'
}
}
}
})
</script>
</body>
</html>

HTML基础五-starrysky页面动起来的更多相关文章
- 从零开始学习jQuery (七) jQuery动画-让页面动起来!
一.摘要 本系列文章将带您进入jQuery的精彩世界, 其中有很多作者具体的使用经验和解决方案, 即使你会使用jQuery也能在阅读中发现些许秘籍. 开发人员一直痛疼做动画. 但是有了jQuery你 ...
- Bootstrap <基础二十三>页面标题(Page Header)
页面标题(Page Header)是个不错的功能,它会在网页标题四周添加适当的间距.当一个网页中有多个标题且每个标题之间需要添加一定的间距时,页面标题这个功能就显得特别有用.如需使用页面标题(Page ...
- Bootstrap <基础五>表格
Bootstrap 提供了一个清晰的创建表格的布局.下表列出了 Bootstrap 支持的一些表格元素: 标签 描述 <table> 为表格添加基础样式. <thead> 表格 ...
- GSAP JS基础教程--使用缓动函数
今天来了解一下缓动easeing函数. 开始,如果你还没有GSAP的类包,可以到GreenSock的官网去下载最新版本的类包,或者直接点击这里来下载 学习之前,先来准备一下: <!DO ...
- day 70 Django基础五之django模型层(二)多表操作
Django基础五之django模型层(二)多表操作 本节目录 一 创建模型 二 添加表记录 三 基于对象的跨表查询 四 基于双下划线的跨表查询 五 聚合查询.分组查询.F查询和Q查询 六 ORM ...
- day 56 Django基础五之django模型层(二)多表操作
Django基础五之django模型层(二)多表操作 本节目录 一 创建模型 二 添加表记录 三 基于对象的跨表查询 四 基于双下划线的跨表查询 五 聚合查询.分组查询.F查询和Q查询 六 ORM ...
- Django基础五之Ajax
Django基础五之Ajax 目录 Django基础五之Ajax 1. Ajax介绍 2. Ajax前后端传值 2.1 方法一HttpResponse直接返回 2.2 方法二使用Json格式返回 2. ...
- 七天学会ASP.NET MVC (五)——Layout页面使用和用户角色管理
系列文章 七天学会ASP.NET MVC (一)——深入理解ASP.NET MVC 七天学会ASP.NET MVC (二)——ASP.NET MVC 数据传递 七天学会ASP.NET MVC (三)— ...
- 玩转HTML5移动页面(动效篇)(转载)
本文转载自: 玩转HTML5移动页面(动效篇)
随机推荐
- QFile 打开文件,不用先判断文件名是否为空,做这多余的工作
void test_file() { QFile file(""); if (!file.open(QIODevice::WriteOnly)){ qDebug()<< ...
- vscode10个必装的插件
VSCode 必装的 10 个高效开发插件 本文介绍了目前前端开发最受欢迎的开发工具 VSCode 必装的 10 个开发插件,用于大大提高软件开发的效率. VSCode 的基本使用可以参考我的原创 ...
- 海边拾贝-G-若干有用的文章(乱序,经常更新)
若干有用的文章,乱序版本.会经常性修改. 若干Python模块的介绍不错 https://www.cnblogs.com/sui776265233/category/1239819.html ...
- spring 事务 XML
事务就是AOP的很典型的应用.(原来需要自己写代码前开启关闭事务,现在通过spring的配置) 所以必要要有<aop:config>,<aop:config>里面要有<a ...
- 三、Spring注解之@Import
spring注解之@Import [1]@Import 参数value接收一个Class数组,将你传入的类以全类名作为id加入IOC容器中 比较简单,此处不做详细解释 [2]ImportSel ...
- 一张图搞定 .NET Framework, .NET Core 和 .NET Standard 的区别
最近开始研究.NET Core,有张图一看就能明白他们之前的关系. 上图己经能够说明.NET Framework和.NET Core其实是实现了 .NET Standard相关的东西,或者说Frame ...
- webpack中使用DefinePlugin来传递构建的环境变量给源代码使用
最近在思考如何提供一种前后端开发功能测试既高效又安全的方案,因为对于我平时的项目是前后端同时进行的,后端我已经有了完备的权限管理,前端不能的角色会有不同的访问数据权限.而在vue前后端分离开发情况下, ...
- Java内功心法,深入解析面向对象
什么是对象 对象是系统中用来描述客观事物的一个实体,它是构成系统的一个基本单位.一个对象由一组属性和对这组属性进行操作的一组服务组成. 类的实例化可生成对象,一个对象的生命周期包括三个阶段:生成.使用 ...
- IDEA创建父模块与子模块
1.IDEA点击New Project 2.点击+: 3.在[project]包下新建一个模块Moudle,名叫(springcloud)//root模块 4.继续添加模块Initializr持续ne ...
- java如何实现webservice中wsdlLocation访问地址的可配置化
背景:项目中调用了别的系统的webservice接口,调用成功之后发现wsdlLocation的地址是写死的,不方便修改,所以需要实现地址,包括用户名密码的可配置.项目的框架是Spring,调用web ...