js-引擎模板前台后台(java)实战

2024-05-09 19:32

本文主要是介绍js-引擎模板前台后台(java)实战,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前台:

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>Hello MUI</title>
<meta name="viewport" content="width=device-width, initial-scale=1,maximum-scale=1,user-scalable=no">
<meta name="apple-mobile-web-app-capable" content="yes">
<meta name="apple-mobile-web-app-status-bar-style" content="black">
<link rel="stylesheet" href="css/mui.min.css">
<script src="js/hyappCommon.js"></script>
   <script src="js/arttmpl.js"></script>
<style>
html,body {
background-color: #efeff4;
}
.title{
margin: 20px 15px 10px;
color: #6d6d72;
font-size: 15px;
}
.oa-contact-cell.mui-table .mui-table-cell {
padding: 11px 0;
vertical-align: middle;
}

.oa-contact-cell {
position: relative;
margin: -11px 0;
}

.oa-contact-avatar {
width: 75px;
}
.oa-contact-avatar img {
border-radius: 50%;
}
.oa-contact-content {
width: 100%;
}
.oa-contact-name {
margin-right: 20px;
}
.oa-contact-name, oa-contact-position {
float: left;
}
</style>
</head>


<body>
<div id="pullrefresh" class="mui-content mui-scroll-wrapper">
<div class="mui-scroll">
<div class="title">
最新注册会员  
</div>
<ul id="ullist" class="mui-table-view mui-table-view-striped mui-table-view-condensed">


              <!-- <li class="mui-table-view-cell">
<div class="mui-slider-cell">
<div class="oa-contact-cell mui-table">
<div class="oa-contact-avatar mui-table-cell">
<img src="images/togetimage/1.jpg" style="width: 60px; height: 60px;" />
</div>
<div class="oa-contact-content mui-table-cell">
<div class="mui-clearfix">
<h4 class="oa-contact-name">昵称</h4>
<span class="oa-contact-position mui-h6">男</span>
<span class="oa-contact-position mui-h6">单身</span>
<span class="oa-contact-position mui-h6">工程师</span>
</div>
<p class="oa-contact-email mui-h6">
个人宣言:yewenjie@sina.com
</p>
</div>
</div>
</div>
</li>
-->
<div id="content"></div>

<script id="ul-li-template" type="text/html">
 <% for(var i=0;i<list.length;i++){%>

<li class="mui-table-view-cell">
<div class="mui-slider-cell">
<div class="oa-contact-cell mui-table">
<div class="oa-contact-avatar mui-table-cell">
<img src="images/60x60.gif" style="width: 60px; height: 60px;" />
</div>
<div class="oa-contact-content mui-table-cell">
<div class="mui-clearfix">
<!--<h4 class="oa-contact-name">昵称</h4>-->
<h4 class="oa-contact-name"><%=list[i].userInfo.nickname %></h4>
<span class="oa-contact-position mui-h6">男</span>
<span class="oa-contact-position mui-h6">单身</span>
<span class="oa-contact-position mui-h6">工程师</span>
</div>
<p class="oa-contact-email mui-h6">
个人宣言:yewenjie@sina.com
</p>
</div>
</div>
</div>
</li>
<%}%>
</script>

</ul>
</div>
</div> 

<script src="js/mui.min.js"></script>
<script>
mui.init({
swipeBack: false,
pullRefresh: {
container: '#pullrefresh',
/*down: {
callback: pulldownRefresh
},*/
up: {
contentrefresh: '正在加载...',
callback: pullupRefresh
}
}
});

mui.plusReady(function() {
//aa();
getAllUserLimit(0,5);
});


/**
* 下拉刷新具体业务实现
*/
/*function pulldownRefresh() {
setTimeout(function() {
var table = document.body.querySelector('.mui-table-view');
var cells = document.body.querySelectorAll('.mui-table-view-cell');
for (var i = cells.length, len = i + 3; i < len; i++) {
var li = document.createElement('li');
li.className = 'mui-table-view-cell';
li.innerHTML = '<a class="mui-navigate-right">Item ' + (i + 1) + '</a>';
//下拉刷新,新纪录插到最前面;
table.insertBefore(li, table.firstChild);
}
mui('#pullrefresh').pullRefresh().endPulldownToRefresh(); //refresh completed
}, 1000);
}*/


