可以通過下列方式拿到構(gòu)件樹:
var it = viewer.model.getData().instanceTree;
//或
viewer.getObjectTree(function( instanceTree ) {
console.log( instanceTree );
});
因數(shù)據(jù)優(yōu)化的緣故,所有數(shù)據(jù)都是平坦化過的,要重建數(shù)據(jù)結(jié)構(gòu)可以通過:
function buildModelTree( model ) {
//builds model tree recursively
function _buildModelTreeRec( node ) {
it.enumNodeChildren( node.dbId, function(childId) {
node.children = node.children || [];
var childNode = {
dbId: childId,
name: it.getNodeName( childId )
};
node.children.push( childNode );
_buildModelTreeRec( childNode );
});
}
//get model instance tree and root component
var it = model.getData().instanceTree;
var rootId = it.getRootId();
var rootNode = {
dbId: rootId,
name: it.getNodeName( rootId )
};
_buildModelTreeRec( rootNode );
return rootNode;
}
var root = buildModelTree( viewer.model );你是用什么軟件打包的
scrollBehavior (to, from, savedPosition) {
return { x: 0, y: 0 }
}
<style>
#parent{
position:relative;
width:100px;
height:100px;
background:#f99;
}
#children{
position: absolute;
width:100px;
height:100px;
right:-100%;
top:0;
background:#99f;
display:none;
}
</style>
<div id="parent">
<div id="children"></div>
</div>
<script>
var eParent = document.getElementById('parent')
var eChildren = document.getElementById('children')
eChildren.onmouseover = eParent.onmouseover = function(e){
eChildren.style.display="block"
}
eChildren.onmouseout = eParent.onmouseout = function(e){
eChildren.style.display="none"
}
</script>
是指這樣嗎
-------------------------------------更新
<style>
*{
margin:0;
padding:0;
}
ul{
list-style: none;
}
.item{
position:relative;
width:100px;
height:100px;
background:#f99;
border:1px solid #ccc;
cursor:pointer;
}
.item div{
position: absolute;
width:100px;
height:100px;
right:-100%;
top:0;
background:#99f;
display:none;
}
</style>
<ul id="list">
<li class="item">
<div></div>
</li>
<li class="item">
<div></div>
</li>
<li class="item">
<div></div>
</li>
</ul>
<script src="https://cdn.bootcss.com/jquer...;></script>
<script>
$('.item').on('mouseover',function(){
$(this).find('div').css('display','block')
})
$('.item').on('mouseout',function(){
$(this).find('div').css('display','none')
})
</script>
*{
margin:0;
padding:0;
}
ul{
list-style: none;
position:relative;
width:500px;
margin:0 auto;
height:500px;
}
.item{
position:relative;
width:100px;
height:100px;
background:#f99;
border:1px solid #ccc;
cursor:pointer;
float:left;
}
.hidden{
position: absolute;
width:100px;
height:100px;
background:#99f;
display:none;
top:100%;
left:0;
}
.bu{
display:block;
width:100%;
height:100%;
}
</style>
<ul id="list">
<li class="item">
<a class="bu" href="www.baidu.com"></a>
<div class="hidden"></div>
</li>
<li class="item">
<a class="bu"></a>
<div class="hidden"></div>
</li>
<li class="item">
<a class="bu"></a>
<div class="hidden"></div>
</li>
</ul>
<script src="https://cdn.bootcss.com/jquer...;></script>
<script>
$('.item').on('mouseover',function(){
$(this).find('.hidden').css('display','block')
})
$('.item').on('mouseout',function(){
$(this).find('.hidden').css('display','none')
})
</script>
注意: 因為 document.write 寫入文檔流,在關(guān)閉(已加載)的文檔上調(diào)用 document.write 會自動調(diào)用 document.open,這將清除該文檔。
@media only screen and (device-width:1920px){
愛的點(diǎn)點(diǎn)滴滴
}
可以加個狀態(tài)。
:style="todo.clicked && todo.liStyle || defaultStyle"
//
{ text: '學(xué)習(xí) JavaScript', liStyle: { color: 'yellow' }, clicked: false },
{ text: '學(xué)習(xí) Vue', liStyle: { color: 'red' }, clicked: false },
{ text: '整個牛項目', liStyle: { color: 'green' }, clicked: false }
//
log (index) {
this.todos[index].clicked = true
}
用計算屬性也行,但是肯定要給每個 todo 加個狀態(tài)標(biāo)識。
已經(jīng)解決問題,應(yīng)該直接使用mongoose的鏈?zhǔn)讲僮鬟M(jìn)行查詢
一般是后臺校驗用戶名和密碼正確后,會生成用戶登錄態(tài)的一個code,服務(wù)器端用session保存,前端用cookie保存。這個是服務(wù)器操作的,前端不用管。因為每個http請求也會自動帶上cookie,服務(wù)器取請求里cookie的值與session里的值比較,來確認(rèn)用戶的登錄態(tài)。這個就是登錄態(tài)的原理。跟vue.js寫spa應(yīng)用這些沒有關(guān)系。都是一樣的處理方法。
用css動畫實現(xiàn),參考https://cn.vuejs.org/v2/guide...
location.origin
作為工作區(qū)項目打開,再用全局搜索。
你把數(shù)據(jù)貼出來啊,一般來說vue里面你要存在對應(yīng)的數(shù)據(jù)才去v-for
解決方式就是三元表達(dá)式
<div v-for="list in item">
<span>{ list.user.name?list.user.name:''}</span>
</div>
無法實現(xiàn).exe
檢查一下你有沒有安裝 less 和 less-loader
經(jīng)過一個下午的折騰,上周五還是發(fā)現(xiàn)出現(xiàn)該異常情況的原因。概括來說還是中文轉(zhuǎn)編碼的問題,即utf-8轉(zhuǎn)gbk出現(xiàn)的小部分行缺少空格或者雙引號的問題。
出現(xiàn)問題的原因:
在進(jìn)行導(dǎo)出的過程中,接收其他程序傳過來的數(shù)組參數(shù),均為utf-8編碼,我這邊在調(diào)用fwrite或者fputcvs寫入文件的過程中并沒有進(jìn)行 iconv("UTF-8", "GB2312//IGNORE", $header),而是將文件保存在了 export目錄下,然后由vuejs做的后臺調(diào)用位于同application下的一個共用類的 export方法,該方法是這樣的:
public function export()
{
$file = \Request::get('file');
header('Content-Type: application/vnd.ms-excel');
header('Content-Disposition: attachment;filename=export.csv');
header('Cache-Control: max-age=0');
$contents = file_get_contents(\Env::get('runtime_path') . '/export/' . $file);
echo iconv("UTF-8", "GB2312//IGNORE", $contents);
@unlink(RUNTIME_PATH . '/export/' . $filename);
exit;
}
問題就出在 echo iconv("UTF-8", "GB2312//IGNORE", $contents); 這句代碼上面,這里看到是對傳入的整個文件進(jìn)行轉(zhuǎn)編碼的,這里未進(jìn)行測試到底多少行的數(shù)據(jù)會出現(xiàn)缺少逗號引號的問題。
最終的解決思路是,把共用類中對整個文件的轉(zhuǎn)編碼放到寫入方法中,逐條轉(zhuǎn)編碼就解決了該問題。
更改后的代碼:
public static function createCsv($data, $header = [], $filename = '')
{
// 參數(shù)判斷
$data = is_object($data) ? $data->toArray() : $data;
$header = is_array($header) ? $header : [];
$filename = (1 > strlen(trim($filename))) ? 'csv-' : trim($filename);
if (empty($data)) {
return false;
}
// 文件名/目錄
$filename = $filename . date("YmdHis", time()) . rand(1000, 9999) . ".csv";
$dir = Env::get('runtime_path') . '/export/';
if (!is_dir($dir) && !mkdir($dir)) {
return false;
}
// 打開文件指針資源
$handle = fopen($dir . $filename, 'w+');
if (!$handle) {
return false;
}
// 寫入文件header頭
if (!empty($header)) {
foreach ($header as $key => $item) {
$header[$key] = iconv("UTF-8", "GB2312//IGNORE", $item);
}
$res = fputcsv($handle, $header);
if (!$res) {
return false;
}
}
// 判斷header是索引數(shù)組還是關(guān)聯(lián)數(shù)組
$is_assoc = array_keys($header) !== range(0, count($header) - 1);
// 寫入文件內(nèi)容
$frequency = 0; // 頻率
$limit = 100000;
foreach ($data as $datum) {
$frequency++;
if ($limit == $frequency) {
// 刷新輸出buffer
ob_flush();
flush();
$frequency = 0;
}
// 如果是關(guān)聯(lián)數(shù)組,則獲取內(nèi)容中和頭部key相對應(yīng)的值
if ($is_assoc) {
$csv = "";
foreach(array_keys($header) as $item) {
$datum[$item] = iconv("UTF-8", "GB2312//IGNORE", $item);
$val = str_replace('"', '""', $datum[$item]); // 將單個雙引號替換為兩個雙引號
$csv .= '"' . $val . '",'; // 為每個字符增加雙引號,并添加逗號分割符
}
$csv = substr($csv, 0, -1); // 去掉每行最后一個逗號
$csv .= "\n"; // 添加換行符
$res = @fwrite($handle, $csv);
} else {
$res = fputcsv($handle, $datum);
}
if (!$res) {
return false;
}
}
// 關(guān)閉指針資源
fclose($handle);
return Url::build('erp/Common/export', 'file=' . $filename);
}
public function export()
{
$file = \Request::get('file');
header('Content-Type: application/vnd.ms-excel');
header('Content-Disposition: attachment;filename=export.csv');
header('Cache-Control: max-age=0');
$contents = file_get_contents(\Env::get('runtime_path') . '/export/' . $file);
echo $contents;
exit;
}
調(diào)用步驟:
先調(diào)用createCsv生成文件,再調(diào)用export下載。
———————————————————————分割線——————————————————————
另外一種解決思路:
csv文件直接存儲 UTF-8 編碼:
即不需要進(jìn)行 iconv 轉(zhuǎn)編碼,這樣會有個小問題就是MacOS中的Excel無法自動識utf-8編碼,中文會出現(xiàn)亂碼的情況。
原因:
Excel在讀取csv的時候是通過讀取文件頭上的bom來識別編碼的,如果文件頭無bom信息,則默認(rèn)按照unicode編碼讀取。(這個bom是微軟自己定義的一種文件頭部協(xié)定,顧名思義存儲在文件頭部,存儲內(nèi)容就是標(biāo)識文件編碼的信息。)而我們生成csv的平臺不一定遵循微軟的bom協(xié)議,導(dǎo)致如果輸出非unicode編碼的csv文件(例如utf-8),并且沒有生成bom信息的話,Excel自動按照unicode編碼讀取,就會出現(xiàn)亂碼問題了。作者:李蛟 鏈接:https://www.zhihu.com/questio...
來源:知乎 著作權(quán)歸作者所有。商業(yè)轉(zhuǎn)載請聯(lián)系作者獲得授權(quán),非商業(yè)轉(zhuǎn)載請注明出處。
根據(jù)知乎查到的答案,原來是這里未遵循微軟的bom協(xié)議。原因找到了,解決方案就能出了。
解決方法:
fopen 方法下寫入bom頭,這里簡單寫一下步驟
function createCsv($filename, $header, $data) {
$handle = fopen($filename, 'w+');
// 添加BOM,標(biāo)識為UTF-8格式
fwrite($handle, chr(0xEF).chr(0xBB).chr(0xBF));
// 寫入頭部
fputcsv($handle, $header);
// 逐行寫入內(nèi)容
foreach ($data as $datum) {
fputcsv($handle, $datum);
}
// 關(guān)閉指針資源
fclose($handle);
}
另外再補(bǔ)充一下 Bom 簡介
- 在UCS 編碼中有一個叫做”ZERO WIDTH NO-BREAKSPACE”的字符,它的編碼是FEFF。
- FFFE在UCS中是不存在的字符,所以不應(yīng)該出現(xiàn)在實際傳輸中。
- UCS規(guī)范建議我們在傳輸字節(jié)流前,先傳輸字符”ZERO WIDTH NO-BREAK SPACE”。
- 這樣如果接收者收到FEFF,就表明這個字節(jié)流是Big-Endian的;
- 如果收到FFFE,就表明這個字節(jié)流是Little-Endian的。
- 因此字符”ZERO WIDTH NO-BREAK SPACE”又被稱作BOM。
- UTF-8不需要BOM來表明字節(jié)順序,但可以用BOM來表明編碼方式。
- 字符”ZERO WIDTH NO-BREAK SPACE”的UTF-8編碼是EF BB BF。
- 所以如果接收者收到以EF BB BF開頭的字節(jié)流,就知道這是UTF-8編碼了。
- Windows就是使用BOM來標(biāo)記文本文件的編碼方式的。
該內(nèi)容來自 http://blog.csdn.net/chaozhi_... 這篇博客
內(nèi)置函數(shù), 官方文檔寫的很清楚
An empty string searchValue will match at any index between 0 and str.length
@submit.prevent="submit"放到提交按鈕上
wafer 是騰訊提供的快速搭建服務(wù)端的方案,服務(wù)端由 nodejs 開發(fā),幫助有服務(wù)端開發(fā)能力的前端工程師實現(xiàn)項目快速搭建發(fā)布
北大青鳥APTECH成立于1999年。依托北京大學(xué)優(yōu)質(zhì)雄厚的教育資源和背景,秉承“教育改變生活”的發(fā)展理念,致力于培養(yǎng)中國IT技能型緊缺人才,是大數(shù)據(jù)專業(yè)的國家
達(dá)內(nèi)教育集團(tuán)成立于2002年,是一家由留學(xué)海歸創(chuàng)辦的高端職業(yè)教育培訓(xùn)機(jī)構(gòu),是中國一站式人才培養(yǎng)平臺、一站式人才輸送平臺。2014年4月3日在美國成功上市,融資1
北大課工場是北京大學(xué)校辦產(chǎn)業(yè)為響應(yīng)國家深化產(chǎn)教融合/校企合作的政策,積極推進(jìn)“中國制造2025”,實現(xiàn)中華民族偉大復(fù)興的升級產(chǎn)業(yè)鏈。利用北京大學(xué)優(yōu)質(zhì)教育資源及背
博為峰,中國職業(yè)人才培訓(xùn)領(lǐng)域的先行者
曾工作于聯(lián)想擔(dān)任系統(tǒng)開發(fā)工程師,曾在博彥科技股份有限公司擔(dān)任項目經(jīng)理從事移動互聯(lián)網(wǎng)管理及研發(fā)工作,曾創(chuàng)辦藍(lán)懿科技有限責(zé)任公司從事總經(jīng)理職務(wù)負(fù)責(zé)iOS教學(xué)及管理工作。
浪潮集團(tuán)項目經(jīng)理。精通Java與.NET 技術(shù), 熟練的跨平臺面向?qū)ο箝_發(fā)經(jīng)驗,技術(shù)功底深厚。 授課風(fēng)格 授課風(fēng)格清新自然、條理清晰、主次分明、重點(diǎn)難點(diǎn)突出、引人入勝。
精通HTML5和CSS3;Javascript及主流js庫,具有快速界面開發(fā)的能力,對瀏覽器兼容性、前端性能優(yōu)化等有深入理解。精通網(wǎng)頁制作和網(wǎng)頁游戲開發(fā)。
具有10 年的Java 企業(yè)應(yīng)用開發(fā)經(jīng)驗。曾經(jīng)歷任德國Software AG 技術(shù)顧問,美國Dachieve 系統(tǒng)架構(gòu)師,美國AngelEngineers Inc. 系統(tǒng)架構(gòu)師。