2016-03-29 14 views
-3

私はプログラマーではないことを知らせてくれます。私はいくつかのコードを理解しようとし、試行錯誤を使ってどこでそれを変更することができます。 私は、関数内で変更する必要があるJoomlaモジュールから次のコードを取得しています。 document.write関数にはdocument.getElementById('ElementID').innerHTMLが使用されています。私は上記のw/o運を実装しようとしたpausescroller関数関数のコードを投稿しています。何も、フロントエンドに表示されなかっ:HEREdocument.writeをdocument.getElementById( 'ElementID')に置き換える方法innerHTML

function pausescroller(content, divId, divClass, delay){ 
    this.content=content //message array content 
    this.tickerid=divId //ID of ticker div to display information 
    this.delay=delay //Delay between msg change, in miliseconds. 
    this.mouseoverBol=0 //Boolean to indicate whether mouse is currently over scroller (and pause it if it is) 
    this.hiddendivpointer=1 //index of message array for hidden div 
    document.getElementById('divId').innerHTML = "<div id="'+divId+'" class="'+divClass+'" style="position: relative; overflow: hidden"><div class="innerDiv" style="position: absolute; width: 100%" id="'+divId+'1">'+content[0]+'</div><div class="innerDiv" style="position: absolute; width: 100%; visibility: hidden" id="'+divId+'2">'+content[1]+'</div></div>"; 
    //document.write('<div id="'+divId+'" class="'+divClass+'" style="position: relative; overflow: hidden"><div class="innerDiv" style="position: absolute; width: 100%" id="'+divId+'1">'+content[0]+'</div><div class="innerDiv" style="position: absolute; width: 100%; visibility: hidden" id="'+divId+'2">'+content[1]+'</div></div>') 
    var scrollerinstance=this 
    if (window.addEventListener) //run onload in DOM2 browsers 
    window.addEventListener("load", function(){scrollerinstance.initialize()}, false) 
    else if (window.attachEvent) //run onload in IE5.5+ 
    window.attachEvent("onload", function(){scrollerinstance.initialize()}) 
    else if (document.getElementById) //if legacy DOM browsers, just start scroller after 0.5 sec 
    setTimeout(function(){scrollerinstance.initialize()}, 500) 
} 

は、全体のJavaScriptの部分のコードです:あなたは完全な文字列であることをニーズにinnerHTMLを設定

<script type="text/javascript"> 
<!-- 
var pausecontent=new Array(); 
var cnti = 0; 

