【20151120】近期学习笔记 博客分类: 随便唠唠 camelajax传值
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调试工具也很重要!
持续补充中。。。。。。。。。