0

情况:您好,我有一个查询,该查询仅在 salesforce vf 页面中运行良好且符合预期。

问题从 iframe 调用时,它返回没有其父对象的输出。

顶点中的代码:

public class showServiceHistory {
CKSW_BASE__Service__c services;
String id = ApexPages.currentPage().getParameters().get('id');
String x;
public myValues()
{
    services = [SELECT id, name, (SELECT Name, Previous_Status__c, New_Status__c, Reason_Code__c, comment__c FROM Service_Status_History__r) FROM CKSW_BASE__Service__c WHERE id=:id];           
}
public String getxx()
{
    x=JSON.Serialize(services);
    return x;   
}
}

VF 中的代码

< apex:page controller="myValues" >

< apex:pageBlock title="{!xx}" >

< /apex:pageBlock >

< /apex:page >

来自 Salesforce 的输出

{"attributes":{"type":"CKSW_BASE__Service__c","url":"/services/data/v38.0/sobjects/CKSW_BASE__Service__c/sss"},"Id":"s","Name":"S","Service_Status_History__r":{"totalSize":6,"done":true,"records":[{"attributes":{"type":"Service_Status_History__c","url":"/services/data/v38.0/sobjects/Service_Status_History__c/ss"},"Service__c":"asss","Id":"uu","Name":"yyy","Previous_Status__c":"xyz","New_Status__c":"y","Reason_Code__c":"xyz","Comment__c":"abc"}]}

从 iframe 输出

{"attributes":{"type":"CKSW_BASE__Service__c","url":"/services/data/v38.0/sobjects/CKSW_BASE__Service__c/444"},"Id":"444","Name":"xyz "}

Vf 页面我得到了具有完整值的所需输出,但是从我的 force.com url 中的 iframe 父对象(嵌套查询)不可用

但是,当我使用简单的专用查询仅调用 parent时,它会返回两个(iframe 和 url)位置的值。

为什么我的嵌套 SOQL 无法获取父对象。我在这里想念什么?

提前致谢。请帮忙。

从 iframe 输出

4

2 回答 2

0

你检查过你的 FLS 吗?

构建 -> 开发 -> 站点 -> -> 公共访问设置

这是 Force.com 结果的罪魁祸首。

于 2016-11-29T18:43:39.463 回答
0

是的,我已经检查过了,它授予了公共访问权限。甚至我在以 JSON 格式转换和打印时也能看到它们。但是如果以解析对象形式打印,我无法在 iframe 中看到它们。

因此,它通过以 Json 字符串格式发送值并在那里解析它对我有用。

在 Vf 页面中

<apex:page Controller="showServiceHistory" sidebar="false" showheader="false">
<html>
    <head>
    <!--<meta http-equiv="refresh" content="20" ></meta> -->

</head>
<a id="history_data" style="display:none;">{!history}</a>
<a id="service_data" style="display:none">{!service}</a>
<style>
    table {
        width: 100%;
    }

    table,
    th,
    td {
        border-collapse: collapse;
        color: #3088D0;
    }

    th,
    td {
        padding: 5px;
        text-align: left;
        color: #1F497D;
    }

    tr {
        //color: #337AB7;
    }

    table#t01 tr:nth-child(even) {
        background-color: #DCE6F1;
        //color: #337AB7;
    }

    table#t01 tr:nth-child(odd) {
        background-color: #fff;
    }

    table#t01 th {
        background-color: #B8CCE4;
        //color: #000015;
    }

    a:link {
        color: #62B3E2;
    }

    a:visited {
        color: #62B3E2;
    }
</style>


<table id="t01">
    <thead>
        <tr>
            <th>
                Name
            </th>

            <th>
                Previous Status
            </th>
            <th>
                New Status
            </th>
            <th>
                Comment
            </th>
        </tr>
    </thead>
    <tbody id="show_values">
    </tbody>

</table>
<script>
    function x()
    {
    var history={}; var service={};
    history=JSON.parse(document.getElementById("history_data").innerHTML); 
    service=JSON.parse(document.getElementById("service_data").innerHTML); 
    var show='';
        for(var i=0;i<history.length;i++)
        {
           show=show+'<tr><td>'+history[i].Name+'</td><td>'+history[i].Previous_Status__c+'</td><td>'+history[i].New_Status__c+'</td><td>'+history[i].Comment__c+'</td><td>'+service.CKSW_BASE__Location__c+'</td></tr>';
        }
            document.getElementById("show_values").innerHTML=document.getElementById("show_values").innerHTML+show;
    }
    x();
</script>
</html>

在顶点代码页中

public class showServiceHistory {
List<Service_Status_History__c> histories;
String x;
CKSW_BASE__Service__c services;
String id = ApexPages.currentPage().getParameters().get('id');
 public showServiceHistory()
{
    services = [SELECT CKSW_BASE__Resource__c, CKSW_BASE__Location__c, (SELECT Name, Previous_Status__c, New_Status__c, comment__c FROM Service_Status_History__r) FROM CKSW_BASE__Service__c WHERE id=:id];         
    histories = services.Service_Status_History__r;
}
public String getService()
{
    return JSON.Serialize(services);   
}
public String getHistory()
{
    return JSON.Serialize(histories);
}

}

于 2016-12-01T12:50:24.040 回答