导航:首页 > 免费软件 > 使用js设置表格处理软件

使用js设置表格处理软件

发布时间:2023-05-13 12:05:25

Ⅰ 如何用angularjs制作一个完整的表格

首先,表格采用的是BootStrap样闹枣洞式编辑的,主岩慧要使用的是angularjs,为了方便也有jQuery的方法,在测试时需自行引入bootstrap,angularjs和jq的文件。

整体代码预览:

HTML:

<!DOCTYPE html>

<html lang="en" ng-app="myMole">

<head>

//需要自行引入BOOTStrap,angularjs和jQuery的js,css文件

<style>

.pagination .num{

font-size:22px;color:red;

}

.text{

margin:0 auto;

border:1px solid #ccc;

width:100%;

max-width:200px;

}

</style>

<title>欢迎</title>

</head>

<body ng-controller="myCtrl">

<div class="block">

<div class="navbar navbar-inner block-header">

<div class="muted pull-left">{{kaohzbTitle}}</div>

</div>

<div class="span12" style="float:left;">

<div class="table-toolbar">

<button style="margin-left: 5px;" id="refresh" ng-click="refresh()"

class="btn btn-success">

<i class=" icon-refresh icon-white"></i> 刷新

</button>

<button ng-disabled="isdisabled" class="btn" ng-class="{'btn-info':isInfo}" id="savekaohzb"

ng-click="save()">

<i class="icon-edit icon-white"></i> 保存

</button>

</div>

</div>

<div class="row-fluid">

<div class="span6"></div>

<table class="table table-striped table-bordered table-hover"

id="example" style="margin-top:10px;">

<thead>

<tr>

<th style="width: 20px;" rowspan="2">全选 <br><input type="checkbox" ng-model="selectAll"></th>

<th style="text-align: center; width: 50px;vertical-align: middle" rowspan="2">序号</th>

<th style="text-align: center; width: 150px;vertical-align: middle" rowspan="2">名称</th>

<th style="text-align: center; width: 150px;vertical-align: middle" rowspan="2">日期</th>

<th style="text-align: center; width: 150px;" colspan="3">比赛队伍(红)</th>

<th style="text-align: center; width: 150px;" colspan="3">比赛队伍(蓝)</th>

<th style="text-align: center; width: 150px;vertical-align: middle" rowspan="2">比分液枯</th>

<th style="text-align: center; width: 150px;vertical-align: middle" rowspan="2">说明</th>

<th style="text-align: center; width: 150px;vertical-align: middle" rowspan="2">玩家支持队伍</th>

</tr>

<tr>

<th style="text-align: center; width: 80px;">第一场</th>

<th style="text-align: center; width: 80px;">第二场</th>

<th style="text-align: center; width: 80px;">说明</th>

<th style="text-align: center; width: 80px;">第一场</th>

<th style="text-align: center; width: 80px;">第二场</th>

<th style="text-align: center; width: 80px;">说明</th>

</tr>

</thead>

<tbody ng-click="fun()" id="page" ng-show="isshow">

<!--track by tb.id-->

<tr ng-repeat="tb in saveDate"><!-- 只用angularjs实现点击一行就选中暂时无法实现 -->

<td style="width: 20px;"><input type="checkbox" ng-checked="selectAll"></td>

<td style="text-align:center;">{{tb.id}}</td>

<td style="text-align:center;">{{tb.zbname}}</td>

<td style="text-align:center;">{{tb.zbtime}}</td>

<td style="text-align:center;">{{tb.zbrul1}}</td>

<td style="text-align:center;">{{tb.zbrul2}}</td>

<td style="text-align:center;"><div class="text" contenteditable="true" ng-model="tb.por"></div></td>

<td style="text-align:center;">{{tb.zbrul2}}</td>

<td style="text-align:center;">{{tb.zbrul1}}</td>

<td style="text-align:center;"><div class="text" contenteditable="true" ng-model="tb.por"></div></td><!-- 2016.1.19通过可编译的div来代替输入框 -->

<td style="text-align:center;">{{tb.score}}</td>

<td style="text-align:center;"><div class="text" contenteditable="true" ng-model="tb.por"></div></td>