/*function pulldownRefresh() {
console.log("fdsffffffffffff");
setTimeout(function() {
var table = document.body.querySelector('.mui-table-view');
var cells = document.body.querySelectorAll('.mui-table-view-cell');

getAllUserLimit(cells.length,3);*/

/*for (var i = cells.length, len = i + 3; i < len; i++) {
var li = document.createElement('li');
li.className = 'mui-table-view-cell';
li.innerHTML = '<a class="mui-navigate-right">Item ' + (i + 1) + '</a>';
//下拉刷新,新纪录插到最前面;
table.insertBefore(li, table.firstChild);
}
mui('#pullrefresh').pullRefresh().endPulldownToRefresh(); //refresh completed*/
/*}, 1000);
}*/



var count = 0;
/**
* 上拉加载具体业务实现
*/
/* function pullupRefresh() {
console.log("vvvvvvvvv");
setTimeout(function() {
mui('#pullrefresh').pullRefresh().endPullupToRefresh((++count > 2)); //参数为true代表没有更多数据了。
var table = document.body.querySelector('.mui-table-view');
var cells = document.body.querySelectorAll('.mui-table-view-cell');
for (var i = cells.length, len = i + 20; i < len; i++) {
var li = document.createElement('li');
li.className = 'mui-table-view-cell';
li.innerHTML = '<a class="mui-navigate-right">Item ' + (i + 1) + '</a>';
table.appendChild(li);
}
}, 1000);
}

*/
function pullupRefresh() {
setTimeout(function() {
mui('#pullrefresh').pullRefresh().endPullupToRefresh((++count > 2)); //参数为true代表没有更多数据了。
var table = document.body.querySelector('.mui-table-view');
var cells = document.body.querySelectorAll('.mui-table-view-cell');
getAllUserLimit(cells.length,5);
}, 1000);
}


function TemplateViewData(configData)
{
var data={
list:configData
};
var html=template('ul-li-template',data);
document.getElementById("ullist").innerHTML=html;
}

function viewListData(configData)
{
var table = document.body.querySelector('.mui-table-view');
var cells = document.body.querySelectorAll('.mui-table-view-cell');  
var storage = window.localStorage;
storage.setItem("userslist_data",configData);
console.log(configData[0].userInfo.nickname);

for (var i =0; i <data.userslist.length;i++) {
var nickname=data.userslist[i].userInfo.nickname;
var job=data.userslist[i].userInfo.job;
var sex='男';
if(data.userslist[i].userInfo.sex=='sexnv')
{
var sex='女';
}
var singleOrDouble=data.userslist[i].userInfo.singleOrdouble;
var birthday=data.userslist[i].userInfo.birthdayStr;
var heading=data.userslist[i].userInfo.heading;
var li = document.createElement('li');
li.className = 'mui-table-view-cell';
li.id=data.userslist[i].userInfo.user_id;
li.value=data.userslist[i];
var a='<div id="listdiv'+li+'" class="mui-slider-cell"><div class="oa-contact-cell mui-table"><div class="oa-contact-avatar mui-table-cell"><img id="heading'+li.id+'" style="width: 60px; height: 60px;" src="'+data.userslist[i].userInfo.heading+'" /></div><div class="oa-contact-content mui-table-cell"><div class="mui-clearfix"><h4 id="nickname'+li.id+'" class="oa-contact-name">'+data.userslist[i].userInfo.nickname+'</h4><span id="sex'+li.id+'" class="oa-contact-position mui-h6">'+sex+'</span>&nbsp;<span id="singleOrDouble'+li.id+'" class="oa-contact-position mui-h6">'+singleOrDouble+'</span>&nbsp;<span id="job'+li.id+'" class="oa-contact-position mui-h6">'+job+'</span></div><p class="oa-contact-email mui-h6">个人宣言aaaa:yewenjie@sina.com</p></div></div></div><div id="birthday'+li.id+'" style="display: none;">'+birthday+'</div>';
li.innerHTML=a;
li.addEventListener('tap', function(li) {
var storage = window.localStorage;
       var isLogin=storage.getItem("people_isLogin");        
       if(isLogin!=1)
       {
        alert("请先登录");
        return;
       }
       else
       {

var myliid = this.getAttribute('id');
storage.setItem("userslist_checked_user_id",myliid);
storage.setItem("userslist_checked_nickname",document.getElementById("nickname"+myliid).innerText);
storage.setItem("userslist_checked_sex",document.getElementById("sex"+myliid).innerText);
storage.setItem("userslist_checked_singleOrDouble",document.getElementById("singleOrDouble"+myliid).innerText);
storage.setItem("userslist_checked_job",document.getElementById("job"+myliid).innerText);
storage.setItem("userslist_checked_birthday",document.getElementById("birthday"+myliid).innerText);
storage.setItem("userslist_checked_heading",document.getElementById("heading"+myliid).src);

mui.openWindow({
  id:'list-userinfo5.html',
  url:'list-userinfo5.html'
});
}
});

//下拉刷新,新纪录插到最前面;
table.insertBefore(li, table.firstChild);
}
mui('#pullrefresh').pullRefresh().endPulldownToRefresh(); //refresh completed
                          
}

