Форум: Форум PHPФорум ApacheФорум Регулярные ВыраженияФорум MySQLHTML+CSS+JavaScriptФорум FlashРазное
Новые темы: 0000000
Социальная инженерия и социальные хакеры. Авторы: Кузнецов М.В., Симдянов И.В. PHP. Практика создания Web-сайтов (второе издание). Авторы: Кузнецов М.В., Симдянов И.В. PHP на примерах (2 издание). Авторы: Кузнецов М.В., Симдянов И.В. Объектно-ориентированное программирование на PHP. Авторы: Кузнецов М.В., Симдянов И.В. PHP 5. На примерах. Авторы: Кузнецов М.В., Симдянов И.В., Голышев С.В.
ВСЕ НАШИ КНИГИ
Консультационный центр SoftTime

HTML+CSS+JavaScript

Выбрать другой форум

 

Здравствуйте, Посетитель!

вид форума:
Линейный форум Структурный форум

тема: ajax & frame
 
 автор: SunEagle   (11.09.2013 в 07:46)   письмо автору
 
 

Подскажите как сделать?
Есть фрейм (пустой), надо чтобы при нажатии на кнопку фрейм загрузил по ссылку страницу и при каждом нажатии заново загружал страницу в фрейме (без перезагрузки страницы)

  Ответить  
 
 автор: SunEagle   (11.09.2013 в 08:06)   письмо автору
 
   для: SunEagle   (11.09.2013 в 07:46)
 

Вроде разобрался) если кому интересно вот код

<html>
<head>
<script type="text/javascript">

var iframeids=["myframe"]

//Should script hide iframe from browsers that don't support this script (non IE5+/NS6+ browsers. Recommended):
var iframehide="yes"

var getFFVersion=navigator.userAgent.substring(navigator.userAgent.indexOf("Firefox")).split("/")[1]
var FFextraHeight=parseFloat(getFFVersion)>=0.1? 16 : 0 //extra height in px to add to iframe in FireFox 1.0+ browsers

function resizeCaller() {
var dyniframe=new Array()
for (i=0; i<iframeids.length; i++){
if (document.getElementById)
resizeIframe(iframeids[i])
//reveal iframe for lower end browsers? (see var above):
if ((document.all || document.getElementById) && iframehide=="no"){
var tempobj=document.all? document.all[iframeids[i]] : document.getElementById(iframeids[i])
tempobj.style.display="block"
}
}
}

function resizeIframe(frameid){
var currentfr=document.getElementById(frameid)
if (currentfr && !window.opera){
currentfr.style.display="block"
if (currentfr.contentDocument && currentfr.contentDocument.body.offsetHeight) //ns6 syntax
currentfr.height = currentfr.contentDocument.body.offsetHeight+FFextraHeight; 
else if (currentfr.Document && currentfr.Document.body.scrollHeight) //ie5+ syntax
currentfr.height = currentfr.Document.body.scrollHeight;
if (currentfr.addEventListener)
currentfr.addEventListener("load", readjustIframe, false)
else if (currentfr.attachEvent){
currentfr.detachEvent("onload", readjustIframe) // Bug fix line
currentfr.attachEvent("onload", readjustIframe)
}
}
}

function readjustIframe(loadevt) {
var crossevt=(window.event)? event : loadevt
var iframeroot=(crossevt.currentTarget)? crossevt.currentTarget : crossevt.srcElement
if (iframeroot)
resizeIframe(iframeroot.id);
}

function loadintoIframe(iframeid, url){
if (document.getElementById)
document.getElementById(iframeid).src=url
}

if (window.addEventListener)
window.addEventListener("load", resizeCaller, false)
else if (window.attachEvent)
window.attachEvent("onload", resizeCaller)
else
window.onload=resizeCaller

</script>
</head>
<body>
<iframe id="myframe" src="" scrolling="no" marginwidth="0" marginheight="0" frameborder="0" vspace="0" hspace="0" style="overflow:visible; width:100%; display:none" target="_top"></iframe>
<a href="javascript:loadintoIframe('myframe', 'ссылка')">Link</a>
</body>
</html>

  Ответить  
 
 автор: яса1   (12.09.2013 в 12:02)   письмо автору
 
   для: SunEagle   (11.09.2013 в 08:06)
 

и где тут ajax, о котором вы поминали в заголовке темы?

  Ответить  
 
 автор: SunEagle   (13.09.2013 в 02:16)   письмо автору
 
   для: яса1   (12.09.2013 в 12:02)
 

Я просто нашел вариант который можно использовать без ajax

Но вот так делается на ajax

<html>

<head>

<meta http-equiv="Content-Type" content="text/html; charset=unicode">
<meta http-equiv="Content-Language" content="ru">

<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.4.4/jquery.js"></script> 
</head>
<body>
<script>
function zapros1() {
            document.getElementById("myframe").src = "http://ru.wikipedia.org/";
}
</script>

<iframe id="myframe" src="" width="100%" height="300" ></iframe>

<form onsubmit="zapros1(); return false;"><input type="submit" name="button" id="button" value="Заменить"></form>

</body>

</html>

  Ответить  
 
 автор: confirm   (13.09.2013 в 03:39)   письмо автору
 
   для: SunEagle   (13.09.2013 в 02:16)
 

Так на Ajax не делается, да и нет тут никакого ajax.

  Ответить  
 
 автор: SunEagle   (14.09.2013 в 04:17)   письмо автору
 
   для: confirm   (13.09.2013 в 03:39)
 

Просветите тогда как надо, а не просто говорить о том что не так

  Ответить  
 
 автор: яса1   (14.09.2013 в 05:13)   письмо автору
 
   для: SunEagle   (14.09.2013 в 04:17)
 

почитайте http://xmlhttprequest.ru/ - там всё по-русски разжёвано про объект XMLHTTPRequest
и в том числе про асинхронный вариант запроса (а это и есть AJAX)

посмотрите пример - http://codecenter.awardspace.com/textajax3108.html - там код всех файлов имеется

  Ответить  
 
 автор: confirm   (14.09.2013 в 06:32)   письмо автору
 
   для: SunEagle   (14.09.2013 в 04:17)
 

Возвращаясь к вашему первоначальному вопросу:

iframe отличается от других элементов на странице тем, что может загружать и отображать содержимое внешних html-файлов, при этом не влияя на содержимое основного документа. То есть, загрузка документа в iframe не приводит к перезагрузке основного документа. А от frame iframe отличается тем, что может позиционироваться на странице как и любой другой html элемент.

Из этого следует, что ваш вопрос просто избыточен, так как применение iframe все и решает. А чтобы загружать в него документ по команде, то нужно иметь элемент управления для этого (кнопку), по щелчку на котором обновлять документ в iframe - изменяя его src значение. При этом сценарий задания src и зависимости от этого нового документа может быть различен. Ajax и большого JS-сценария, вами представленного, для этого совсем не требуется, если только не нужно при обновлении документа выполнять некие действия или изменять параметры iframe.

Что касается Ajax, то это совсем иное (хотя с помощью iframe можно подменить Ajax), и о нем по ссылкам представленным ЯСА.

PS. Выставляя код, форматируйте его.

  Ответить  
Rambler's Top100
вверх

Rambler's Top100 Яндекс.Метрика Яндекс цитирования