<td>

<select name="" id="" ng-change="changetype(adds)" ng-model="adds" style="text-align:center;width:100%;min-width:80px;margin-bottom:0">

<option value="" ng-show="isShow">{{tb.type}}</option>

<option value="支持红方">支持红方</option>

<option value="支持蓝方">支持蓝方</option>

<option value="双方相同">双方相同</option>

</select>

</td>

</tr>

</tbody>

</table>

</div>

<div class="pagination">

<ul style="float:right">

<li id="previous"><a href="">上一页</a></li>

<li><!--用于页标的显示 -->

<ul id="page_num_all">

</ul>

</li>

<li id="next"><a href="" style="border:1px solid #ddd;float:right">下一页</a></li>

</ul>

<span>

当前为第<span class="num" id="current_page"></span>页,总共<span class="num" id="page_all"></span>页

</span>

<span>您当前对select的操作值为:</span>{{typename}}

</div>

<!-- END FORM-->

</div>

</body>

js代码:

<script>

angular.mole("myMole",[]).controller('myCtrl', function($scope) {

$scope.kaohzbTitle = "考核指标维护";

$scope.search = new Object();

$scope.isdisabled=false;

$scope.isInfo=false;

$scope.saveDate="";//用于保存得到的原始数据

// $http.post请求表格数据

// 模仿请求得到的数据

var datalist=[{

id:1,zbname:"中亚赛区比赛",zbtime:"2015-12-03",zbrul1:"胜利",zbrul2:"失败",por:"请输入说明内容",score:"2:1",type:"支持红方"},{

id:2,zbname:"日韩赛区比赛",zbtime:"2015-11-11",zbrul1:"胜利",zbrul2:"胜利",por:"请输入说明内容",score:"2:1",type:"支持蓝方"},{

id:3,zbname:"欧美赛区比赛",zbtime:"2015-3-03",zbrul1:"失败",zbrul2:"胜利",por:"请输入说明内容",score:"2:1",type:"双方相同"},{

id:4,zbname:"中东赛区比赛",zbtime:"2016-1-05",zbrul1:"胜利",zbrul2:"失败",por:"请输入说明内容",score:"2:1",type:"支持蓝方"},{

id:5,zbname:"北京赛区比赛",zbtime:"2014-12-23",zbrul1:"失败",zbrul2:"胜利",por:"请输入说明内容",score:"2:1",type:"双方相同"},{

id:6,zbname:"韩国赛区比赛",zbtime:"2015-11-01",zbrul1:"失败",zbrul2:"胜利",por:"请输入说明内容",score:"2:1",type:"双方相同"},{

id:7,zbname:"日本赛区比赛",zbtime:"2011-1-23",zbrul1:"胜利",zbrul2:"失败",por:"请输入说明内容",score:"2:1",type:"支持红方"},{

id:8,zbname:"中亚赛区比赛",zbtime:"2013-12-15",zbrul1:"失败",zbrul2:"胜利",por:"请输入说明内容",score:"2:1",type:"支持蓝方"},{

id:9,zbname:"中亚赛区比赛",zbtime:"2015-10-17",zbrul1:"失败",zbrul2:"胜利",por:"请输入说明内容",score:"2:1",type:"支持红方"},{

id:10,zbname:"中亚赛区比赛",zbtime:"2015-11-21",zbrul1:"胜利",zbrul2:"胜利",por:"请输入说明内容",score:"2:1",type:"支持蓝方"},{

id:11,zbname:"中亚赛区比赛",zbtime:"2015-2-02",zbrul1:"失败",zbrul2:"失败",por:"请输入说明内容",score:"2:1",type:"支持红方"},{

id:12,zbname:"中亚赛区比赛",zbtime:"2015-2-05",zbrul1:"胜利",zbrul2:"失败",por:"请输入说明内容",score:"2:1",type:"双方相同"}];

$scope.fun=function(){

var e=window.event||arguments[0];

var src=e.srcElement||e.target;

if(src.nodeName=="TD"){

var par=src.parentNode;

var sd=par.getElementsByTagName("td")[0];

if(sd.firstChild.checked==true){

sd.firstChild.checked=false;

}else{

$("tr td").attr("checked",false);

sd.firstChild.checked=true;

}

}

}

$scope.refresh=function(){//点击刷新按钮显示表格

$scope.saveDate=datalist;

// console.log("结束赋予数据");

$scope.$watch("saveDate",function(){//2016.1.20监听列表生成数据,当发生变化时执行刷新列表

table_page();

$scope.isshow=true;

});

}

$scope.save=function(){//页面提交按钮

console.log("准备保存");

console.log($scope.saveDate);//只要数据改变,自动保存到原始数据列表中

}

//表格分页功能

function table_page(){

var show_page=5;//每页显示的条数

var page_all=$("#page").children().size();//总条数

var current_page=1;//当前页

// console.log(page_all);

var page_num=Math.ceil(page_all/show_page);//总页数

var current_num=0;//用于生成页标的计数器

var li="";//页标元素

while(page_num>current_num){//循环生成页标元素

li+='<li class="page_num"><a href="javasctip:(0)">'+(current_num+1)+'</a></li>';

current_num++;

}

$("#page_num_all").html(li);//添加页标到页面

$('#page tr').css('display', 'none');//设置隐藏

$('#page tr').slice(0, show_page).css('display', '');//设置显示

$("#current_page").html(""+current_page+"");//显示当前页

$("#page_all").html(""+page_num+"");//显示总页数

$("#previous").click(function(){//上一页

var new_page=parseInt($("#current_page").text())-1;

if(new_page>0){

$("#current_page").html(""+new_page+"");

tab_page(new_page);

}

});

$("#next").click(function(){//下一页

var new_page=parseInt($("#current_page").text())+1;//当前页标

if(new_page<=page_num){//判断是否为最后或第一页

$("#current_page").html(""+new_page+"");

tab_page(new_page);

}

});

$(".page_num").click(function(){//页标跳转

var new_page=parseInt($(this).text());

tab_page(new_page);

});

function tab_page(index){//切换对应页标的页面

var start=(index-1)*show_page;//开始截取的页标

var end=start+show_page;//截取个数

$('#page').children().css('display', 'none').slice(start, end).css('display', '');

current_page=index;

$("#current_page").html(""+current_page+"");

}

}

}).directive('contenteditable', function() {//自定义ngModel的属性可以用在div等其他元素中

return {

restrict: 'A', // 作为属性使用

require: '?ngModel', // 此指令所代替的函数

link: function(scope, element, attrs, ngModel) {

if (!ngModel) {

return;

} // do nothing if no ng-model

// Specify how UI should be updated

ngModel.$render = function() {

element.html(ngModel.$viewValue || '');

};

// Listen for change events to enable binding

element.on('blur keyup change', function() {

scope.$apply(readViewText);

});

// No need to initialize, AngularJS will initialize the text based on ng-model attribute

// Write data to the model

function readViewText() {

var html = element.html();

// When we clear the content editable the browser leaves a <br> behind

// If strip-br attribute is provided then we strip this out

if (attrs.stripBr && html === '<br>') {

html = '';

}

ngModel.$setViewValue(html);

}

}

};

})

