estoy relizando un index.php, un molde1.php (este contiene la estructura de divs) y pretende tener la estructura de contenidos almacenadas en index.php mediante un vector, el asunto es que cuando hago el include en index.php no me reconoce el vector invocado en molde1.php.
El error que tira es: Undefined variable: vector in C:\Archivos de programa\EasyPHP\www\Pruebas\eje10\eje10-b\template1\molde1.php on line 27
A continuación paso el código de los 3 archivos a ver si alguien puede ayudarme.
index.php
Código php:
molde1.phpVer original
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html> <head> <meta http-equiv="content-type" content="text/html; charset=iso-8859-1"> <meta name="author" content=""> <?php { $n= $_GET["estilo"]; switch ($n) { case "1": case "2": case "3": $ref="href=template$n/estilo$n.css"; include ("template$n/molde$n"); break; default: echo('ha ocurrido un error'); break; } } else { $ref="href= \"template1/estilo1.css\""; include "template1/molde1.php"; } ?> <link rel="stylesheet" type="text/css" <?php echo ($ref)?>> <title>Eleccion templates noticias</title> </head> <body> <form action="" method="get"> Ingrese el estilo que prefiera<br> <input type="radio" name="estilo" value="1">A tres columnas<br> <input type="radio" name="estilo" value="2">A dos columnas<br> <input type="radio" name="estilo" value="3">Colorido<br> <input type="submit" value="Elegir"> </form> <?php $vector["encabezado"]="ULTIMAS NOTICIAS"; $vector["antartida"]="Continúa encallado en la Antártida un crucero de lujo con 122 personas a bordo"; $vector["cuerpoAntartida"]= "El crucero Ushuaia, con 89 personas y 33 tripulantes, se encuentra varado desde ayer a la tarde cerca de la Antártida, con entrada mínima de agua y pérdida de combustible, según informó la Armada Argentina. El capitán, Jorge Aldegueri, dijo a Clarín.com que los pasajeros y tripulantes no corren peligro."; $vector["patriarca"]="Murió el patriarca de la Iglesia Ortodoxa Rusa "; $vector["cuerpoPatriarca"]="Alexis II, cercano del actual primer ministro y ex presidente Vladimir Putin, encabezaba desde 1990 la Iglesia Ortodoxa Rusa . Durante su patriarcado, mantuvo momentos de tensión con el Vaticano, y en una oportunidad se negó a recibir al Papa Juan Pablo II al argumentar que se intentaría promover la fe católica en el país."; $vector["trenes"]= "Demoras en la línea Roca" ; $vector["cuerpoTrenes"]="Los servicios del ex ferrocarril Roca se prestaba con demoras de hasta 25 minutos por fallas técnicas registrados en la estación cabecera de Plaza Constitución. Los retrasos se registraban esta mañana en todos los ramales de de la empresa Unidad de Gestión Operativa Ferroviaria de Emergencias (UGOFE), línea Roca, a cargo del funcionamiento del ex Ferrocarril Roca."; $vector["asueto"]="Aclaran que el asueto por las Fiestas no rige para los bancos"; $vector["cuerpoAsueto"]="Lo informó esta tarde el Ministerio del Interior. De esta forma, el beneficio sólo alcanzará a los trabajadores de la administración pública nacional y de la provincia de Buenos Aires, que descansarán el 26 de diciembre y el 2 de enero."; $vector["madonna"]="Una multitud deliró con Madonna "; $vector["cuerpoMadonna"]="Tras quince años sin ofrecer un show aquí y ocho sin pisar suelo argentino, anoche Madonna volvió a presentarse en Buenos Aires. La Reina del Pop cantó ante un River colmado luego de que la fecha del miércoles, la primera del capítulo argentino del \"Sticky & Sweet Tour\", fuera pospuesta. Unos 50.000 fanáticos corearon las canciones en las dos horas de un concierto que ostentó un despliegue escénico impactante: bailarines, escenografía, luces y hasta un Rolls Royce en escena. "; ?> </body> </html>
Código php:
estilo1.cssVer original
<div id="encabezado"> <h1>Banner de publicidad del sitio</h1> </div> <div id="contenidoTotal"> <div id="contenColumns"> <div id="botonera"> <ul> <li><a href="#"><?php echo $vector["antartida"]?></a></li> <li><a href="#"><?php $vector["patriarca"]?></a></li> <li><a href="#"><?php $vector["trenes"]?></a></li> <li><a href="#"><?php $vector["asueto"]?></a></li> <li><a href="#"><?php $vector["madonna"]?></a></li> </ul> </div> <div id="columDer"> <h3>Find out more</h3> <p> Lorem ipsum dolor sit amet, consectetuer adipiscing elit, sed diam nonummy nibh euismod tincidunt ut laoreet. </p> </div> <div id="contenido"> <h2><?php echo $vector["encabezado"] ?></h2> <p>contenidos</p> </div> <div id="cleardiv"></div> </div> </div> <div id="pie"> <h3>La noticia al instante</h3> </div>
Código php:
Ver original
/*body { margin: 0; padding: 0; font-size: 90%; color: #000; background-color: #fff; }*/ a:link { color: #036; } a:visited { color: #066; } a:hover ,a:active { color: #fff; background-color: #036; } div#encabezado { color: #fff; background-color: #333; border-bottom: 1px solid #000; } div#encabezado h1 { margin: 0; padding: .3em 0 .3em .5em; } div#contenidoTotal { background-image: url(imagenes/nav_col_base.jpg); background-repeat: repeat-y; } div#contenColumns { background-image: url(imagenes/more_col_base.jpg); background-repeat: repeat-y; background-position: right; } div#botonera { float: left; width: 150px; padding-top: 2em; } div#botonera ul { list-style-type: none; padding: 0; margin: 0; } div#botonera ul li { margin-top: 4px; } #botonera ul li a { display: block; width: 135px; padding: 3px 5px 3px 10px; text-decoration: none; color: #000; background-image: url(imagenes/nav_base.jpg); background-repeat: repeat-y; } #botonera ul li a:hover { color: #fff; background-color: #ccc; background-image: url(imagenes/nav_base2.jpg); background-repeat: repeat-y; } div#columDer { float: right; width: 160px; margin: 0; padding: 2em 10px 0 0; color: #fff; } div#columDer h3 { margin-top: 0; color: #fff; padding: .2em; background-image: url(imagenes/more_base.jpg); background-position: right; background-repeat: repeat-y; } div#contenido { margin-left: 190px; margin-right: 200px; line-height: 150%; } div#contenido h2 { font-size: 2em; color: #036; margin: 0; padding-top: 1em; font-weight: normal; } #cleardiv { clear: both; height: 1em; } div#pie { color: #fff; background-color: #333; border-top: 2px solid #000; } div#pie h3 { margin: 0; padding: .3em 0 .3em .5em; } /*div#pie ul { padding: 0; margin: 0; list-style-type: none; } div#pie li { display: inline; margin-right: 1em; }
En realidad no que estoy esperando es que muestre el contenido de un vector asociativo el el "molde" mediante un echo, ya que no se me permite realizar echos en el index.
el css es una plantilla y no creo que tenga nada que ver en el problema.
Gracias nuevamente.
anticic