<?php 
for($im=0; $im<count($testi_RSMSC); $im++) { 
    $dateExp_RSMSC = explode('-', $testi_RSMSC[$im]['date']); 
    $timestamp_RSMSC = mktime(12,0,0,$dateExp_RSMSC[1],$dateExp_RSMSC[2],$dateExp_RSMSC[0]); 
    $dateConfig_RSMSC = JFactory::getConfig(); 
    $siteLang_RSMSC = $dateConfig_RSMSC->get('config.language'); 
    setlocale(LC_ALL, $siteLang_RSMSC); 
    $dateView_RSMSC = strftime("%d %B %Y", $timestamp_RSMSC); 
    $testi_RSMSC[$im]['comment'] = preg_replace('/\s\s+/', ' ', trim($testi_RSMSC[$im]['comment'])); 
    $testi_text = ''; 
    if($char_RSMSC > 0) { 
     $testi_text .= substr($testi_RSMSC[$im]['comment'], 0, ($char_RSMSC-3)).'...'; 
    } else { 
     $testi_text .= $testi_RSMSC[$im]['comment']; 
    } 
    #### 
    $RStesti_pic_file = ''; 
    if($imgDispRSMSC == '1') { 
     if(file_exists(JPATH_ROOT.DS.'images'.DS.'com_rsmonials'.DS.$testi_RSMSC[$im]['id'].'.gif')) { 
      $RStesti_pic_file = '<img src="'.JURI::root().'images/com_rsmonials/'.$testi_RSMSC[$im]['id'].'.gif" style="max-width:'.$imgMwRSMSC.'px; max-height:'.$imgMhRSMSC.'px; border:'.$imgBorderRSMSC.';" />'; 
     } else if(file_exists(JPATH_ROOT.DS.'images'.DS.'com_rsmonials'.DS.$testi_RSMSC[$im]['id'].'.png')) { 
      $RStesti_pic_file = '<img src="'.JURI::root().'images/com_rsmonials/'.$testi_RSMSC[$im]['id'].'.png" style="max-width:'.$imgMwRSMSC.'px; max-height:'.$imgMhRSMSC.'px; border:'.$imgBorderRSMSC.';" />'; 
     } else if(file_exists(JPATH_ROOT.DS.'images'.DS.'com_rsmonials'.DS.$testi_RSMSC[$im]['id'].'.jpg')) { 
      $RStesti_pic_file = '<img src="'.JURI::root().'images/com_rsmonials/'.$testi_RSMSC[$im]['id'].'.jpg" style="max-width:'.$imgMwRSMSC.'px; max-height:'.$imgMhRSMSC.'px; border:'.$imgBorderRSMSC.';" />'; 
     } else if(file_exists(JPATH_ROOT.DS.'images'.DS.'com_rsmonials'.DS.$testi_RSMSC[$im]['id'].'.jpeg')) { 
      $RStesti_pic_file = '<img src="'.JURI::root().'images/com_rsmonials/'.$testi_RSMSC[$im]['id'].'.jpeg" style="max-width:'.$imgMwRSMSC.'px; max-height:'.$imgMhRSMSC.'px; border:'.$imgBorderRSMSC.';" />'; 
     } else { 
      $RStesti_pic_file = $RS_noimg; 
     } 
     if($imgAlignRSMSC == '1') { 
      $RStesti_pic_file = '<div style="margin-bottom:5px; text-align:left;">'.$RStesti_pic_file.'</div>'; 
     } else if($imgAlignRSMSC == '2') { 
      $RStesti_pic_file = '<div style="margin-bottom:5px; text-align:right;">'.$RStesti_pic_file.'</div>'; 
     } else if($imgAlignRSMSC == '3') { 
      $RStesti_pic_file = '<span style="float:left; margin-right:5px;">'.$RStesti_pic_file.'</span>'; 
     } else if($imgAlignRSMSC == '4') { 
      $RStesti_pic_file = '<span style="float:right; margin-left:5px;">'.$RStesti_pic_file.'</span>'; 
     } else { 
      $RStesti_pic_file = '<div style="margin-bottom:5px; text-align:center;">'.$RStesti_pic_file.'</div>'; 
     } 
    } 
    #### 
    $RSMSC_disp_context = '<div style="text-align:'.$alignRSMSC.';">'.$RStesti_pic_file.addslashes($testi_text).'</div><br /><em><strong>'.addslashes($testi_RSMSC[$im]['fname']).' '.addslashes($testi_RSMSC[$im]['lname']).'</strong>'; 
    if($displayaboutRSMSC == '1') { 
     if(($testi_RSMSC[$im]['about'] != '') || ($testi_RSMSC[$im]['location'] != '')) { 
      $RSMSC_disp_context .= ', Ηλικία: <small>'; 
      $RS_isa = 0; 
      if($testi_RSMSC[$im]['about'] != '') { 
       $RSMSC_disp_context .= addslashes($testi_RSMSC[$im]['about']); 
       $RS_isa = 1; 
      } 
      if($testi_RSMSC[$im]['location'] != '') { 
       if($RS_isa == '1') { 
        $RSMSC_disp_context .= ', '; 
       } 
       $RSMSC_disp_context .= addslashes($testi_RSMSC[$im]['location']); 
      } 
      $RSMSC_disp_context .= '</small>'; 
     } 
    } 
    if(($displayurlRSMSC == '1') && ($testi_RSMSC[$im]['website'] != '')) { 
     $RSMSC_disp_context .= '<br /><small>'.$testi_RSMSC[$im]['website'].'</small>'; 
    } 
    if($displaydateRSMSC == '1') { 
     $RSMSC_disp_context .= '<br /><small>'.$dateView_RSMSC.'</small>'; 
    } 
    $RSMSC_disp_context .= '</em>'; 

?> 
pausecontent[cnti++]='<?php echo $RSMSC_disp_context; ?>'; 
<?php 
} 
?> 