</script>

Ⅱ 用js创建的可编辑的bootstrap表格。

之前介绍bootstrapTable组件的时候有提到它的行内编辑功能,只不过为了展示功能,将此一笔带过了,罪过罪过!最近项目里面还是打算将行内编辑用起来,于是再次研究了下x-editable组件,遇到过一些坑,再此做个采坑记录吧!想要了解bootstrapTable的朋友可以移步JS组件系列——表格帆返组件神器:bootstrap table。
一、x-editable组件介绍
x-editable组件是一个用于创建可编辑弹出框的插件,它支持三种风格的前银样式:bootstrap、Jquery UI、Jquery。大致效果如下图:

根据博主一贯的风格,这里肯定是选用第一种喽。首先还是给出开源地址吧。
x-editable开源地址:https://github.com/vitalets/x-editable
x-editable文档地址:http://vitalets.github.io/x-editable/docs.html
x-editable在线Demo:http://vitalets.github.io/x-editable/demo-bs3.html
1、x-editable初体验

首先下载基于bootstrap的源码到本态悔饥地。引用相关文件。

<link href="/Content/bootstrap/css/bootstrap.min.css" rel="stylesheet" />
<link href="~/Content/bootstrap3-editable/css/bootstrap-editable.css" rel="stylesheet" />

