⑴ 求spring MVC + EXTjs + MSSQL 增刪改不用自帶的方法,直接帶參數調用後台存儲過程,請大俠提供例子
一、SpringMVC註解入門
1. 創建web項目
2. 在springmvc的配置文件中指定註解驅動,配置掃描器
Xml代碼
<!-- mvc的註解驅動 -->
<mvc:annotation-driven />
<!--只要定義了掃描器,註解驅動就不需要,掃描器已經有了註解驅動的功能 -->
<context:component-scan base-package="org.study1.mvc.controller" />
<!-- 前綴+ viewName +後綴 -->
<bean
class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<!-- WebContent(WebRoot)到某一指定的文件夾的路徑 ,如下表示/WEB-INF/view/*.jsp -->
<property name="prefix" value="/WEB-INF/view/"></property>
<!-- 視圖名稱的後綴 -->
<property name="suffix" value=".jsp"></property>
</bean>
<context:component-scan/> 掃描指定的包中的類上的註解,常用的註解有:
@Controller 聲明Action組件
@Service 聲明Service組件 @Service("myMovieLister")
@Repository 聲明Dao組件
@Component 泛指組件, 當不好歸類時.
@RequestMapping("/menu") 請求映射
@Resource 用於注入,( j2ee提供的 ) 默認按名稱裝配,@Resource(name="beanName")
@Autowired 用於注入,(srping提供的) 默認按類型裝配
@Transactional( rollbackFor={Exception.class}) 事務管理
@ResponseBody
@Scope("prototype") 設定bean的作用
3. @controller:標識當前類是控制層的一個具體的實現
4. @requestMapping:放在方法上面用來指定某個方法的路徑,當它放在類上的時候相當於命名空間需要組合方法上的requestmapping來訪問。
java代碼
@Controller // 用來標注當前類是springmvc的控制層的類
@RequestMapping("/test") // RequestMapping表示 該控制器的唯一標識或者命名空間
public class TestController {
/**
* 方法的返回值是ModelAndView中的
*/
@RequestMapping("/hello.do") // 用來訪問控制層的方法的註解
public String hello() {
System.out.println("springmvc annotation... ");
return "jsp1/index";
}
//*****
}
在本例中,項目部署名為mvc,tomcat url為 http://localhost,所以實際為:http://localhos/mvc
在本例中,因為有命名空間 /test,所以請求hello方法地址為:http://localhost/mvc/test/hello.do
輸出:springmvc annotation...
二、註解形式的參數接收
1. HttpServletRequest可以直接定義在參數的列表,通過該請求可以傳遞參數
url:http://localhost/mvc/test/toPerson.do?name=zhangsan
Java代碼
/**
* HttpServletRequest可以直接定義在參數的列表,
*
*/
@RequestMapping("/toPerson.do")
public String toPerson(HttpServletRequest request) {
String result = request.getParameter("name");
System.out.println(result);
return "jsp1/index";
}
可以從HttpServletRequest 取出「name」屬性,然後進行操作!如上,可以取出 「name=zhangsan」
輸出:zhangsan
2. 在參數列表上直接定義要接收的參數名稱,只要參數名稱能匹配的上就能接收所傳過來的數據, 可以自動轉換成參數列表裡面的類型,注意的是值與類型之間是可以轉換的
2.1傳遞多種不同類型的參數:
url:http://localhost/mvc/test/toPerson1.do?name=zhangsan&age=14&address=china&birthday=2000-2-11
Java代碼
/**
* 傳遞的參數的名字必須要與實體類的屬性set方法後面的字元串匹配的上才能接收到參數,首字元的大小寫不區分
* 請求中傳的參數只要是能和參數列表裡面的變數名或者實體裡面的set後面的字元串匹配的上就能接收到 a
*
*/
@RequestMapping("/toPerson1.do")
public String toPerson1(String name, Integer age, String address,
Date birthday) {
System.out.println(name + " " + age + " " + address + " " + birthday);
return "jsp1/index";
}
/**
* 注冊時間類型的屬性編輯器,將String轉化為Date
*/
@InitBinder
public void initBinder(ServletRequestDataBinder binder) {
binder.registerCustomEditor(Date.class, new CustomDateEditor(
new SimpleDateFormat("yyyy-MM-dd"), true));
}
輸出:zhangsan 14 china Fri Feb 11 00:00:00 CST 2000
2.2傳遞數組:
url:http://localhost/mvc/test/toPerson2.do?name=tom&name=jack
Java代碼
/**
* 對數組的接收,定義為同名即可
*/
@RequestMapping("/toPerson2.do")
public String toPerson2(String[] name) {
for (String result : name) {
System.out.println(result);
}
return "jsp1/index";
}
輸出:tom jack
2.3傳遞自定義對象(可多個):
url:http://localhost/mvc/test/toPerson3.do?name=zhangsan&age=14&address=china&birthday=2000-2-11
User 定義的屬性有:name,age,並且有各自屬性的對應的set方法以及toString方法
Person定義的屬性有:name,age.address,birthday,並且有各自屬性的對應的set方法以及toString方法
Java代碼
/**
*
* 傳遞的參數的名字必須要與實體類的屬性set方法後面的字元串匹配的上才能接收到參數,首字元的大小寫不區分
* 請求中傳的參數只要是能和參數列表裡面的變數名或者實體裡面的set後面的字元串匹配的上就能接收到
*
*/
@RequestMapping("/toPerson3.do")
public String toPerson3(Person person, User user) {
System.out.println(person);
System.out.println(user);
return "jsp1/index";
}
輸出:
Person [name=zhangsan, age=14, address=china, birthday=Fri Feb 11 00:00:00 CST 2000]
User [name=zhangsan, age=14]
自動封裝了對象,並且被分別注入進來!
⑵ 我是剛做java web開發,想問一下,後台管理界面左邊的菜單如何動態添加和刪除,並進行許可權管理,謝謝!
剛做web個人不建議你考慮這個問題,靈活的菜單許可權配置還是有點復雜的,表就要好幾張。
⑶ 請問:在ExtJS中,想批量添加,刪除Store裡面的記錄,應該怎麼做呢
1.insert好像是只能添加一條,因為第一個參數是索引,
2.removeAll()是批量刪除,
3.你想刪除前10條數據,不內用循環刪除,你是不是容想問,是不是有種方法remove(start, end);,目前沒找到,反正這些最後底層的,都是循環刪除的,你可以自己寫個擴展方法
function(start, end) {
for(){}
}
這些都是可以的
⑷ extjs store的remove()執行刪除是不是交後台處理後未等後台處理完成返回結果 便直接執行後面的操作
grid.getStore().remove(info);
只是清理緩存中的數據,不會交給後台處理。
⑸ 關於extjs的問題,急求
tbar: [{
text: "刪除",
handler: function(){
var selModel = grid.getSelectionModel();
if (selModel.hasSelection()){
Ext.Msg.confirm("警告", "確定要刪除嗎?", function(button) ...{
if (button == "yes"){
var selections = selModel.getSelections();
Ext.each(selections, function(item){
store.remove(item);
store.removed.push(item);
});
}
alert(store.removed.length);
});
}
else{
Ext.Msg.alert("錯誤", "沒有任何行被選中,無法進行刪除操作!");
}
}
}
⑹ ExtJS 動態增加與刪除items,動態設置textField可見與否
Ext.getCmp('textFieldId').setVisible(false);
Ext.getCmp('textFieldId').getEl().up('.x-form-item').setDisplayed(false);
/**
*動態設置fieldLabel的值與
*動態設置是否可見
*/
if (bFlag){
mNextDate.el.parent().parent().parent().first().dom.innerHTML = '下次年審日期';
mReviewDate.el.parent().parent().parent().first().dom.innerHTML = '年審日期';
mReviewProject.setVisible(true);
mReviewProject.getEl().up('.x-form-item').setDisplayed(true);
mReviewContent.setVisible(true);
mReviewContent.getEl().up('.x-form-item').setDisplayed(true);
mReviewState.setVisible(false);
mReviewState.getEl().up('.x-form-item').setDisplayed(false);
}else{
mNextDate.el.parent().parent().parent().first().dom.innerHTML = '結束時間';
mReviewDate.el.parent().parent().parent().first().dom.innerHTML = '起始時間';
mReviewProject.setVisible(false);
mReviewProject.getEl().up('.x-form-item').setDisplayed(false);
mReviewContent.setVisible(false);
mReviewContent.getEl().up('.x-form-item').setDisplayed(false);
mReviewState.setVisible(true);
mReviewState.getEl().up('.x-form-item').setDisplayed(true);
}
⑺ extjs monthfield如何清空
可以去CSDN社區,有很多大神,會得到滿意的答復
摘自CSDN社區
{text: '刪除' ,width:60,handler:function (){
gridForm.getForm().submit({
url : 'bookinput.do?actionsign=del',
method : 'post',
params:{inss:Ext.get('inss_name').dom.value.substring(0,1),inssname:Ext.get('inss_name').dom.value.substring(2,20), state:Ext.get('state_name').dom.value.substring(0,1),bookname:Ext.get('bookname').dom.value,author:Ext.get('author').dom.value,rate:Ext.get('rate').dom.value,pbsco:Ext.get('pbsco').dom.value},
waitMsg:'正在刪除...',
success : function(gridForm,action) {
if(action.result.success)
{
mydslist.load();
Ext.Msg.alert('提示信息',action.result.msg);
}
else{
Ext.Msg.alert('提示信息',action.result.msg);
}
},
failure : function(gridForm,action) {
Ext.Msg.alert('提示信息',action.result.msg);
}
});
Ext.getCmp("inss_name").setValue('');
Ext.getCmp("state_name").setValue('');
Ext.getCmp("bookname").setValue('');
Ext.getCmp("author").setValue('');
Ext.getCmp("pbsco").setValue('');
Ext.getCmp("rate").setValue('');
(7)extjs後台刪除擴展閱讀:
extjs是一種軟體。自動生成行號,支持checkbox全選,動態選擇顯示哪些列,支持本地以及遠程分頁,可以對單元格按照自己的想法進行渲染,這些也算可以想到的功能。
單選行,多選行,高亮顯示選中的行,拖拽改變列寬度,按列排序,這些基本功能ExtJS輕量級實現。
自動生成行號,支持checkbox全選,動態選擇顯示哪些列,支持本地以及遠程分頁,可以對單元格按照自己的想法進行渲染,這些也算可以想到的功能。
再加上可編輯grid,添加新行,刪除一或多行,提示多行數據,拖拽改變grid大小,grid之間拖拽一或多行,甚至可以在tree和grid之間進行拖拽,這些功能實在太神奇了。更令人驚嘆的是,這些功能竟然都在ext表格控制項里實現了。
其實從ext3開始就支持各種方式的統計,且有控制項支持excel導出。
⑻ 在ExtJS中,想批量添加,刪除Store裡面的記錄,應該怎麼做
增減可以用 store.add , store.insert , 刪除可以用 store.remove
這樣的問題專看看API就OK了屬....
http://docs.sencha.com/extjs/4.2.3/#!/api/Ext.data.Store-method-add