Jasperreport+ireport 实践操作及web应用
1.字段,变量,參数,传參
2.矢量图,位图
3.超链接,锚
4.数据源,自己定义数据源
5.国际化(I18N)
6.脚本
7.子报表
8.图表(饼图,柱图,线图)
9.导出pdf,xls,html...
操作版本号:jasperreports2.0.2+ireport2.0.2
下面针对每一个知识点,解说在ireport中是怎样操作,以及在真实项目中怎样部署.
点击 Parameters 菜单,此时弹出一个操作參数的窗体,单击 New button,输入參数名(Parameter Name),选择參数类型(Parameter Class Type),如要赋一个默认值则填写默认值表达式(Default Value Expression)(默认值如为字符串则以"string"形式填写,如为整形则以 new Integer(1) 形式填写,以此类推.),填好后,点 OK 就新建了一个參数了.
定义字段与定义參数是一样的操作,至于定义变量操作差点儿相同,也相对少用一些,在此就不讲述.
在ireport中怎样引用字段,变量,參数?
引用字段使用 $F{field_name}
引用变量使用 $V{variable_name}
引用參数使用 $P{param_name} 或 $P!{param_name}
$P!{param_name}一般用于拼接sql语句,它的值能够与sql语句拼接后,再去运行查询.
例:定义一个參数名为 where 类型为String 默认值为 "where id=100"
有一查询语句:select * from user $P!{where}
则运行查询时会替换成:select * from user where id=100
$P{param_name}在sql语句中使用时,也有一特殊情况.
例:有一參数名为 id,类型为Integer,默认值为 new Integer(100)
有一查询语句:select * from user where id=$P{id}
运行查询可正常查询,但假设有一參数名为 name,类型为String,默认值为"zhanngle"
有一查询语句:select * from user where name=$P{name}
运行查询时出错,不知道为什么(即使数据库中有该条记录),不知是不是bug,还是自已哪里弄错了.解决的方法是,将查询语句改为:select * from user where name='$P!{name}'
能够证明$P!{}语法,仅仅做替换操作,如上仅仅将$P!{name}替换成zhanngle.
也能够证明$P{}语法,在sql语句中使用时,值为数字类型还能够正常运行,如为字符串类型则会出错.
在程序中怎样传參? 如上例定义了一个name參数,那么在程序中怎样动态传參查询出不同的记录呢,也非常easy.
程序代码例如以下:
params.put("name","zhanngle");
JasperPrint print=JasperFillManager.fillReport(jasper, params,conn);
就是将參数名和值put进入一map,然后再填充报表时将map传过去即可了.
图与图之间(更详细的说法,应该是元素与元素之间)不能有不论什么重叠,如重叠则仅仅能显示最上层的图.
使用线条工具能够绘制斜线,当导出为pdf文件,没有不论什么问题,当导出html,xls文件时,发现斜线变成了矩形,解决方式是:使用外部图形编辑软件,绘制一条斜线,并保存为图片文件,再将这个图片文件插入到报表对应位置中.
你也能够设置使用我们配制的外部程序来预览,点Build -> PDF Preview,再点Execute (empty data source)button,就可以预览PDF文件。点Build -> HTML Preview,再点Execute (empty data source)button。就可以预览HTML文件。
定义一个參数名为 imageName 类型:String 没有默认值
在报表设计界面中绘制一个Image,打开该Image的属性框,选Image选项卡,在Image Expression文本框中输入:$P{imageName},代表该图片的路径是由imageName的參数值来决定的,我们能够在程序中传入该參数的值.
Map params=new HashMap();
Params.put(“imageName”,context.getRealPath(“/reports/test.jpg”));
JasperPrint print=JasperFillManager.fillReport(jasper, params,conn);
<servlet-name>JasperreportsImageServlet</servlet-name>
<servlet-class>net.sf.jasperreports.j2ee.servlets.ImageServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>JasperreportsImageServlet</servlet-name>
<url-pattern>/servlets/image</url-pattern>
</servlet-mapping>
2.程序代码按下面方式编写
Map params=new HashMap();
Params.put(“imageName”,context.getRealPath(“/reports/test.jpg”));
Map imageMap=new HashMap();
request.getSession().setAttribute("IMAGES_MAP", imageMap);
JasperPrint print=JasperFillManager.fillReport(jasper,params,conn);
request.getSession().setAttribute(net.sf.jasperreports.j2ee.servlets.ImageServlet.DEFAULT_JASPER_PRINT_SESSION_ATTRIBUTE,print);
JRHtmlExporter exporter = new JRHtmlExporter();
exporter.setParameter(JRExporterParameter.JASPER_PRINT, print);
exporter.setParameter(JRExporterParameter.OUTPUT_WRITER, response.getWriter());
exporter.setParameter(JRHtmlExporterParameter.IMAGES_MAP,imageMap);
exporter.setParameter(JRHtmlExporterParameter.IMAGES_URI, request.getContextPath()+"/servlets/image?
image=");
exporter.setParameter(JRHtmlExporterParameter.IS_REMOVE_EMPTY_SPACE_BETWEEN_ROWS, Boolean.TRUE);
exporter.setParameter(JRHtmlExporterParameter.IS_USING_IMAGES_TO_ALIGN, Boolean.TRUE);
要包括双引號)
否则配制错误,请检查哪里出错。
调整好Detail区域的高度,执行(Build -> Execute (whit active connection))一下看看吧,假设你看到有正确数据,那恭喜你,你试验成功了!
...{
public boolean next() throws JRException;
public Object getFieldValue(JRField jrField) throws
JRException;
}
下面我是我自己定义的一个数据源码:
import java.sql.Timestamp;
publicclass Bean ...{
privateintID;
private String NAME;
private String NICKNAME;
privateintSCORE;
privatefloatBALANCE;
private Timestamp LASTLOGINDATE;
publicfloat getBALANCE() ...{
returnBALANCE;
}
publicvoid setBALANCE(float balance) ...{
this.BALANCE = balance;
}
publicint getID() ...{
returnID;
}
publicvoid setID(int id) ...{
this.ID = id;
}
public Timestamp getLASTLOGINDATE() ...{
returnLASTLOGINDATE;
}
publicvoid setLASTLOGINDATE(Timestamp lastLoginDate) ...{
this.LASTLOGINDATE = lastLoginDate;
}
public String getNAME() ...{
returnNAME;
}
publicvoid setNAME(String name) ...{
this.NAME = name;
}
public String getNICKNAME() ...{
returnNICKNAME;
}
publicvoid setNICKNAME(String nickname) ...{
this.NICKNAME = nickname;
}
publicint getSCORE() ...{
returnSCORE;
}
publicvoid setSCORE(int score) ...{
this.SCORE = score;
}
}
2.创建实现数据源类
import java.sql.Timestamp;
import java.util.ArrayList;
import java.util.List;
import org.apache.commons.beanutils.PropertyUtils;
import net.sf.jasperreports.engine.JRDataSource;
import net.sf.jasperreports.engine.JRException;
import net.sf.jasperreports.engine.JRField;
publicclass TestBeanDataSource implements JRDataSource ...{
private List list;
privateintindex;
public TestBeanDataSource() ...{
list=new ArrayList();
Bean bean=null;
;i++) ...{
bean=new Bean();
bean.setID(i);
bean.setNAME("name"+i);
bean.setNICKNAME("nickname"+i);
bean.setBALANCE((*i));
bean.setSCORE(i);
bean.setLASTLOGINDATE(new Timestamp(System.currentTimeMillis()));
list.add(bean);
}
}
publicboolean next() throws JRException ...{
return ++index<list.size();
// return false;
}
public Object getFieldValue(JRField field) throws JRException ...{
Bean bean=(Bean)list.get(index);
String fieldName=field.getName();
try ...{
return PropertyUtils.getProperty(bean,fieldName);
} catch (Exception e) ...{
thrownew JRException(e);
}
}
public List getList() ...{
returnlist;
}
publicvoid setList(List list) ...{
this.list = list;
}
}
3.在填充报表时将该DataSource传进去即可了。
JRHtmlExporter exporter = new JRHtmlExporter();
…
exporter.setParameter(JRExporterParameter.JASPER_PRINT, print);
…
exporter.exportReport();
此时报表数据的来源。就是从自己定义数据源中得到的100条记录。
import net.sf.jasperreports.engine.JRDataSource;
publicclass TestCustomJRDataSourceFactory ...{
publicstatic JRDataSource test() ...{
returnnew TestBeanDataSource();
}
}
2.因为是自己定义数据源,因此要将数据源引用的相关类,所有引入ireport的classpath。以供ireport调用,否则ireport会抛java.lang.ClassNotFoundException。比如我以上三个类都是放在d:/workspace/jasperreports/classes文件夹下,那么点 Options -> Classpath -> Add Folder 选择d:/workspace/jasperreports/classes,选择好后,点Save Classpath。
5.国际化(I18N)
假设你对ResourceBundle类有些了解,那么你就会知道输入的是什么意思。
国际化,然后保存。
再编辑I18NTest_en.properties,在属性文件里添加一条i18n=hello I18n,保存。
arg1
)脚本中的一些方法被报表引擎的调用,当一些特殊的事件,像创建一个新页或者处理detail 行。
/** *//**
* @author Teodor Danciu (teodord@users.sourceforge.net)
* @version $Id: JRDefaultScriptlet.java,v 1.3 2004/06/01 20:28:22
teodord Exp $
*/
public class JRDefaultScriptlet extends JRAbstractScriptlet
...{
public JRDefaultScriptlet() ...{ }
public void beforeReportInit() throws JRScriptletException
...{
}
public void afterReportInit() throws JRScriptletException
...{
}
public void beforePageInit() throws JRScriptletException
...{
}
public void afterPageInit() throws JRScriptletException
...{
}
public void beforeColumnInit() throws JRScriptletException
...{
}
public void afterColumnInit() throws JRScriptletException
...{
}
public void beforeGroupInit(String groupName) throws
JRScriptletException
...{
}
public void afterGroupInit(String groupName) throws
JRScriptletException
...{
}
public void beforeDetailEval() throws JRScriptletException
...{
}
public void afterDetailEval() throws JRScriptletException
...{
}
}
public class <ScriptletClassName> extends it.businesslogic.ireport.IReportScriptlet ...{
/** *//** Creates a new instance of JRIreportDefaultScriptlet */
public <ScriptletClassName>() ...{
System.out.println("create scriptlet...");
}
public int max(int a,int b) ...{
if(a>=b) return a;
return b;
}
}
然后点Save保存。即创建了一个脚本。并再保存报表文件,此时你能够到报表文件文件夹找到一个TestScriptleScriptlet的java文件。这就是ireport自己主动生成的脚本类文件(脚本类名= 报表名+Scriptlet)。
8.图表(饼图,柱图,线图)
9.导出pdf,xls,html...
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.io.PrintWriter;
import java.io.StringWriter;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.util.HashMap;
import java.util.Map;
import javax.servlet.ServletContext;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import oracle.jdbc.driver.OracleDriver;
import test.TestBeanDataSource;
import net.sf.jasperreports.engine.JRAbstractExporter;
import net.sf.jasperreports.engine.JREmptyDataSource;
import net.sf.jasperreports.engine.JRException;
import net.sf.jasperreports.engine.JRExporterParameter;
import net.sf.jasperreports.engine.JasperCompileManager;
import net.sf.jasperreports.engine.JasperExportManager;
import net.sf.jasperreports.engine.JasperFillManager;
import net.sf.jasperreports.engine.JasperPrint;
import net.sf.jasperreports.engine.JasperReport;
import net.sf.jasperreports.engine.JasperRunManager;
import net.sf.jasperreports.engine.base.JRBaseReport;
import net.sf.jasperreports.engine.export.JExcelApiExporter;
import net.sf.jasperreports.engine.export.JRHtmlExporter;
import net.sf.jasperreports.engine.export.JRHtmlExporterParameter;
import net.sf.jasperreports.engine.export.JRXlsExporterParameter;
import net.sf.jasperreports.engine.export.JRXmlExporter;
import net.sf.jasperreports.engine.util.JRLoader;
import net.sf.jasperreports.j2ee.servlets.ImageServlet;
publicclass ExportReportServlet extends HttpServlet ...{
/** *//**
*Destructionoftheservlet.<br>
*/
publicvoid destroy() ...{
super.destroy(); // Just puts "destroy" string in log
// Put your code here
}
publicvoid doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException ...{
String view=request.getParameter("view");
) return;
if(view.equalsIgnoreCase("html")) doHtml(request,response);
if(view.equalsIgnoreCase("pdf")) doPdf(request,response);
if(view.equalsIgnoreCase("xls")) doExcel(request,response);
if(view.equalsIgnoreCase("xml")) doXml(request,response);
}
privatevoid doHtml(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException ...{
ServletContext context=getServletContext();
//String jrxml=context.getRealPath("/WEB-INF/reports/Test1.jrxml");
/**//*
try {
String jasper=context.getRealPath("/WEB-INF/reports/Test1.jasper");
String html="/reports/"+System.currentTimeMillis()+".html";
JasperRunManager.runReportToHtmlFile(jasper,context.getRealPath(html),new HashMap(),getConn());
response.sendRedirect(request.getContextPath()+html);
} catch (JRException e) { e.printStackTrace(); }
*/
String reportDir=context.getRealPath("/WEB-INF/reports");
String jasper=reportDir+"/Test1.jasper";
response.setContentType("text/html");
response.setCharacterEncoding("utf-8");
Map map=new HashMap();
Map imageMap=new HashMap();
map.put("exportType","html");
map.put("imageTest",context.getRealPath("/reports/star.gif"));
map.put("SUBREPORT_DIR",reportDir+"/");
request.getSession().setAttribute("IMAGES_MAP", imageMap);
Connection conn=getConn();
try ...{
// JasperPrint print=JasperFillManager.fillReport(jasper,map,new TestBeanDataSource());
JasperPrint print=JasperFillManager.fillReport(jasper,map,conn);
// JasperPrint print=JasperFillManager.fillReport(jasper,map,new JREmptyDataSource());
JRHtmlExporter exporter = new JRHtmlExporter();
request.getSession().setAttribute(ImageServlet.DEFAULT_JASPER_PRINT_SESSION_ATTRIBUTE,print);
exporter.setParameter(JRExporterParameter.JASPER_PRINT, print);
exporter.setParameter(JRExporterParameter.OUTPUT_WRITER, response.getWriter());
exporter.setParameter(JRHtmlExporterParameter.IMAGES_MAP,imageMap);
exporter.setParameter(JRHtmlExporterParameter.IMAGES_URI, request.getContextPath()+"/servlets/image?image=");
exporter.setParameter(JRHtmlExporterParameter.IS_REMOVE_EMPTY_SPACE_BETWEEN_ROWS, Boolean.TRUE);
exporter.setParameter(JRHtmlExporterParameter.IS_USING_IMAGES_TO_ALIGN, Boolean.TRUE);
exporter.exportReport();
} catch (JRException e) ...{
StringWriter sw=new StringWriter();
PrintWriter pw=new PrintWriter(sw);
e.printStackTrace(pw);
response.setContentType("text/plain");
response.getOutputStream().print(sw.toString());
} finally ...{
if(conn!=null)
try ...{
if(!conn.isClosed()) conn.close();
} catch (SQLException e) ...{
e.printStackTrace();
}
}
}
privatevoid doPdf(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException ...{
ServletContext context=getServletContext();
//String jrxml=context.getRealPath("/WEB-INF/reports/Test1.jrxml");
String reportDir=context.getRealPath("/WEB-INF/reports");
String jasper=reportDir+"/Test1.jasper";
response.setContentType("application/pdf");
Map map=new HashMap();
map.put("exportType","pdf");
map.put("imageTest",context.getRealPath("/reports/star.gif"));
map.put("SUBREPORT_DIR",reportDir+"/");
Connection conn=getConn();
try ...{
OutputStream os=response.getOutputStream();
InputStream is=new FileInputStream(jasper);
JasperRunManager.runReportToPdfStream(is,os,map,conn);
// JasperRunManager.runReportToPdfStream(is,os,map,new TestBeanDataSource());
os.flush();
os.close();
} catch (JRException e) ...{
StringWriter sw=new StringWriter();
PrintWriter pw=new PrintWriter(sw);
e.printStackTrace(pw);
response.setContentType("text/plain");
response.getOutputStream().print(sw.toString());
} finally ...{
if(conn!=null)
try ...{
if(!conn.isClosed()) conn.close();
} catch (SQLException e) ...{
e.printStackTrace();
}
}
}
privatevoid doExcel(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException ...{
ServletContext context=getServletContext();
String reportDir=context.getRealPath("/WEB-INF/reports");
String jasper=reportDir+"/Test1.jasper";
response.setContentType("application/vnd.ms-excel");
response.setHeader("Content-Disposition","attachment;filename=Test1.xls");
Map map=new HashMap();
map.put("exportType","xls");//设置參数,导出类型为xls
map.put("imageTest",context.getRealPath("/reports/star.gif"));// 设置參数,图片路径
map.put("SUBREPORT_DIR",reportDir+"/");
Connection conn=getConn();
try ...{
JasperReport report=(JasperReport)JRLoader.loadObject(jasper);
try ...{//设置上边距,左边距,右边距,下边距为0
java.lang.reflect.Field margin = JRBaseReport.class.getDeclaredField("leftMargin");
margin.setAccessible(true);
margin.setInt(report, );
margin = JRBaseReport.class.getDeclaredField("topMargin");
margin.setAccessible(true);
margin.setInt(report, );
margin = JRBaseReport.class.getDeclaredField("rightMargin");
margin.setAccessible(true);
margin.setInt(report, );
margin = JRBaseReport.class.getDeclaredField("bottomMargin");
margin.setAccessible(true);
margin.setInt(report, );
//去掉Excel中隐藏的行,技巧
java.lang.reflect.Field pageHeight = JRBaseReport.class.getDeclaredField("pageHeight");
pageHeight.setAccessible(true);
pageHeight.setInt(report, Integer.MAX_VALUE);
//Don't print group header on each page
if (null != report.getGroups())
...{
; i < report.getGroups().length; i++)
...{
report.getGroups()[i].setReprintHeaderOnEachPage(false);
}
}
} catch(Exception e) ...{ e.printStackTrace(); }
JasperPrint print=JasperFillManager.fillReport(report,map,conn);//填充数据
// JasperPrint print=JasperFillManager.fillReport(report,map,new TestBeanDataSource());//填充数据
JRAbstractExporter exporter=new JExcelApiExporter();
exporter.setParameter(JRExporterParameter.JASPER_PRINT,print);
exporter.setParameter(JRExporterParameter.OUTPUT_STREAM,response.getOutputStream());
exporter.setParameter(JRXlsExporterParameter.IS_REMOVE_EMPTY_SPACE_BETWEEN_ROWS,
Boolean.TRUE);//删除空白行
exporter.setParameter(JRXlsExporterParameter.IS_ONE_PAGE_PER_SHEET,Boolean.FALSE);//是否是每一页产生一个工作表
exporter.setParameter(JRXlsExporterParameter.IS_WHITE_PAGE_BACKGROUND, Boolean.FALSE);//是否为空白背景
exporter.exportReport();
response.getOutputStream().flush();
response.getOutputStream().close();
} catch (JRException e) ...{
StringWriter sw=new StringWriter();
PrintWriter pw=new PrintWriter(sw);
e.printStackTrace(pw);
response.setContentType("text/plain");
response.getOutputStream().print(sw.toString());
} finally ...{
if(conn!=null)
try ...{
if(!conn.isClosed()) conn.close();
} catch (SQLException e) ...{
e.printStackTrace();
}
}
}
privatevoid doXml(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException ...{
ServletContext context=getServletContext();
//String jrxml=context.getRealPath("/WEB-INF/reports/Test1.jrxml");
String reportDir=context.getRealPath("/WEB-INF/reports");
String jasper=reportDir+"/Test1.jasper";
response.setContentType("text/xml");
Map map=new HashMap();
map.put("exportType","xml");
map.put("imageTest",context.getRealPath("/reports/star.gif"));
map.put("SUBREPORT_DIR",reportDir+"/");
Connection conn=getConn();
try ...{
JasperPrint print=JasperFillManager.fillReport(jasper,map,conn);
OutputStream os=response.getOutputStream();
JasperExportManager.exportReportToXmlStream(print,os);
os.flush();
os.close();
} catch (JRException e) ...{
StringWriter sw=new StringWriter();
PrintWriter pw=new PrintWriter(sw);
e.printStackTrace(pw);
response.setContentType("text/plain");
response.getOutputStream().print(sw.toString());
} finally ...{
if(conn!=null)
try ...{
if(!conn.isClosed()) conn.close();
} catch (SQLException e) ...{
e.printStackTrace();
}
}
}
privatestatic Connection getConn() ...{
try ...{
Class.forName(OracleDriver.class.getName());
return DriverManager.getConnection("jdbc:oracle:thin:@202.192.xxx.xxx:1521:orc92","name","password");
} catch (Exception e) ...{
e.printStackTrace();
}
returnnull;
}
/** *//**
*Initializationoftheservlet.<br>
*
*@throwsServletExceptionifanerroroccure
*/
publicvoid init() throws ServletException ...{
// Put your code here
}
}
用户指南Ireport
Jasperreports api
Jasperreport+ireport 实践操作及web应用的更多相关文章
- 利用JasperReport+iReport进行Web报表开发
用JasperReport+iReport进行Web报表开发 序言 在非常多实际的项目里,报表都是当中十分重要的组成部分,比如把查询结果以报表的形式呈现出来.这里所提到的报表可不是简单的二维表,而是拥 ...
- 使用JasperReport+iReport进行Web报表开发
使用JasperReport+iReport进行Web报表开发 前言 在实际工程中非常,报告是其中很重要的一部分,结果以报表的形式呈现出来.这里所提到的报表可不是简单的二维表,而是拥有复杂表头的.多维 ...
- 20145203盖泽双 《网络对抗技术》实践九:Web安全基础实践
20145203盖泽双 <网络对抗技术>实践九:Web安全基础实践 1.实践目标 1.理解常用网络攻击技术的基本原理. 2.Webgoat下进行相关实验:SQL注入攻击.XSS攻击.CSR ...
- 20145203盖泽双 《网络对抗技术》实践八:Web基础
20145203盖泽双 <网络对抗技术>实践八:Web基础 1.实践目标 (1)编写Web前端--含有表单的HTML代码. (2)编写Web前端--javascipt验证用户名.密码的代码 ...
- kmeans算法原理以及实践操作(多种k值确定以及如何选取初始点方法)
kmeans一般在数据分析前期使用,选取适当的k,将数据聚类后,然后研究不同聚类下数据的特点. 算法原理: (1) 随机选取k个中心点: (2) 在第j次迭代中,对于每个样本点,选取最近的中心点,归为 ...
- 【ASP.NET Web API教程】2.1 创建支持CRUD操作的Web API
原文 [ASP.NET Web API教程]2.1 创建支持CRUD操作的Web API 2.1 Creating a Web API that Supports CRUD Operations2.1 ...
- 自学Aruba6.2-控制器基本维护操作(web页面配置)
点击返回:自学Aruba之路 自学Aruba6.2-控制器基本维护操作(web页面配置) 1 显示当前控制器版本 Dashboard---Controller中 2 升级Aruab os版本 Main ...
- ASP.NET 工作流:支持长时间运行操作的 Web 应用程序
ASP.NET 工作流 支持长时间运行操作的 Web 应用程序 Michael Kennedy 代码下载位置:MSDN 代码库 在线浏览代码 本文将介绍以下内容: 独立于进程的工作流 同步和异步活 ...
- Oracle delete和truncate实践操作之一
实践说明 本文章主要记录在Oracle中,delete和truncate进行数据删除之后,如何进行数据恢复.由于网上对delete和truncate的区别说明较多,此处不过多介绍两者区别. 注:由于环 ...
随机推荐
- [Javascript] 5个最佳的Javascript日期处理类库
在大家日常网站开发和web应用开发中,我们往往需要有效的调用Javascript处理日期和时间格式相关的函数,在Javascript中已经包含了部分最基本的内建处理方法. 在大家日常网站开发和web应 ...
- javascript中的分号【;】
以前一直以为,在编写js代码的时候,如果在代码后面不添加分号,JavaScript会自动填补分号.最近看了权威指南,才突然发现一直理解有误,而且关于分号的使用,还有很多需要注意的地方. 1.分号的省略 ...
- LeetCode Weekly Contest 25
1. 507. Perfect Number 显然小于2的都不满足(尤其是负数的情况),进一步,显然质数都不满足,所以小于4的数,直接return false. 然后依次暴力枚举判断到sqrt(n), ...
- Kettle bug收集
20160919(未确定): 加载表的使用"Use batch update for inserts"会引致奇怪的转换失败? 出错日志: - linenr 450000- line ...
- DELPHI调试出现disconnected session的解决办法
我在控制面板中,是禁用了UAC的,如下图 但是,在注册表中启用了UAC(EnableLUA), 工程中请求了管理员权限,如下图: 所以,整个权限请求混乱了. 解决办法,要么把注册表的LUA设置为0,要 ...
- 『转』The Beginning of your Design Career
想想,如果明天我开始学日语,坚持到毕业,其实也可以日语入门了.所以机会都是抓住,当初,也就是去年的时候,我那个时候就开始坚持日语入门,想想现在应该可以开始N2了吧-所以...过去不去理会,现在开始继续 ...
- CDR中是否有图层,如何调出图层面板?
什么是图层?如果有点PS基础的同学,应该会非常清楚这个概念,它是构成图像的重要组成单位,许多效果可以通过对层的直接操作而得到,并在当前图层操作时候不会影响到其他图层,所以在绘图的过程中有着很重要的作用 ...
- tomcat 配置 https 几点注意
1.修改server.xml时候把注释的改改就好,不要添加,免得杂乱. 2.安装openssl openssl-devel autoconf libtool apr tomcat-native 才行. ...
- iOS tcpdump抓包方法(需越狱)
前提条件:机器要破解,cydia能打开 需要工具1.openssh2.tcpdump 安装工具方法:1.连接网络,打开cydia2.确认Cydia设置为开发者模式(管理->设置->开发者) ...
- 计蒜客 时间复杂度 (模拟) & 洛谷 P3952 时间复杂度
链接 : Here! 思路 : 这是一道大模拟, 区分好情况就没问题了 循环构成部分 : $F , x , i , j$ 和 $E$ , 需要注意的是 $i , j$, - 分析 $i, j$ 的情况 ...