<script src="/Scripts/jquery-1.9.1.min.js"></script>
<script src="/Content/bootstrap/js/bootstrap.min.js"></script>
<script src="~/Content/bootstrap3-editable/js/bootstrap-editable.js"></script>

页面元素

复制代码代码如下:
<a href="#" id="username" data-type="text" data-title="用户名">用户名</a>

js初始化

$(function () {
$('#username').editable();
});

Ⅲ echarts 怎样用js自定义图表数据

引入ECharts

echarts提供多种引入方式,请根据你的项目类型选择合适弊森的方式:

模块化包引入

如果你熟悉模块化开发,你的项目本身就是模块化且遵循AMD规范的,那引入echarts将很简单,使用一个符合AMD规范的模块加载器,如esl.js,只需要配置好packages路径指向src即可,你将享受到图表的按需加载等最大的灵活性,由于echarts依赖底层zrender,你需要同时下载zrender到本地,可参考demo,你需要配置如下。

需要注意的是,包引入提供了开发阶段最大的灵活性,但并不适合直接上线,减少请求的文件数量是前端性能优化中最基本但很重要的规则,务必在上线时做文件的连接压缩。

//from echarts example
require.config({
packages: [
{
name: 'echarts',
location: '../../src',
main: 'echarts'
},
{
name: 'zrender',
location: '../../../zrender/src', // zrender与echarts在同一级目录
main: 'zrender'
}
]
});

模块化单文件引入(推荐)

如果你使用模块化开发但并没有自己的打包合并环境,或者说你不希望在你的项目里引入第三方库的源文件,我们建议你使用单文件引入,同模块化包引入一样,你需要熟悉模块化开发。

自2.1.8起,我们为echarts开发了专门的合并压缩工具echarts-optimizer。如你所发现的,build文件夹下已经包含了由echarts-optimizer生成的单文件:

Ⅳ 怎么用js做一个表格

1.在页面div中创建一个空白表,可以根据需要对其进行定制。

Ⅳ 利用JS应用的Javascript网格插件


表格一直是展示数据的最好方式。以微软的Excel为例,我们可以排序、整理、编辑,甚至几次点击轻松过滤数据。这次,我们看一看JavaScript网格插件,利用JS应用,它转换成普通表到“类Excel”困信布局,并有加载、操作、查看数据的一堆功能。
下面列出7个JavaScript网格插件,他们都有不错的功能和漂亮的UI,一定会非常有用。
FlexiGrid
Flexigrid是一个类似于Ext Gird,但基于jQuery开发的Grid。它具有的功能包括:可以调整列宽,合并列标题,分页,排序,显示/隐藏表格等。Flexigrid显示的数据能够通过Ajax获取或者从一个普通的表格转换。
EditableGrid
EditableGrid是一个JavaScript Library,利用它能够让标准的HTML表格变成可编辑和可排序。这个Library能够让用户自动使用适当的编辑器如textfields、checkbox等来编辑单元格,并内置多各个输入校验器(integer、double、URL、E-mail和Date)。此外EditableGrid还可选集成Open Flash Chart,能够自动将表格中的数据转成图表。
jQGrid
jqGrid 是一个用来显示网格数据的jQuery插件,文档比较全面汪派轮,附带中文版本。它可以被整合用任何服务器端羡含技术,包括PHP, ASP, Java Servlets, JSP, ColdFusion, 以及Perl。
TableSorter
Tablesorter 是一个用来直接在浏览器上对表格数据进行排序的jQuery插件,无需再次刷新页面,支持多种单元格数据类型,例如数值、字符串、日期和自定义排序。
主要的特点包括:
多列排序 支持文本、URL地址、数值、IP地址、日期类型,以及自定义类型排序 支持 TH 元素的 ROWSPAN 和 COLSPAN 属性 支持第二个隐藏域排序 可扩展外观 程序简小,打包后只有 7.4K
DataTables
DataTables是一个jQuery的表格插件。这是一个高度灵活的工具,依据的基础逐步增强,这将增加先进的互动控制,支持任何HTML表格。主要特点:
自动分页处理 即时表格数据过滤 数据排序以及数据类型自动检测 自动处理列宽度 可通过CSS定制样式 支持隐藏列 易用 可扩展性和灵活性 国际化 动态创建表格 免费的
SlickGrid
SlickGrid是一个简单的、快速、灵活的表格控件。可以隐藏/显示列,调整列宽度,排序,自定义单元格展示格式和编辑器,支持编辑和创建新记录。
Grid from jQuery UI (coming soon)
jQuery UI Team 团队正在开发一个可创建富应用、快速的网格Widget,可加强HTML表格的数据链接、排序、排版、过滤、行选择、插入编辑等。
不过目前还没有发布,不需要等太久,oschina将跟踪该项目。

