0

我知道足够的 html 和 css 来处理我需要的大多数东西,但我不是最擅长 JQuery 的。所以我需要一些帮助。

塞纳里奥:

我有一个包含 jquery 可排序 portlet 的网页

body { min-width:100%; }
.column { width: 33%; float: left; padding-bottom: 100px;}
.portlet { margin: 0 1em 1em 0; }
.portlet-header { margin: 0.3em; padding-bottom: 4px; padding-left: 0.2em; }
.portlet-header .ui-icon { float: right; }
.portlet-content { padding: 0.4em; }
.ui-sortable-placeholder { border: 1px dotted black; visibility: visible !important; height: 50px !important; }
.ui-sortable-placeholder * { visibility: hidden; }
.boxmax{position:absolute;width:100%;height:100%;}


<div class="column">
    <div class="portlet">
        <div class="portlet-header">Feeds</div>
        <div class="portlet-content"><p>Lorem ipsum dolor sit amet, consectetuer adipiscing elit</p></div>
    </div>
    <div class="portlet">
        <div class="portlet-header">News</div>
        <div class="portlet-content"><span>Lorem ipsum dolor sit amet, consectetuer adipiscing elit</span></div>
    </div>
</div>
<div class="column">
    <div class="portlet">
        <div class="portlet-header">Shopping</div>
        <div class="portlet-content">Lorem ipsum dolor sit amet, consectetuer adipiscing elit</div>
    </div>
</div>
<div class="column">
    <div class="portlet">
        <div class="portlet-header">Links</div>
        <div class="portlet-content">Lorem ipsum dolor sit amet, consectetuer adipiscing elit</div>
    </div>
    <div class="portlet">
        <div class="portlet-header">Images</div>
        <div class="portlet-content">Lorem ipsum dolor sit amet, consectetuer adipiscing elit</div>
    </div>
</div>


$(function() {
    $( ".column" ).sortable({
        connectWith: ".column"
    });
    $( ".portlet" ).addClass( "ui-widget ui-widget-content ui-helper-clearfix ui-corner-all" )
                    .find( ".portlet-header" )
                    .addClass( "ui-widget-header ui-corner-all" )
                    .prepend( "<span class='ui-icon ui-icon-minusthick'></span>")
                    .end()
                    .find( ".portlet-content" );
    $( ".portlet-header .ui-icon" ).click(function() {
        if($( this ).parents(".portlet-header").find("span")[0].className.match("ui-icon-minusthick") != null)
        {
            $( this ).parents(".portlet").css({"position":"absolute", "height":"90%", "width":"90%", "left" : "0.4%", "top" : "1.2%"});
        }
        else
        {
            $( this ).parents(".portlet").css({"position":"", "height":"", "width":"", "left" : "" , "top" : ""});
        }
        $( this ).toggleClass( "ui-icon-minusthick").toggleClass("ui-icon-plusthick" );
        <!--$( this ).parents( ".portlet:first" ).find( ".portlet-content" ).toggle();-->


    });

    $( ".column" ).disableSelection();
});

到目前为止我已经尝试过:

http://jsfiddle.net/VHWHm/2/

  1. 它可以从一列排序到另一列
  2. 它可以最大化全屏并最小化到以前的位置

我想要做什么:

http://jsfiddle.net/VHWHm/1/

问题:

如何将 portlet 包装在响应百分比值的 div 中

问题阐述:

如果我单击最大化按钮,portlet 将最大化到全屏(全浏览器)。在最小化 portlet 回到以前的位置时,现在如果我当时放置一个外部 div 的 portlet,最大化 portlet 应该在父 div 内最大化,而不是全屏。我怎样才能做到这一点。

提前致谢。

4

1 回答 1

0

您可以根据此更改脚本:

$(function() {
$( ".column" ).sortable({
connectWith: ".column"
 });
  $( ".portlet" ).addClass( "ui-widget ui-widget-content ui-helper-clearfix ui-corner-   all"     )
.find( ".portlet-header" )
.addClass( "ui-widget-header ui-corner-all" )
 .prepend( "<span class='ui-icon ui-icon-minusthick'></span>")
.end()
.find( ".portlet-content" );
 $( ".portlet-header .ui-icon" ).click(function() {
  $( this ).toggleClass( "ui-icon-minusthick" ).toggleClass( "ui-icon-plusthick" );
  $( this ).parents( ".portlet:first" ).find( ".portlet-content" ).toggle();

 });

 $( ".column" ).disableSelection();
   });

工作演示

于 2013-11-13T12:46:04.917 回答