function getAllUserLimit(start,end)
{
//var func_url="http://192.168.21.106:8080/tan.maven.springmvc Maven Webapp/users.do?method=allUsers";  
// var func_url="http://192.168.21.106:8081/tan.maven.springmvc Maven Webapp/users.do?method=getAllUserLimit"; 
                  
               var func_url=ServerUrl.IP+"/tan.maven.springmvc Maven Webapp/users.do?method=getAllUserLimit&callback='jsoncallback'"; 
                mui.ajax(func_url,{
        data:{
start:start,end:end
},
dataType:'jsonp',//服务器返回json格式数据
//dataType:'json',
type:'post',//HTTP请求类型
//timeout:10000,//超时时间设置为10秒;
jsonp:"jsoncallback",   
success:function(data){ 
console.log("测试:"+data);    
var configData=JSON.parse(data);        //解析数据 cinfig:OK
if(configData && configData.length>0)
{TemplateViewData(configData);}
},
error:function(xhr,type,errorThrown){
//异常处理;
//console.log(xhr.Message+"  "+type+" "+errorThrown);
}  
});            
}

</script>
</body>
</html>


后台:

@RequestMapping(params = "method=getAllUserLimit")
public void getAllUserLimit(Users user,HttpServletRequest request, HttpServletResponse response) throws UnsupportedEncodingException{
System.out.println("UsersController.java getAllUserLimit");  
 request.setCharacterEncoding("utf-8");  
 int start = Integer.parseInt(request.getParameter("start"));
 int end = Integer.parseInt(request.getParameter("end"));

 userSignInDao=new UserSignInDao();
 List<UserSignIn> userslist=userSignInDao.getAllUserLimit(start, end);
 
 response.setContentType("text/html;charset=GBK");
/* JSONObject jsonObj = new JSONObject();
 jsonObj.put("userslist",userslist); */
 
//  JSONObject jsonObject = JSONObject.fromObject(jsonObj); 
// System.out.println(jsonObject);//输出  
 //JSONArray jsonArray = JSONArray.fromObject(userslist);  
  
try {
// ok1
response.setHeader("Access-Control-Allow-Origin", "");
response.setHeader("Access-Control-Allow-Headers", "X-Requested-With");
response.setHeader("Cache-Control", "no-cache");

 JSONArray jsonArray = JSONArray.fromObject(userslist);
 System.out.println(jsonArray);
 response.getWriter().print(jsonArray.toString());

//ok2
/*【需要解决】
 String jsonp=request.getParameter("callback");  
    System.out.println("jsonp "+jsonp); 
response.setHeader("Access-Control-Allow-Origin", "");
response.setHeader("Access-Control-Allow-Headers", "X-Requested-With");
response.setHeader("Cache-Control", "no-cache");
JSONArray jsonArray = JSONArray.fromObject(userslist);
System.out.println("获取"+jsonArray.toString());  
response.getWriter().print(jsonp+"("+jsonArray.toString()+")");*/

/* 【需要解决】
JSONObject jsonObj = new JSONObject();
 jsonObj.put("userslist",userslist);
JSONObject jsonObject = JSONObject.fromObject(jsonObj);
String jsonp=request.getParameter("callback");  
    System.out.println("jsonp "+jsonp);     
response.setHeader("Access-Control-Allow-Origin", "");
response.setHeader("Access-Control-Allow-Headers", "X-Requested-With");
response.setHeader("Cache-Control", "no-cache");
response.getWriter().print(jsonp+"("+jsonObject.toString()+")");*/

} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}

}



