初识grails的效果

写了个简单的增删查改的demo,用于了解grails的编程思路及风格,也便于自己以后查阅

User.groovy

package com.demo

class User {
	String name
    Integer age
	Date birthday
	
    static constraints = {
		name blank:false
		age blank:false
		birthday blank:false
    }
}
UserController.groovy

package com.demo

import grails.converters.JSON;

class UserController {
	
	def beforeInterceptor = {
		println "Tracing action ${actionUri}"
	}
	
	def index(){}

    def listByServer() { 
		def userList = User.findAll()
		
		render (contentType: "text/html") {
			table (style: "border:1") {
				for (u in userList) {
					tr(
						td(u.id), 
						td(u.name),
						td(u.birthday)
					)
				}
			}
		}
	}
	
	def upload(){
	}
	
	def doUpload() {
		def f = request.getFile('myFile')
		if (f.empty) {
			flash.message = 'file cannot be empty'
			render(view: 'upload')
			return
		}
		f.transferTo(new File('c:/myfile.txt'))
		response.sendError(200, 'Done')
	}
	
	def list(){
		[users : User.list()]
	}
	
	def detail() {
		def userId = request.getParameter("id")
		if (userId == null) {
			flash.message = "input your user id"
			render(view: 'detail')
		} else {
			def user = User.get(userId)
			if (user == null) {
				flash.message = "user does not exist"
				render(view: 'detail')
			} else {
				flash.message = "this user detail is shown as below"
				render (view:"detail", model:[userBean:user])
			}
		}
	}
	
	def edit() {
		def user = User.get(params.id)
		user.name = params.name
		user.birthday = params.birthday
		user.save();
		
		render "edit success"
	}
	
	def delete() {
		def returnMap = ['success':false, 'msg':'']
		def userId = request.getParameter("id")
		if (userId == null) {
			returnMap.msg = "user does not exist"
			render returnMap as JSON
		} else {
			def user = User.get(userId)
			if (user == null) {
				returnMap.msg = "user does not exist"
				render returnMap as JSON
			} else {
				user.delete();
				returnMap.msg = "delete success"
				returnMap.success = true
				render returnMap as JSON
			}
		}
	}
}

list.gsp

<html>
	<head>
		<meta name="layout" content="main">
		<title>Welcome</title>
	</head>
	<body id="welcome">
		<div id="container">
			<table>
				<thead>
					<tr>
						<th>ID</th>
						<th>NAME</th>
						<th>BIRTHDAY</th>
					</tr>
				</thead>
				<tbody>
					<g:each in="${users }" var="user">
						<tr>
							<td>${user.id }</td>
							<td>${user.name }</td>
							<td>${user.birthday }</td>
						</tr>
					</g:each>
				</tbody>
			</table>
		</div>
	</body>
</html>

detail.gsp

<html>
	<head>
		<meta name="layout" content="main">
		<title>Welcome</title>
		<g:javascript>
			function handleDelete(data) {
				$("#message").html(data.msg);
				if (data.success) {
					$("#edit").hide();
				}
			}
		</g:javascript>
	</head>
	<body id="welcome">
		<div id="container">
			<g:form action="detail" >
			<g:textField name="id"/>
			<g:submitButton name="submit"/>
			</g:form>
			${flash.message} <br />
			<g:if test="${userBean != null }">
			<g:formRemote url="[controller: 'user', action: 'edit']" update="message" name="edit">
				<g:textField name="id" value="${userBean.id }"/>
				<g:textField name="name" value="${userBean.name }"/>
				<g:datePicker name="birthday" value="${userBean.birthday }" />
			<input type="submit" value="EDIT" />
			<g:submitToRemote action="delete" onSuccess="handleDelete(data)" value="DELETE" />
			</g:formRemote>
			</g:if>
			<div id="message"></div>
		</div>
	</body>
</html>


效果如下图:



评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值