function pausescroller(content, divId, divClass, delay){ 
this.content=content //message array content 
this.tickerid=divId //ID of ticker div to display information 
this.delay=delay //Delay between msg change, in miliseconds. 
this.mouseoverBol=0 //Boolean to indicate whether mouse is currently over scroller (and pause it if it is) 
this.hiddendivpointer=1 //index of message array for hidden div 
document.getElementById(divId).innerHTML = '<div class="innerDiv" style="position: absolute; width: 100%" id="' + divId + '1">' + content[0] + '</div><div class="innerDiv" style="position: absolute; width: 100%; visibility: hidden" id="' + divId + '2">' + content[1] + '</div>'; 
//document.write('<div id="'+divId+'" class="'+divClass+'" style="position: relative; overflow: hidden"><div class="innerDiv" style="position: absolute; width: 100%" id="'+divId+'1">'+content[0]+'</div><div class="innerDiv" style="position: absolute; width: 100%; visibility: hidden" id="'+divId+'2">'+content[1]+'</div></div>') 
var scrollerinstance=this 
if (window.addEventListener) //run onload in DOM2 browsers 
window.addEventListener("load", function(){scrollerinstance.initialize()}, false) 
else if (window.attachEvent) //run onload in IE5.5+ 
window.attachEvent("onload", function(){scrollerinstance.initialize()}) 
else if (document.getElementById) //if legacy DOM browsers, just start scroller after 0.5 sec 
setTimeout(function(){scrollerinstance.initialize()}, 500) 
} 

/* initialize()- Initialize scroller method. -Get div objects, set initial positions, start up down animation */ 

pausescroller.prototype.initialize=function(){ 
this.tickerdiv=document.getElementById(this.tickerid) 
this.visiblediv=document.getElementById(this.tickerid+"1") 
this.hiddendiv=document.getElementById(this.tickerid+"2") 
this.visibledivtop=parseInt(pausescroller.getCSSpadding(this.tickerdiv)) 
//set width of inner DIVs to outer DIV's width minus padding (padding assumed to be top padding x 2) 
this.visiblediv.style.width=this.hiddendiv.style.width=this.tickerdiv.offsetWidth-(this.visibledivtop*2)+"px" 
this.getinline(this.visiblediv, this.hiddendiv) 
this.hiddendiv.style.visibility="visible" 
var scrollerinstance=this 
document.getElementById(this.tickerid).onmouseover=function(){scrollerinstance.mouseoverBol=1} 
document.getElementById(this.tickerid).onmouseout=function(){scrollerinstance.mouseoverBol=0} 
if (window.attachEvent) //Clean up loose references in IE 
window.attachEvent("onunload", function(){scrollerinstance.tickerdiv.onmouseover=scrollerinstance.tickerdiv.onmouseout=null}) 
setTimeout(function(){scrollerinstance.animateup()}, this.delay) 
} 


/* animateup()- Move the two inner divs of the scroller up and in sync */ 

pausescroller.prototype.animateup=function(){ 
var scrollerinstance=this 
if (parseInt(this.hiddendiv.style.top)>(this.visibledivtop+5)){ 
this.visiblediv.style.top=parseInt(this.visiblediv.style.top)-5+"px" 
this.hiddendiv.style.top=parseInt(this.hiddendiv.style.top)-5+"px" 
setTimeout(function(){scrollerinstance.animateup()}, 50) 
} 
else{ 
this.getinline(this.hiddendiv, this.visiblediv) 
this.swapdivs() 
setTimeout(function(){scrollerinstance.setmessage()}, this.delay) 
} 
} 

/* swapdivs()- Swap between which is the visible and which is the hidden div */ 

pausescroller.prototype.swapdivs=function(){ 
var tempcontainer=this.visiblediv 
this.visiblediv=this.hiddendiv 
this.hiddendiv=tempcontainer 
} 

pausescroller.prototype.getinline=function(div1, div2){ 
div1.style.top=this.visibledivtop+"px" 
div2.style.top=Math.max(div1.parentNode.offsetHeight, div1.offsetHeight)+"px" 
} 

