Hallo Benjamin,
ich schätze in deinem Fall beisst dich das Caching from typo3.
Ich vermute mal die extension benutzt ein USER_INT object.

wenn eine seite USER_INT objecte enthält rendert 
typo3 den seiteninhalt (ohne USER_INT) objecte.) an ihre Stelle kommt dann
lediglich eine marker,

wenn die seite später dann aus dem cache geholt wird. Wird eieser marker 
einfach durch die ausgabe
des USER_int Objectes ersetzt.

Dein Json encode greift vor dem Caching. 
Und erst danach wird der cachmarker druch das html ersetzt.

Deswegen funktioniert dein encoding so nicht.

Gruss chris


-----Ursprüngliche Nachricht-----
Von: typo3-german-boun...@lists.typo3.org 
[mailto:typo3-german-boun...@lists.typo3.org] Im Auftrag von Benjamin Giesbrecht
Gesendet: Montag, 20. Juli 2015 13:47
An: typo3-german@lists.typo3.org
Betreff: [TYPO3-german] Ajax handling

Hallo Zusammen,

Ich bin daran einen Ajax-Handler zu implementieren. Es gibt bekanntlich diverse 
Wege um mit Ajax Requests umzugehen. Ich habe mich dazu entschieden mit 
pageTypes zu arbeiten. Ruft man eine Seite im Browser auf wird diese mit 
PageType 0 geladen. Drückt man einen Link in der Navigation wird die nächste 
Seite via Ajax mit PageType 1 geladen. 

Lädt man eine Seite mit PageType 1 bereitet TYPO3 die Seite für JSON vor.

So weit so gut:
[code]
page = PAGE
page {

        typeNum = 0

     10 = FLUIDTEMPLATE 
     10 {
        file.cObject = CASE  
        file.cObject {
            key.field = backend_layout
            key.ifEmpty.data = levelfield: -2, backend_layout_next_level, slide
            
            default = TEXT
            default.value = {$filepaths.templates}Basic.html
            
            1 = TEXT
            1.value = {$filepaths.templates}Home.html
            
            2 = TEXT
            2.value = {$filepaths.templates}Basic.html
            
            3 = TEXT
            3.value = {$filepaths.templates}Overlay.html
            
            4 = TEXT
            4.value = {$filepaths.templates}Modal.html
            
            5 = TEXT
            5.value = {$filepaths.templates}Dashboard.html
            
            6 = TEXT
            6.value = {$filepaths.templates}OverlayForm.html


        }
                
        partialRootPath = {$filepaths.partials}Default/
        layoutRootPath = {$filepaths.layouts}Default/
    }
    
}

// ajax request contact form
ajax = PAGE
ajax {
    typeNum = 1
    config {
        disableAllHeaderCode = 1
        xhtml_cleaning = 0
        admPanel = 0
        additionalHeaders = Content-type: application/json
        no_cache = 1
    }

    10 < page.10
    10 {              
        partialRootPath = {$filepaths.partials}Ajax/
        layoutRootPath = {$filepaths.layouts}Ajax/
    }

}

Mittels Viewhelper leite ich den Content durch eine json_encode funktion.

{namespace g=VENDOR\UsermanagerPt\ViewHelpers}
<f:layout name="OverlayForm" />
<f:section name="Main">  
        <g:jsonResponse>
                <f:cObject typoscriptObjectPath="lib.register" />
        </g:jsonResponse>
</f:section>

/**
         * @param boolean $appendContent append content
         * @param boolean $submitForm submit form
         * @return string
         */
        public function render($appendContent = false, $submitForm = false) {
                $html = $this->renderChildren();

                return json_encode(array(
                'success' => true,
                'content' => $html
            ));

Nun zum Problem. Normale Content Elemente werden sauber mit json_encode 
gerendert. Jedoch wird sämtlicher Content aus einer Extension NICHT verändert. 
Mache ich einen Denkfehler?

[code]


_______________________________________________
TYPO3-german mailing list
TYPO3-german@lists.typo3.org
http://lists.typo3.org/cgi-bin/mailman/listinfo/typo3-german
_______________________________________________
TYPO3-german mailing list
TYPO3-german@lists.typo3.org
http://lists.typo3.org/cgi-bin/mailman/listinfo/typo3-german

Antwort per Email an