`
Everyday都不同
  • 浏览: 713468 次
  • 性别: Icon_minigender_1
  • 来自: 宇宙
社区版块
存档分类
最新评论

【20151120】近期学习笔记

阅读更多

 

1)camel流程中的if else

假设流程是CamelStart->A->B

流程启动类

 

public class CamelStart {
	public static void main(String[] args) {
		ApplicationContext ctx = new FileSystemXmlApplicationContext("itmon_demo/WEB-INF/conf/spring/sys/context-route.xml");
		System.out.println(ctx);
		
		ProducerTemplate template = ctx.getBean("producerTemplate", ProducerTemplate.class);
//		template.sendBody("direct://AstartData");
		String str = "a";
		template.sendBody("direct://AstartData", "okoko");
		if(StringUtils.isBlank(str)) {
			try {
				template.start();
			} catch (Exception e) {
				e.printStackTrace();
			}
		}
	}
}

 ACamel1:

 

 

public class ACamel1 implements Processor {

	@Override
	public void process(Exchange exchange) throws Exception {
		String ret = (String) exchange.getIn().getBody();
		
		ret = ret + "a1";
		if(StringUtils.isBlank(ret)) {
			System.out.println("进入到A流程的第一步。。 " + ret);
			exchange.getIn().setBody(ret);
		}
		
	}

}

 ACamel2:

 

 

public class ACamel2 implements Processor {

	@Override
	public void process(Exchange exchange) throws Exception {
		String ret = (String) exchange.getIn().getBody();
		ret = ret + "a2";
		System.out.println("进入到A流程的第二步。。" + ret);
		
	}

}

 运行之后,结果为:

 

 

进入到A流程的第二步。。okokoa2

 

这说明,现在流程为CamelStart->B 很容易误以为因为A中不往下sendBody,所以流程在起始点 CamelStart就会卡住。但实际情况是,虽然A没有sendBody,但B依然会接收从CamelStart中的数据。(这是因为流程配置的关系,实际上是走了A,虽然A没有sendBody,但B会接收从CamelStart中的数据,如果A sendBody了,那么B接收的就是A处理之后的数据)

 

2)ajax集合类型的数据传给前台

先假设有一个list或map要传到前台,你需要在后台把他们都放到一个map中,再把这个map转成JSON对象~

如果该list或map的赋值需要满足某个条件,即在if中。这时候你需要注意把这个list或map放在转成json对象的map中的位置。

如果你put这些集合类型的数据的操作放在if中,那么前台通过json.key得到的则会是undefined造成js报错。所以一般建议把put的操作放在if外面。

 

3)ajax的一种简便写法:

$.post("ajax url",params).done(function(data){
   //处理逻辑
});//params为传到后台的json格式的数据~

 后台返回给前台返回的不一定是json格式的字符串,也有可能就是一个Map<String, Object>数据。前台js还是可以通过data.key的形式来获取; 前台传给后台的参数,如果后台的方法有参数,且参数的命名和前台传过来的params的key保持一致的话,那么该方法的参数也可以直接接收到传过来的值!

 

4)一种比较好的思想:对于提交按钮,如果要在提交前校验,除了传统的做法外,可以就把该按钮当做普通按钮,提交与否可以在js函数的if else里进行。比如满足校验条件的进入If,则我们可以在if里面写ajax提交的逻辑,在else里则只提示不能提交的原因而已。。

 

5)关于设置redis的过期时间

这个听起来稀松平常吧,之前我也有介绍过。设置redis的key过期时间很有必要,因为既然你使用上了redis,那么它缓存的数据量无疑是非常huge的,所以你不可能永久保存每个数据。下面介绍的并不是设置redis的key的过期时间的作用,而是要来演示redis的分区选择对设置过期时间的影响~

Jedis jedis = new Jedis("localhost");
jedis.select(8);
Map<String, String> map = new HashMap<String, String>();
map.put("test", "content");
map.put("test2", "content2");
jedis.hmset("map", map);
		
jedis.select(7);//注意这里切换了分区
jedis.set("test", "cs");
jedis.expire("map", 30);

 这段代码的本意很简单,先在8分区里缓存一个map,并设置其存活时间,之后再切换到7分区保存一个string。。  但需注意的是,把设置该map的过期时间放在切换分区的操作之后了!  测试下,你会发现,8分区的map并不能如愿在30s之后过期!原因是:你分区已经切换到8分区了,你之后的所有操作只对8分区有效~~  expire虽然针对的是7分区的map,但是已经在8分区了,该设置是 “够不着” 的,所以,应该把jedis.expire("map", 30);这行代码挪到jedis.select(7);之前~

——这个bug比较隐秘,但确实是致命的,尤其在实际的大数据量的情形下,虽然在本地测试一个数据还看不出来。。

 

6)在同一个搜索框输入,ajax穿给后台——神奇sql系列

很常见的一种情况是“输入你想要查询的xx或yy”,这里:xx或yy是不同的查询条件,但你可以做到只输入一个查询文本,却可以根据任一查询条件查询。这里常常在sql上下功夫,例如:

 

SELECT * FROM tablename
WHERE (xx LIKE '%查询文本%' OR yy LIKE '%查询文本%')

 其中“查询文本”即是你在搜索框输入的文本,而xx和yy是不同的查询条件。如果你什么也不输入(注意也不要输入空格),则where后面的变成 WHERE (xx LIKE '%%' OR yy LIKE '%%')这样就会搜寻出所有的记录,达到目的~~

此时你ajax只传一个参数给后台即可。。

 

========================================= BTW系列 ============================================

一下午调样式我也是醉了,总结几点小经验:

1)想让div在一行里显示,必须为每个div设置float:left  margin-right:m.px

2)每个div若不设置width: n% (0<n<100),则默认会横向占满整个body

3)观察这些div是否被一个大的div包围,如果有,确保这个大的div的width还有height足够容纳下这些一行中显示的若干小div

4)每个小的div里如果想让某些内容在一行显示,确保某些元素的width不会太大,否则会把其他元素挤掉

5)想在一行显示的元素如果错位显示成2行 ,调试某个元素的width,设置小一点

 

5)学会用浏览器的css调试工具也很重要!

持续补充中。。。。。。。。。

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics