目录
Layui(谐音:类 UI) 是一套开源的 Web UI 解决方案;
由国人开发(作者贤心),16年出厂的框架;
其风格简约轻盈,而组件优雅丰盈,从源代码到使用方法的每一处细节都经过精心雕琢,
非常适合网页界面的快速开发;
极大减少了后端人员的开发成本。
① 更偏向与后端开发人员使用,在服务端页面上有非常好的效果;
② 适合做后台框架;
③ layui更符合现在的审美。
由于LayUI在2021年的10月份下线了,所以现在的参考网站则是后面有大佬保存下来的,
保留了原来的文档提供学习参考!
官方网站:https://www.layui.com/(已下线)
参考地址:http://layui.org.cn/demo/index.html(已下线,非官网)
我们进入参考地址,看到这个首页:

我们直接下载,得到一个这种的压缩包:

我们把它解压,得到一个layui的文件夹:

然后就直接把它导入我们自己的工程就好啦!
我们在文档中可以学习到如何引入使用,Leaf这里直接也放上引入重点:
注意:这里的href和src都是根据我们放入自己的工程目录位置来写的,不要忘记修改噢!
<!-- 引入 layui.css -->
<link rel="stylesheet" href="${pageContext.request.contextPath }/static/js/layui/css/layui.css">
<!-- 引入 layui.js -->
<script src="${pageContext.request.contextPath }/static/js/layui/layui.js"></script>
当我们引入好css和js文件后就可以开始尝试测试使用一下啦,
我们就来测试一下弹出输入内容的这个功能吧~
这里直接放上代码:
<h3>请输入:</h3>
<input type="text" value="Leaf" id="layui_test1_input">
<button id="layui_test1_btn" style="cursor: pointer;">点我</button>
<script>
//导入js相关的模块jquery.js
layui.use(['layer', 'form', 'jquery'], function(){
//将模块赋值给变量$
var layer = layui.layer
,form = layui.form
,$ = layui.jquery;
$("#layui_test1_btn").click(function(){
var val = $("#layui_test1_input").val();
layer.msg(val);
});
layer.msg('Hello World');
});
</script>
运行结果:


LayUI每使用一个模块功能就需要导入加载一个模块,然后为其定义一个变量并赋值。
通过上面对LayUI的测试使用后,我们得到了一些结论,同时也得到了一个疑问:
4.1 如何自定义功能模块
对的,当作者写好的模块不足以支撑我们的需求时,如何去自定义一个模块呢?
在官方文档上学习了一下,下面来一起看看吧~
我们直接在导入的layui那个文件夹下建立一个mymodules(就是我的模块),
然后再建一个子文件夹:js
就在这个js文件夹里建立我们自定义的模块js文件:mymod.js
layui.define(function(exports){ //提示:模块也可以依赖其它模块,如:layui.define('mod1', callback);
var obj = {
hello: function(str){
alert('Hello '+ (str||'mymod'));
},say: function(str){
alert('say '+ (str||'mymod'));
}
};
//输出 mymod 接口
exports('mymod', obj);
});
紧接着我们再建立一个配置文件:mymod_config.js
注意:这里的base目录一定要看清楚!是你存放自定义模块的根目录,结尾不是放文件!!!
//config的设置是全局的
layui.config({
base: 'static/js/layui/mymodules/js/' //假设这是你存放拓展模块的根目录
}).extend({ //设定模块别名
mymod: 'mymod' //如果 mymod.js 是在根目录,也可以不用设定别名
});

我们在建立好自己的模块后,就可以开始引入测试啦!
注意要引入的是mymod.js以及配置文件mymod_config.js噢~
<!-- 引入 layui.css -->
<link rel="stylesheet" href="${pageContext.request.contextPath }/static/js/layui/css/layui.css">
<!-- 引入 layui.js -->
<script src="${pageContext.request.contextPath }/static/js/layui/layui.js"></script>
<!-- 引入自定义的模块mymod.js-->
<script src="${pageContext.request.contextPath }/static/js/layui/mymodules/js/mymod.js"></script>
<script src="${pageContext.request.contextPath }/static/js/layui/mymodules/mymodule_config.js"></script>
<input type="text" value="Leaf" id="layui_test2_input">
<button id="layui_test2_btn" style="cursor: pointer;">自定义模块</button>
<script>
//导入js相关的模块mymod.js
//将模块赋值给变量mymod
layui.use(['layer', 'form', 'jquery', 'mymod'], function(){
var layer = layui.layer
,form = layui.form
,mymod = layui.mymod
,$ = layui.jquery;
//给自定义模块按钮添加点击事件
$("#layui_test2_btn").click(function(){
var val2 = $("#layui_test2_input").val();
mymod.say(val2);
mymod.hello(val2);
});
layer.msg('Hello World');
});
</script>
运行结果:



利用我们之前编写的MVC,我们编写一个action:UserAction
不了解的可以参考Leaf之前的几篇文章:自定义MVC(上)__Leaf1217的博客-CSDN博客
这里直接放上代码:
package com.leaf.web;
import java.util.HashMap;
import java.util.Map;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import com.leaf.entity.User;
import com.leaf.mvc.ActionSupport;
import com.leaf.mvc.ModelDriven;
import com.leaf.util.R;
import com.leaf.util.ResponseUtil;
public class UserAction extends ActionSupport implements ModelDriven<User> {
private User user = new User();
//写一个方法处理前台的请求
public String login(HttpServletRequest req, HttpServletResponse resp) {
Map<String, Object> map = new HashMap<String,Object>();
if("Leaf".equals(user.getUsername()) && "999999".equals(user.getPassword())) {
//登录成功
map.put("code", 200);
map.put("msg", "成功!");
}else {
//登录失败
map.put("code", 0);
map.put("msg", "账户或者密码错误!");
}
try {
ResponseUtil.writeJson(resp, map);
} catch (Exception e) {
e.printStackTrace();
}
return null;
}
@Override
public User getModel() {
return user;
}
}
前台这里就不过多阐述了,就注意一下如何使用的那一段javascript代码就好啦~
这里直接放上代码,就是没有放图片,你们运行可能没有好看的效果;
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!-- 引入layui -->
<%@ include file="common/header.jsp" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>登录</title>
<link rel="stylesheet" rev="stylesheet" href="${pageContext.request.contextPath }/static/css/iconfont.css" type="text/css" media="all">
<link rel="stylesheet" rev="stylesheet" href="${pageContext.request.contextPath }/static/css/login.css" type="text/css" media="all">
<style>
body{color:#;}a{color:#;}a:hover{color:#;}.bg-black{background-color:#;}.tx-login-bg{background:url(static/images/bg.jpg) no-repeat 0 0;}
</style>
</head>
<body class="tx-login-bg">
<div class="tx-login-box">
<div class="login-avatar bg-black"><i class="iconfont icon-wode"></i></div>
<ul class="tx-form-li row">
<li class="col-24 col-m-24"><p><input type="text" id="username" placeholder="登录账号" class="tx-input"></p></li>
<li class="col-24 col-m-24"><p><input type="password" id="password" placeholder="登录密码" class="tx-input"></p></li>
<li class="col-24 col-m-24"><p class="tx-input-full"><button id="login" class="tx-btn tx-btn-big bg-black">登录</button></p></li>
<li class="col-12 col-m-12"><p><a href="#" class="f-12 f-gray">新用户注册</a></p></li>
<li class="col-12 col-m-12"><p class="ta-r"><a href="#" class="f-12 f-gray">忘记密码</a></p></li>
</ul>
</div>
<script type="text/javascript">
layui.use(['jquery','layer'],function(){
let $ = layui.jquery
,layer = layui.layer;
$('#login').click(function() {
$.ajax({
url:"${pageContext.request.contextPath }/user.action?methodName=login"
,dataType:'json'
,data:{
username:$("#username").val(),
password:$("#password").val()
}
,success:function(data){
//console.log(data);
if(data.code == 200){
layer.alert('登录成功!', {icon: 1});
location.href='index.jsp';
}
else{
layer.alert('登录失败!', {icon: 2});
}
}
});
});
});
</script>
</body>
</html>
输入错误信息:
输入正确信息:

OK,今天Leaf带来的学习分享就到这里啦,有问题的可以私信或者评论问我噢,喜欢的可以关注一起学习进步啊,下次见!!!
我正在学习如何使用Nokogiri,根据这段代码我遇到了一些问题:require'rubygems'require'mechanize'post_agent=WWW::Mechanize.newpost_page=post_agent.get('http://www.vbulletin.org/forum/showthread.php?t=230708')puts"\nabsolutepathwithtbodygivesnil"putspost_page.parser.xpath('/html/body/div/div/div/div/div/table/tbody/tr/td/div
我有一个Ruby程序,它使用rubyzip压缩XML文件的目录树。gem。我的问题是文件开始变得很重,我想提高压缩级别,因为压缩时间不是问题。我在rubyzipdocumentation中找不到一种为创建的ZIP文件指定压缩级别的方法。有人知道如何更改此设置吗?是否有另一个允许指定压缩级别的Ruby库? 最佳答案 这是我通过查看rubyzip内部创建的代码。level=Zlib::BEST_COMPRESSIONZip::ZipOutputStream.open(zip_file)do|zip|Dir.glob("**/*")d
类classAprivatedeffooputs:fooendpublicdefbarputs:barendprivatedefzimputs:zimendprotecteddefdibputs:dibendendA的实例a=A.new测试a.foorescueputs:faila.barrescueputs:faila.zimrescueputs:faila.dibrescueputs:faila.gazrescueputs:fail测试输出failbarfailfailfail.发送测试[:foo,:bar,:zim,:dib,:gaz].each{|m|a.send(m)resc
很好奇,就使用rubyonrails自动化单元测试而言,你们正在做什么?您是否创建了一个脚本来在cron中运行rake作业并将结果邮寄给您?git中的预提交Hook?只是手动调用?我完全理解测试,但想知道在错误发生之前捕获错误的最佳实践是什么。让我们理所当然地认为测试本身是完美无缺的,并且可以正常工作。下一步是什么以确保他们在正确的时间将可能有害的结果传达给您? 最佳答案 不确定您到底想听什么,但是有几个级别的自动代码库控制:在处理某项功能时,您可以使用类似autotest的内容获得关于哪些有效,哪些无效的即时反馈。要确保您的提
假设我做了一个模块如下:m=Module.newdoclassCendend三个问题:除了对m的引用之外,还有什么方法可以访问C和m中的其他内容?我可以在创建匿名模块后为其命名吗(就像我输入“module...”一样)?如何在使用完匿名模块后将其删除,使其定义的常量不再存在? 最佳答案 三个答案:是的,使用ObjectSpace.此代码使c引用你的类(class)C不引用m:c=nilObjectSpace.each_object{|obj|c=objif(Class===objandobj.name=~/::C$/)}当然这取决于
我正在尝试使用ruby和Savon来使用网络服务。测试服务为http://www.webservicex.net/WS/WSDetails.aspx?WSID=9&CATID=2require'rubygems'require'savon'client=Savon::Client.new"http://www.webservicex.net/stockquote.asmx?WSDL"client.get_quotedo|soap|soap.body={:symbol=>"AAPL"}end返回SOAP异常。检查soap信封,在我看来soap请求没有正确的命名空间。任何人都可以建议我
关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭4年前。Improvethisquestion我想在固定时间创建一系列低音和高音调的哔哔声。例如:在150毫秒时发出高音调的蜂鸣声在151毫秒时发出低音调的蜂鸣声200毫秒时发出低音调的蜂鸣声250毫秒的高音调蜂鸣声有没有办法在Ruby或Python中做到这一点?我真的不在乎输出编码是什么(.wav、.mp3、.ogg等等),但我确实想创建一个输出文件。
我正在尝试测试是否存在表单。我是Rails新手。我的new.html.erb_spec.rb文件的内容是:require'spec_helper'describe"messages/new.html.erb"doit"shouldrendertheform"dorender'/messages/new.html.erb'reponse.shouldhave_form_putting_to(@message)with_submit_buttonendendView本身,new.html.erb,有代码:当我运行rspec时,它失败了:1)messages/new.html.erbshou
我在从html页面生成PDF时遇到问题。我正在使用PDFkit。在安装它的过程中,我注意到我需要wkhtmltopdf。所以我也安装了它。我做了PDFkit的文档所说的一切......现在我在尝试加载PDF时遇到了这个错误。这里是错误:commandfailed:"/usr/local/bin/wkhtmltopdf""--margin-right""0.75in""--page-size""Letter""--margin-top""0.75in""--margin-bottom""0.75in""--encoding""UTF-8""--margin-left""0.75in""-
我在我的项目目录中完成了compasscreate.和compassinitrails。几个问题:我已将我的.sass文件放在public/stylesheets中。这是放置它们的正确位置吗?当我运行compasswatch时,它不会自动编译这些.sass文件。我必须手动指定文件:compasswatchpublic/stylesheets/myfile.sass等。如何让它自动运行?文件ie.css、print.css和screen.css已放在stylesheets/compiled。如何在编译后不让它们重新出现的情况下删除它们?我自己编译的.sass文件编译成compiled/t