/* setmessage()- Populate the hidden div with the next message before it's visible */ 

pausescroller.prototype.setmessage=function(){ 
var scrollerinstance=this 
if (this.mouseoverBol==1) //if mouse is currently over scoller, do nothing (pause it) 
setTimeout(function(){scrollerinstance.setmessage()}, 100) 
else{ 
var i=this.hiddendivpointer 
var ceiling=this.content.length 
this.hiddendivpointer=(i+1>ceiling-1)? 0 : i+1 
this.hiddendiv.innerHTML=this.content[this.hiddendivpointer] 
this.animateup() 
} 
} 

pausescroller.getCSSpadding=function(tickerobj){ //get CSS padding value, if any 
if (tickerobj.currentStyle) 
return tickerobj.currentStyle["paddingTop"] 
else if (window.getComputedStyle) //if DOM2 
return window.getComputedStyle(tickerobj, "").getPropertyValue("padding-top") 
else 
return 0 
} 

//new pausescroller(name_of_message_array, CSS_ID, CSS_classname, pause_in_miliseconds) 
new pausescroller(pausecontent, "rsmsc_scroller", "rsmsc_scroller_class", <?php echo $delay_RSMSC; ?>); 
//--> 
</script> 
+0

ようこそ。 SOの仕組みを理解するには、[ツアー](http://stackoverflow.com/tour)をご覧ください。 – Peter

+0

さらに、「問題を説明する方法を理解し、より良い機会を得る方法を理解するために、「[最小限の、完全で検証可能な例を作成する](http://stackoverflow.com/help/mcve)」を読むことができます答えを得る。 – Peter

答えて

0

値 - それぞれの側に'を追加するには、修正しますそれ:

document.getElementById('divId').innerHTML = '"<div id="'+divId+'" class="'+divClass+'" style="position: relative; overflow: hidden"><div class="innerDiv" style="position: absolute; width: 100%" id="'+divId+'1">'+content[0]+'</div><div class="innerDiv" style="position: absolute; width: 100%; visibility: hidden" id="'+divId+'2">'+content[1]+'</div></div>";' 
+0

ご返信ありがとうございます! !しかし、「両サイドに追加してもそれを修正することはできませんでした。コンテンツはフロントエンドには表示されません。私はちょうど私がdocument.getElementByIdでコメントされているdocument.write関数を十分に置き換えるかどうか分からない....ありがとう – its4yougr

1

変更この行:

document.getElementById('divId').innerHTML = "<div id="'+divId+'" class="'+divClass+'" style="position: relative; overflow: hidden"><div class="innerDiv" style="position: absolute; width: 100%" id="'+divId+'1">'+content[0]+'</div><div class="innerDiv" style="position: absolute; width: 100%; visibility: hidden" id="'+divId+'2">'+content[1]+'</div></div>"; 
これに

document.getElementById(divId).innerHTML = '<div class="innerDiv" style="position: absolute; width: 100%" id="' + divId + '1">' + content[0] + '</div><div class="innerDiv" style="position: absolute; width: 100%; visibility: hidden" id="' + divId + '2">' + content[1] + '</div>'; 

(一番最初の、そして最後の二重引用符、単一引用符でなければならず、document.getElementById(divId).innerHTML呼び出すときのvar名dividの前後に引用符を入れないでください)

を-EDIT-しかし、実際にあなたが探している要素がまだ存在していない、HTMLに親のdivを配置'<div id="myDiv" class="divClass" style="position: relative; overflow: hidden"></div>まずvar divId = 'myDiv';がで関数を呼び出す場合:

pausescroller(content, divId, divClass, delay); 
+0

ありがとう...これは私の最初の試みだった...それは動作しませんでした。あなたはより良い理解を持つことができるように私はPHPコード全体を投稿する必要がありますか?他に何か変える必要があるのでしょうか? – its4yougr

+0

もう一度おねがいします..提案されたコードをどこに置くべきかわからないので、私はPHPファイル全体を投稿できますか? – its4yougr

+0

私はプログラミングに精通していないので、ここでPHPコード全体を投稿しようとしました(これは私が試した方法であれば分かりませんが)。私はどこでそれをすることができますか? – its4yougr

関連する問題