zoukankan      html  css  js  c++  java
  • SAP CRM Fiori应用冗余round trip的原因分析

    Sent: Wednesday, July 22, 2015 7:54 PM

    有同事抱怨每次他们保存一个appointment时,除了正常的batch 操作外,还有3个莫名的read 操作。


    The callstack clearly shows that the three roundtrips are NOT issued by customer extension, or else the customer js file could be observed in the callstack.

    Set a breakpoint on the top most callstack, h function. Check the content of e.target.data:

    This is actually the batch request payload which could be observed in Chrome network tab:

    This finding gives me more confidence that these roundtrips are issued by framework, not standard or customer application code.

    So I just continue debugging until I reach this suspicious stack:

    in line 1957, this.bRefreshAfterChange = true.

    However, in our internal system ( where everything works fine, there is no duplicate read operations ), this.bRefreshAfterChange = false, which has suppressed the refresh operation. This is the reason why the read operation could not be found in my internal system, since they are not executed at all. But in customer system, _isRefreshNeeded returns true, which leads to the execution of all subsequent read operations.

    So why is this difference between two systems? In Chrome development tool, search the boolean variable name and we found one function setRefreshAfterChange defined for ODataModel. Just set a breakpoint in this method and re-launch the application in my internal system from beginning:

    Breakpoint is triggered:

    However, this line in customer system is missing, which is the root cause - our latest standard code didn't reach customer system.

    出问题的系统上的标准代码里少了这一行,我在local的Eclipse里试过,如果注释掉,behavior就和出问题的系统上一样,能够重现那三个多余的读操作了。

    要获取更多Jerry的原创文章,请关注公众号"汪子熙":

  • 相关阅读:
    IsPostBack
    判断客户端.net版本
    js 汉字转换成拼音 转载
    观察者模式
    常用的js阻止冒泡的方法
    jquery中事件的绑定
    uclinux编译 skyeye运行
    dotNet学习之路 Struct与Class异同点
    dotNet学习之路 Delegate内部原理
    设计模式之旅(策略模式) 十号刚发工资的博友们,赶紧跟我一起算算你们的老板有没有给你少发工资。。。
  • 原文地址:https://www.cnblogs.com/sap-jerry/p/12371574.html
Copyright © 2011-2022 走看看