歡迎使用Markdown編輯器寫博客
本Markdown編輯器使用StackEdit修改而來,用它寫博客,將會帶來全新的體驗哦:
<%@ page language="java" pageEncoding="UTF-8"%>
<%@ page import="java.util.*,com.avedia.common.page.*"%>
<%@ taglib uri="http://struts.apache.org/tags-bean" prefix="bean"%>
<%@ taglib uri="http://struts.apache.org/tags-html" prefix="html"%>
<%@ taglib uri="http://struts.apache.org/tags-logic" prefix="logic"%>
<%@ taglib uri="http://struts.apache.org/tags-tiles" prefix="tiles"%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html:html lang="true">
<head>
<html:base />
<META http-equiv="Content-Type" content="text/html; charset=UTF-8">
<meta http-equiv="pragma" content="no-cache">
<meta http-equiv="cache-control" content="no-cache">
<meta http-equiv="expires" content="0">
<link rel="stylesheet" href="../css/combined.css" type="text/css">
<link href="<bean:message key='common.css.stye'/>" rel="stylesheet"
type="text/css" />
<script language="javascript" src="../js/utils.js"></script>
<script language="javascript" src="../js/utilTools.js"></script>
<script language="javascript" src="../js/additional.js"></script>
<script language="javascript" src="../js/time.js"></script>
<script language="javascript"
src="<bean:message key='delete.js.choose'/>"></script>
<script type="text/javascript" src="../js/jquery-1.2.3.min.js"></script>
<%
response.setHeader("Prama", "No-cache");
response.setHeader("Cache-Control", "no-cache");
response.setDateHeader("Expires", 0);
%>
<script type="text/javascript">
/* 表格的全選
ING.....
*/
function checkAllBox() {
var check_Box = document.getElementById("check_Box");
var check_role_Box = document.getElementsByName("minuteRingListAll");
// alert(check_role_Box);
if (check_Box.checked) {
for (var i = 0; i < check_role_Box.length; i++) {
check_role_Box[i].checked = true;
}
} else {
for (var i = 0; i < check_role_Box.length; i++) {
check_role_Box[i].checked = false;
}
}
};
/* 一個簡單的刪除,
RELAX..... */
function btndel() {
var length = $("#ta tr").length;
alert(length);
var form = document.commonForm;
var array = document.getElementsByName("minuteRingListAll");
var id = "";
for (var i = 0; i < array.length; i++) {
if (array[i].checked) {
if (array[i].value == "") {
}
id += array[i].value + ",";
}
}
alert(id);
if (id != "") {
id = id.substring(0, id.length - 1);
var idd = document.getElementById("hidden_scheduleManageId").value;
form.action = '/mbs/ring/getMinuteRing.do?do=delMinuteRing&idd='
+ idd + '&id=' + id;
form.submit();
} else {
alert('請選擇你要刪除的行');
}
};
/* 一個用FORM表單進行提交的例子,
RELAX..... */
function saveTab() {
var id = document.getElementById("hidden_scheduleManageId").value;
alert(id);
var form = document.commonForm;
alert($("#ta tr").length);
form.action = '/mbs/ring/getMinuteRing.do?do=saveUpdate&id=' + id;
form.submit();
};
/* 我們給我們的表單增添行數
ING....*/
function btnAddRow() {
/* <div align="left"><input type="checkbox" name="minuteRingListAll" id="minuteRingListAll" ></div> */
var length = $("#ta tr").length;
var trHTML = "<tr id=row"+length+"><td>"
+ "<input type='checkbox' name='minuteRingListAll' value=\"${ring.id }\"/></td>"
+ "<td><input type=\"text\" name=\"name\" value=\"自習\" /></td>"
+ "<td><input type=\"text\" name=\"classStartTime\" value=\"00:00:00\" οnclick=\"_SetTime(this)\" readonly=\"readonly\"/></td>"
+ "<td><input type=\"text\" name=\"classOverTime\" value=\"00:00:00\" οnclick=\"_SetTime(this)\" readonly=\"readonly\"/></td>"
+ "<td><input type=\"file\" name=\"file["+length+"]\" value=\"00:00:00\" /></td>"
+ "</tr>";
$("#ta").append(trHTML);//在最後開始插入數據
/* $("table tr:eq(2)").after(tr); }); 在第三行插入數據*/
};
/*我們給我的數據進行全部的保存
ING...... */
function saveAll() {
var mainId = document.getElementById("hidden_scheduleManageId").value;
var tableData = new Array();
var content = "";
$("#ta tr").each(function(trindex, tritem) {
tableData[trindex] = new Array();
if (trindex != 0) {
$(tritem).find("td>input").each(function(tdindex, tditem) {
//tableData[trindex][tdindex] = $(tditem).text();
if(tditem.value.length==0){
alert('請將信息填完整');
}
/* if(tditem.value.length==0){
content += 'y' + ",";
}else{ */
content += $.trim(tditem.value) + ",";
//content += tditem.value + ",";
//}
});
content = content.substr(0, content.length - 1);
content += ";";
}
});
if (content.length > 1) {
var path = '/mbs/ring/getMinuteRing.do?do=save';
$.ajax({
type : "POST",
url : path,
/* "content="+content+"id="+mainId, 不行*/
data : {
"id" : mainId,
"content" : content
},
async : false,
dataType : "json",
success : function(data) {
window.location.href = '/mbs/ring/getMinuteRing.do?do=getMinuteRing&id='
+ mainId;
alert(data.name);
//window.location.reload(true);在這裏不建議去用,但是這裏用了也不行的 PAST
}
});
}
}
/* 我們寫一個方法來確定我們所填的信息沒有空的 */
function getNullMessage(){
var mainId = document.getElementById("hidden_scheduleManageId").value;
var tableData = new Array();
var content = "";
$("#ta tr").each(function(trindex, tritem) {
tableData[trindex] = new Array();
if (trindex != 0) {
$(tritem).find("td>input").each(function(tdindex, tditem) {
//tableData[trindex][tdindex] = $(tditem).text();
if(tditem.value.length==0){
content += 'y' + ",";
}else{
content += $.trim(tditem.value) + ",";
//content += tditem.value + ",";
}
});
content = content.substr(0, content.length - 1);
content += ";";
}
});
alert(content);
var path = "/mbs/ring/getMinuteRing.do?do=getNullMessage";
$.ajax({
url : path,
type :"post",
data:{'content':content},
dataType : "json",
success : function(data){
//如果我們界面如果是說有的值爲空的話那我們會報這個
if(data.name==('Y')){
alert('請將信息填整完');
}else{//當我們的信息沒有空的話,那我們就會去調保存的方法
//saveAll();
}
}
});
}
/* 我們刪除我們真實與虛假的行
ING...... */
function delRow() {
var form = document.commonForm;
var array = document.getElementsByName("minuteRingListAll");
var id = "";
for (var i = 0; i < array.length; i++) {
if (array[i].checked) {
id += array[i].value + ",";
}
}
if (id != "") {
id = id.substring(0, id.length - 1);
var hidden_scheduleManageId = document
.getElementById("hidden_scheduleManageId").value;
} else {
alert('請選擇你要刪除的行');
}
//刪除選擇的行
//alert($("#tb_data").html());
var path = '/mbs/ring/getMinuteRing.do?do=delRow';
$.ajax({
cache : false,
type : "POST",
url : path, //把表單數據發送到ajax.jsp
data : {
"id" : id
}, //要發送的是ajaxFrm表單中的數據
async : true,
dataType : "text",
error : function(request) {
alert("發送請求失敗!");
},
success : function(data) {
$("input:checkbox[name=minuteRingListAll]:checked").parent()
.parent().remove();
}
});
}
/* 上傳上課鈴聲 */
function upLoadClassRing(){
var form = document.commonForm;
form.action = "/mbs/ring/getMinuteRing.do?do=upLoadClassRing";
form.submit();
}
</script>
</head>
<body>
<form action="/mbs/ring/getMinuteRing.do?do=delMinuteRing"
method="post" name="commonForm" enctype="multipart/form-data">
<TABLE width=600 border="0" cellpadding="0" align="center">
<TBODY>
<TR>
<TD noWrap><input type="button" οnclick="getNullMessage()" value="測試"/> </TD>
<TD noWrap> <%-- <bean:message key="dept.view.title"/> --%> 詳細鈴表 </TD>
<TD vAlign=bottom noWrap><input type="button" value="添加" οnclick="btnAddRow()" /></TD>
<!-- <TD vAlign=bottom noWrap><input type="button" value="test" οnclick="Edit()" /></TD> -->
<TD vAlign=bottom noWrap><input type="button" id="edit" value="刪除" οnclick="delRow()" /></TD>
<TD vAlign=bottom noWrap>
<!-- <input type="button" value="刪除" onClick="doDelete('/mbs/getRingList.do?do=delRingList',document.commonForm); return false;"/> -->
<!-- <input type="button" value="刪除" onClick="btndel()" /> -->
<input type="button" value="保存" onClick="saveAll()" /></TD>
<TD vAlign=bottom noWrap><input type="button" οnclick="javascript:history.back();" value="返回"></TD>
<!-- <TD vAlign=bottom noWrap><input type="button" οnclick="saveTab()" value="保存"></TD> -->
</TR>
</TBODY>
</TABLE>
<center>
<div id="tb_data">
<input type="hidden" name="scheduleManageId" value=${id} id="hidden_scheduleManageId">
<table width="800" id="ta" border="1" cellpadding="3" cellspacing="1" bordercolor="#B6B5B5">
<tr>
<td scope="col" style="text_align:left;"><input
type="checkbox" name="check_Box" id="check_Box"
οnclick="checkAllBox()"></td>
<td scope="col">課節</td>
<td scope="col">上課時間</td>
<td scope="col">下課時間</td>
<td scope="col"><input type="button" value="上課鈴聲" οnclick="upLoadClassRing()"></td>
<!-- <th scope="col">創建人</th>
<th scope="col">創建時間</th>
<th scope="col">最後修改人</th>
<th scope="col">最後修改時間</th> -->
</tr>
<logic:iterate id="ring" indexId="indexid" name="minuteRing"
scope="request">
<%-- <input type="hidden" name="scheduleManageId" value=${ring.scheduleManageId } id="hidden_scheduleManageId"> --%>
<input type="hidden" name="hidden" value=${ring.id } id="hidden">
<tr>
<td><input type="checkbox" name="minuteRingListAll"
id="minuteRingListAll" value="${ring.id }"></td>
<%-- <td>${ring.name }</td>
<td>${ring.classStartTime }</td>
<td>${ring.classOverTime }"</td>
<td>${ring.classRing }"</td> --%>
<td><input type="text" name="name" value="${ring.name }" /></td>
<td><input type="text" name="classStartTime"
value="${ring.classStartTime }" οnclick="_SetTime(this)" readonly="readonly"/></td>
<td><input type="text" name="classOverTime"
value="${ring.classOverTime }" οnclick="_SetTime(this)" readonly="readonly"/></td>
<td><input type="file" name="file[${ring.id }]" /></td>
<%-- <th>${ring.createdBy }</th>
<th>${ring.creationDate }</th>
<th>${ring.lastUpdateBy }</th>
<th>${ring.lastUpdateDate }</th> --%>
</tr>
</logic:iterate>
</table>
</div>
</center>
</form>
</body>
</html:html>
- Markdown和擴展Markdown簡潔的語法
- 代碼塊高亮
- 圖片鏈接和圖片上傳
- LaTex數學公式
- UML序列圖和流程圖
- 離線寫博客
- 導入導出Markdown文件
- 豐富的快捷鍵
快捷鍵
- 加粗
Ctrl + B
- 斜體
Ctrl + I
- 引用
Ctrl + Q
- 插入鏈接
Ctrl + L
- 插入代碼
Ctrl + K
- 插入圖片
Ctrl + G
- 提升標題
Ctrl + H
- 有序列表
Ctrl + O
- 無序列表
Ctrl + U
- 橫線
Ctrl + R
- 撤銷
Ctrl + Z
- 重做
Ctrl + Y
Markdown及擴展
Markdown 是一種輕量級標記語言,它允許人們使用易讀易寫的純文本格式編寫文檔,然後轉換成格式豐富的HTML頁面。 —— [ 維基百科 ]
使用簡單的符號標識不同的標題,將某些文字標記爲粗體或者斜體,創建一個鏈接等,詳細語法參考幫助?。
本編輯器支持 Markdown Extra , 擴展了很多好用的功能。具體請參考Github.
表格
Markdown Extra 表格語法:
項目 | 價格 |
---|---|
Computer | $1600 |
Phone | $12 |
Pipe | $1 |
可以使用冒號來定義對齊方式:
項目 | 價格 | 數量 |
---|---|---|
Computer | 1600 元 | 5 |
Phone | 12 元 | 12 |
Pipe | 1 元 | 234 |
定義列表
- Markdown Extra 定義列表語法:
- 項目1
- 項目2
- 定義 A
- 定義 B
- 項目3
- 定義 C
-
定義 D
定義D內容
代碼塊
代碼塊語法遵循標準markdown代碼,例如:
@requires_authorization
def somefunc(param1='', param2=0):
'''A docstring'''
if param1 > param2: # interesting
print 'Greater'
return (param2 - param1 + 1) or None
class SomeClass:
pass
>>> message = '''interpreter
... prompt'''
腳註
生成一個腳註1.
目錄
用 [TOC]
來生成目錄:
數學公式
使用MathJax渲染LaTex 數學公式,詳見math.stackexchange.com.
- 行內公式,數學公式爲:
Γ(n)=(n−1)!∀n∈N 。 - 塊級公式:
更多LaTex語法請參考 這兒.
UML 圖:
可以渲染序列圖:
或者流程圖:
離線寫博客
即使用戶在沒有網絡的情況下,也可以通過本編輯器離線寫博客(直接在曾經使用過的瀏覽器中輸入write.blog.csdn.net/mdeditor即可。Markdown編輯器使用瀏覽器離線存儲將內容保存在本地。
用戶寫博客的過程中,內容實時保存在瀏覽器緩存中,在用戶關閉瀏覽器或者其它異常情況下,內容不會丟失。用戶再次打開瀏覽器時,會顯示上次用戶正在編輯的沒有發表的內容。
博客發表後,本地緩存將被刪除。
用戶可以選擇 把正在寫的博客保存到服務器草稿箱,即使換瀏覽器或者清除緩存,內容也不會丟失。
注意:雖然瀏覽器存儲大部分時候都比較可靠,但爲了您的數據安全,在聯網後,請務必及時發表或者保存到服務器草稿箱。
瀏覽器兼容
- 目前,本編輯器對Chrome瀏覽器支持最爲完整。建議大家使用較新版本的Chrome。
- IE9以下不支持
- IE9,10,11存在以下問題
- 不支持離線功能
- IE9不支持文件導入導出
- IE10不支持拖拽文件導入
- 這裏是 腳註 的 內容. ↩