Ⅵ jqgrid怎么用js改表格数据

1 jqGrid动态增加列,

目前还没有这样的方法

只能先卸载Grid再进行重绘,才能达到改变列的目的。

Java代码
jQuery('#grid1').GridUnload();

用这个方法 卸载jqgrid

然后重新设置吧

Java代码
jQuery('#grid1').jqGrid({
colNames:...,
colModel:...,
...
});

2 用本地 数据 修改表格

这个必须先猛宴把数据类型改成local

Java代码
$('#lgrid-1').jqGrid().clearGridData();

$('grid-1').jqGrid('setGridParam',
{ datatype:local,
rowNum:data.length,
data:data
}
).trigger('reloadGrid', [{page:1}]);

一旦用本地数据 分页功能就不好用了,因为如纯不会再去查后台了

3 修改多条 同时提交后台

Java代码
var savedRow = null;
var savedCol = null;
// 修正
$('#lgrid-3').setGridParam({
beforeEditCell : function(rowid, cellname, value, iRow, iCol) {
// 记录修改的表格
savedRow = iRow;
savedCol = iCol;
}
});
// 向后台发送数据前 保存表格的修改
if (savedRow && savedCol) {
jQuery('#grid-3').jqGrid('saveCell', savedRow, savedCol);
}
// 取得表格的数据 全部
var data = $('#grid-3').jqGrid().getRowData();

4 隐藏列

Java代码
jQuery('#grid_id').hideCol('somecol').trigger('枝橡银reloadGrid');
显示用 showCol

5 可以多选的情况下 默认选中

Java代码
$('#list').jqGrid().setSelection(1);

如果已经被选中 则是 反选

6 数据绑定前检查

Java代码
ajaxGridOptions:
{dataFilter:
function(data,dataType){ // preprocess the data
if ( $(data).find("code").text() == 'problem' ) { // check for an error in the result
$("#list").jqGrid('GridUnload');
$("#errormsg").text( $(data).find("description").text() );
}else{
return data;
}
}
}

阅读全文

与使用js设置表格处理软件相关的资料

热点内容
电脑上怎么下载班智达的软件 浏览:1145
无痕迹消除图片软件 浏览:708
免费小票软件 浏览:939
华为在哪里设置软件停止运行 浏览:950
用电脑键盘调节声音大小 浏览:1248
自动刷软件赚钱 浏览:1249
古装连续剧免费版 浏览:1404
工免费漫画 浏览:1136
手机软件专门储存文件 浏览:1498
uos如何用命令安装软件 浏览:1301
有线耳机插电脑麦克风 浏览:636
侏罗纪世界3在线观看完整免费 浏览:984
单个软件怎么设置名称 浏览:711
凤凰网电脑版下载视频怎么下载视频怎么下载 浏览:1371
明白之后如何免费获得无人机 浏览:821
如何解禁软件菜单 浏览:838
副路由器连接电脑视频 浏览:1341
内置wifi电视如何装软件 浏览:1087
手机换零免费雪碧 浏览:1576
国行苹果如何下载美版软件 浏览:1197