这篇关于js-引擎模板前台后台(java)实战的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/974293

相关文章

Java设计模式---迭代器模式(Iterator)解读

《Java设计模式---迭代器模式(Iterator)解读》:本文主要介绍Java设计模式---迭代器模式(Iterator),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,... 目录1、迭代器(Iterator)1.1、结构1.2、常用方法1.3、本质1、解耦集合与遍历逻辑2、统一

Java内存分配与JVM参数详解(推荐)

《Java内存分配与JVM参数详解(推荐)》本文详解JVM内存结构与参数调整,涵盖堆分代、元空间、GC选择及优化策略,帮助开发者提升性能、避免内存泄漏,本文给大家介绍Java内存分配与JVM参数详解,... 目录引言JVM内存结构JVM参数概述堆内存分配年轻代与老年代调整堆内存大小调整年轻代与老年代比例元空

深度解析Java DTO(最新推荐)

《深度解析JavaDTO(最新推荐)》DTO(DataTransferObject)是一种用于在不同层(如Controller层、Service层)之间传输数据的对象设计模式,其核心目的是封装数据,... 目录一、什么是DTO?DTO的核心特点:二、为什么需要DTO?(对比Entity)三、实际应用场景解析

Java 线程安全与 volatile与单例模式问题及解决方案

《Java线程安全与volatile与单例模式问题及解决方案》文章主要讲解线程安全问题的五个成因(调度随机、变量修改、非原子操作、内存可见性、指令重排序)及解决方案,强调使用volatile关键字... 目录什么是线程安全线程安全问题的产生与解决方案线程的调度是随机的多个线程对同一个变量进行修改线程的修改操

从原理到实战深入理解Java 断言assert

《从原理到实战深入理解Java断言assert》本文深入解析Java断言机制,涵盖语法、工作原理、启用方式及与异常的区别,推荐用于开发阶段的条件检查与状态验证,并强调生产环境应使用参数验证工具类替代... 目录深入理解 Java 断言(assert):从原理到实战引言:为什么需要断言?一、断言基础1.1 语

深度解析Java项目中包和包之间的联系

《深度解析Java项目中包和包之间的联系》文章浏览阅读850次,点赞13次,收藏8次。本文详细介绍了Java分层架构中的几个关键包:DTO、Controller、Service和Mapper。_jav... 目录前言一、各大包1.DTO1.1、DTO的核心用途1.2. DTO与实体类(Entity)的区别1

Java中的雪花算法Snowflake解析与实践技巧

《Java中的雪花算法Snowflake解析与实践技巧》本文解析了雪花算法的原理、Java实现及生产实践,涵盖ID结构、位运算技巧、时钟回拨处理、WorkerId分配等关键点,并探讨了百度UidGen... 目录一、雪花算法核心原理1.1 算法起源1.2 ID结构详解1.3 核心特性二、Java实现解析2.

SpringBoot整合liteflow的详细过程

《SpringBoot整合liteflow的详细过程》:本文主要介绍SpringBoot整合liteflow的详细过程,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋...  liteflow 是什么? 能做什么?总之一句话:能帮你规范写代码逻辑 ,编排并解耦业务逻辑,代码

JavaSE正则表达式用法总结大全

《JavaSE正则表达式用法总结大全》正则表达式就是由一些特定的字符组成,代表的是一个规则,:本文主要介绍JavaSE正则表达式用法的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录常用的正则表达式匹配符正则表China编程达式常用的类Pattern类Matcher类PatternSynta

Spring Security中用户名和密码的验证完整流程

《SpringSecurity中用户名和密码的验证完整流程》本文给大家介绍SpringSecurity中用户名和密码的验证完整流程,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定... 首先创建了一个UsernamePasswordAuthenticationTChina编程oken对象,这是S