如何让UI对其他屏幕尺寸更具响应性?

时间:2015-09-06 16:45:30

标签: javascript html css responsive-design

我有一个html页面,其中有一个文本框(键入您的文本)和TextArea列表。我需要输入文本框,然后单击“添加”按钮,以便文本框中的任何内容都转到我的TextArea列表中。我需要在文本框中输入以下格式。

Name=Value

用户可以使用此文本框快速将名称值对添加到该文本框下方的列表中。让我们说如果我们在上面的文本框中输入Hello=World并点击添加,那么在下面的列表中,它应显示为

Hello=World

如果我们再次在同一文本框中输入ABC=PQR,那么在下面的列表中,它应该显示为这样,这意味着它应该继续在其原始条目下方添加新的名称值对。

Hello=World
ABC=PQR

但是如果语法不正确,就好像它不在Name = Value对中那么它不应该向列表中添加任何东西,而是显示弹出错误的输入格式。名称和值只能包含字母数字字符。我还有三个按钮Sort by nameSort by valueDelete按钮。单击其中一个按钮后,它应使用名称或值对TextArea列表中的条目进行排序,并删除条目。现在,我所有上述事情都没有任何问题。

这是我的jsfiddle。我需要使用纯HTML,CSS和Javascript,我不想使用任何库,因为我想保持简单,因为我还在学习。现在我试图看看我们是否可以使UI更具响应性,就像UI应该根据查看它的屏幕大小进行调整一样。例如,如果在移动电话(即Android或iPhone)上查看,页面应自动调整以更好的方式呈现布局。这也适用于在桌面上重新调整浏览器大小,以及在平板电脑上查看页面。

我需要在CSS或HTML中进行哪些更改才能使其更具响应性?我可以在这做任何改进吗?由于我的UI非常简单,所以我应该在这里做一些简单的方法或一些改进。

以下是我的代码:

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Test</title>

<style type="text/css">
.main{
    background:white;
    padding: 35px;
    border-radius: 5px;
}

#my-text-box {
    font-size: 18px;
    height: 1.5em;
    width: 585px;
}
#list{
    width:585px;
    height:300px;
    font-size: 18px;
}
.form-section{
    overflow:hidden;
    width:700px;
}
.fleft{float:left}
.fright{float:left; padding-left:15px;}
.fright button{display:block; margin-bottom:10px;}

html, body {
    height: 100%;
    font-family: "Calibri";
    font-size: 20px;
}

html {
    display: table;
    margin: auto;
}

body {
    display: table-cell;
    vertical-align: middle;
    background-color: #5C87B2;
}
</style>

<script language="javascript" type="text/javascript">
document.getElementById('add').onclick = addtext;
function addtext() {
    var nameValue = document.getElementById('my-text-box').value;
      if (/^([a-zA-Z0-9]+=[a-zA-Z0-9]+)$/.test(nameValue)){
        var x = document.getElementById("list");

        var option = document.createElement("option");
        option.text = nameValue;
        x.add(option);
    }
    else
        alert('Incorrect Name Value pair format.');
}
document.getElementById('btnDelete').onclick = deleteText;
function deleteText(){
    var myList = document.getElementById('list');
    var i;
    for (i = myList.length - 1; i>=0; i--) {
    if (myList.options[i].selected) {
      myList.remove(i);
    }
  }
}

document.getElementById('sortByValue').onclick = sortByValue;
function sortByValue(){
    var myList = document.getElementById('list');
    var values = new Array();
    for (var i=0;i<myList.options.length;i++) {
        values[i] = myList.options[i].text;
    }
      values.sort(function(a, b){
            if(a != "" && b != ""){
                return a.split('=')[1].localeCompare(b.split('=')[1])
            } else {
                return 0
            }
        });

   clearList(myList);
   fillList(myList, values);
}
document.getElementById('sortByName').onclick = sortByName;
function sortByName(){
    var myList = document.getElementById('list');
    var values = new Array();
    for (var i=0;i<myList.options.length;i++) {
        values[i] = myList.options[i].text;
    }
      values.sort(function (a, b){
            if(a != "" && b != ""){
                return a.split('=')[0].localeCompare(b.split('=')[0])
            } else {
                return 0
            }
        });

    clearList(myList);

    fillList(myList, values);
}

function clearList(list) {
    while (list.options.length > 0) {
        list.options[0] = null;
    }
}

function fillList(myList, values){
    for (var i=0;i<values.length;i++) {
        var option = document.createElement("option");
        option.text = values[i];
        myList.options[i] = option;
    }
}
</script>

</head>

<body>
<div class = 'main'>
    <h3>Test</h3>

    <label for="pair">Type your text</label></br>
    <div class="form-section">
        <div class="fleft">
            <input type='text' id='my-text-box' value="Name=Value" />
        </div>
        <div class="fright">
            <button type="button" id='add' onclick='addtext()'>Add</button>
        </div>
    </div>
    <label for="pairs">Name/Value Pair List</label></br>
    <div class="form-section">
        <div class="fleft">
           <select id="list" multiple></select>
        </div>
        <div class="fright">
            <button type="button" id='sortByName' onclick='sortByName()'>Sort by name</button>
            <button type="button" id='sortByValue' onclick='sortByValue()'>Sort by value</button>
            <button type="button" id='btnDelete' onclick='deleteText()'>Delete</button>
            <button type="button">Show XML</button>
        </div>
    </div>
</div>

</body>
</html>

1 个答案:

答案 0 :(得分:0)

W3在响应式网页设计方面拥有大量资源:

http://www.w3schools.com/html/html_responsive.asp http://www.w3schools.com/css/css_responsive_intro.asp

不使用PHP来检测浏览器/用户代理,您的响应式设计通常会涉及确保网站更流畅,更流畅,允许更改浏览器宽度(如上面的第一个示例中所示)和/或提供不同的样式表取决于关于CSS中的视口大小和媒体类型(第二个示例)。