Show toolbar

2019年11月12日 星期二

Mask String

標題:Mask String
JavaScript (maskString.js):
const maskString = (str, style) => {
  switch (style) {
    case "email":
      // abcde@gmail.com => a***e@g*******m
      return str.replace(/([^@]+)/g, s => maskString(s));
    default:
      // abcde => a***e
      return str.replace(/(?<=.).(?=.*?.)/g, "*");
  }
};

const str = maskString("abcd1234@gmail.com", "email");
console.log(str);

範例:

a******4@g*******m

說明:
遮罩第1個字與最後1個字以外的字元。

2017年11月23日 星期四

Click the upload icon below to upload a file

標題:Click the upload icon below to upload a file
JavaScript (index.html):
<div>
    <label for="fileboxy">
        <img src="http://bit.ly/2PmisVq" style="cursor: pointer;" />
    </label>
    <input id="fileboxy" type="file" style="display: none;" />
</div>

範例:

說明:
使用label的方式點選圖片同步觸發隱藏的input file選擇檔案。

2017年4月18日 星期二

Random Color

標題:Random Color
JavaScript (index.html):
<button onclick="getRandomColor(this)">Change Color</button>
<script>
function getRandomColor(e) {
  var color = '#' + Math.floor(Math.random()*16777215).toString(16);
  console.log(color);
  e.innerHTML = color;
  e.style.color = color;
}
</script>

範例:


說明:
透過『16777215』白色,隨機產生顏色。

2015年5月6日 星期三

Using the div tag to create table colspan

標題:使用div建立表格合併欄位
HTML (index.html):
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" lang="zh-TW" xml:lang="zh-TW">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<meta name=viewport content="width=device-width, initial-scale=1">
<title>TableBoxy</title>
<style>
.css_fieldset { /*框架*/
    padding: 10px;
    border-style: solid;
    border-width: 1px;
    border-color: #000000;
}
.css_legend { /*框架標題*/
    float: left;
    background: #fff;
    margin-top: -20px;
    padding: 0 10px;
}
.css_tablebox { /*表格框架*/
    clear: both;
    overflow-x: auto;
}
.css_table { /*表格*/
    border-collapse: collapse;
    display: table;
}
.css_tr { /*橫列*/
    padding: 3px;
    display: table-row;
}
.css_th { /*標題欄位*/
    padding: 5px;
    border-style: solid;
    border-width: 1px;
    border-color: #000000;
    display: table-cell;
    font-weight: bold;
    white-space: nowrap;
}
.css_td { /*一般欄位*/
    padding: 5px;
    border-style: solid;
    border-width: 1px;
    border-color: #000000;
    display: table-cell;
    white-space: nowrap;
}
.css_colspan { /*表格合併欄位*/
    border-left-style: solid;
    border-top-style: solid;
    border-bottom-style: solid;
    border-left-width: 1px;
    border-top-width: 1px;
    border-bottom-width: 1px;
    border-color: #000000;
    display: table-cell;
    white-space: nowrap;
}
.css_colspan_text { /*文字欄位*/
    width: 0px;
    padding: 5px;
    position:relative;
}
.css_colspan_blank { /*中間空欄位*/
    border-top-style: solid;
    border-bottom-style: solid;
    border-top-width: 1px;
    border-bottom-width: 1px;
    display: table-cell;
}
.css_colspan_last { /*最後欄位*/
    border-top-style: solid;
    border-right-style: solid;
    border-bottom-style: solid;
    border-top-width: 1px;
    border-right-width: 1px;
    border-bottom-width: 1px;
    border-color: #000000;
    display: table-cell;
}
</style>
</head>
<body>
<div class="css_fieldset">
    <div class="css_legend">標題</div>
    <div class="css_tablebox">
        <div class="css_table">
            <div class="css_tr">
                <div class="css_th">標題</div>
                <div class="css_th">日期</div>
                <div class="css_th">回應</div>
            </div>
            <div class="css_tr">
                <div class="css_td">今天晚餐吃少一點吧</div>
                <div class="css_td">2015-05-05</div>
                <div class="css_td">5</div>
            </div>
            <div class="css_tr">
                <div class="css_colspan">
                    <div class="css_colspan_text">宵夜不吃了,早點回家睡覺比較實際。</div>
                </div>
                <div class="css_colspan_blank"></div>
                <div class="css_colspan_last"></div>
            </div>
            <div class="css_tr">
                <div class="css_td">今天早餐到底要吃什麼好呢?</div>
                <div class="css_td">2015-05-06</div>
                <div class="css_td">3</div>
            </div>
            <div class="css_tr">
                <div class="css_td">作者</div>
                <div class="css_colspan">
                    <div class="css_colspan_text">QQBoxy</div>
                </div>
                <div class="css_colspan_last"></div>
            </div>
        </div>
    </div>
</div>
</body>
</html>


範例:

標題
標題
日期
回應
今天晚餐吃少一點吧
2015-05-05
5
宵夜不吃了,早點回家睡覺比較實際。
今天早餐到底要吃什麼好呢?
2015-05-06
3
作者
QQBoxy


於新視窗開啟檢視效果:http://output.jsbin.com/kagobamopi

說明:
使用div建構具有合併欄位(colspan)的表格效果,
並且建構div分組fieldset、legend能在行動裝置自適應顯示過長內容。

2014年7月14日 星期一

Regular Expression Iterator

標題:使用迭代器匹配字串
VC++ (regex.cpp):
#include <iostream>
#include <regex> //string lib here
using namespace std;

int main(int argc, char* argv[])
{
    string str = "facet normal -8.944272e-001 4.472136e-001 0.000000e+000";
    regex pattern("[+-]?[0-9]\\.[0-9]+[eE][+-]?[0-9]+");

    auto words_begin = sregex_iterator(str.begin(), str.end(), pattern);
    auto words_end = sregex_iterator();

    cout << "Found " << std::distance(words_begin, words_end) << " numbers:\n";

    for (sregex_iterator i = words_begin; i != words_end; ++i) {
        cout << atof( ((smatch) *i).str().c_str() ) << '\n';
    }

    system("pause");
    return 0;
}


說明:
使用迭代器匹配字串。