nth-child是選擇父元素下的子元素,下標(biāo)從1開始
p:nth-child(3n + 0)表示選擇p元素父元素下的第3,6,9...個子元素,如果要選中第一個元素,要寫成:nth-child(1),同理:nth-child(3n + 1)就代表選中第1,4,7...個子元素。
這里需要注意的是p元素父元素的第一個子元素為h1標(biāo)簽,所以要想選中p元素父元素下第1,4,7...個p元素,使用:nth-child需要寫成:nth-child(3n + 2)。不過這里建議你使用:nth-of-type(3n+1)
因為不知道你是怎么進(jìn)行組件劃分的
如果是做成兄弟組件的話
那這個屬于兄弟組件之間傳值問題
可以用vuex解決
<div dangerouslySetInnerHTML={ {__html: '測試文本,lilnong'.replace(/(測試文本)/g,'<i>$1</i>')} }/>加個withRouter試試https://reacttraining.com/rea...
可以在server_name下面這行這個試試
server {
listen 443;
# server_name *.ht920.com ht920.com;
server_name www.ht920.com;
server_name_in_redirect off;
ssl on;
ssl_certificate cert/1523974750873.pem;
ssl_certificate_key cert/1523974750873.key;
ssl_session_timeout 5m;
ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:ECDHE:ECDH:AES:HIGH:!NULL:!aNULL:!MD5:!ADH:!RC4;
ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
ssl_prefer_server_ciphers on;
location / {
index index.html index.htm index.php;
proxy_redirect off;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_pass https://localhost:8443;
}
access_log logs/ht920.com_access.log;
}使用CDN,加速視頻。
題主是不是對ts的類型斷言有誤解,類型斷言的作用只是在這個變量不確定是什么類型的時候告訴ts的編譯器你想要斷言的類型,然后ts的編譯器會根據(jù)你斷言后的類型去做相應(yīng)的類型檢查,類型斷言不是類型轉(zhuǎn)換,你這個問題里面你的res返回的是object類型的就算你再怎么斷言它還是一個object
PS: 類型斷言不是類型轉(zhuǎn)換
下面有一個場景
將每一個請求想象為一個運動員,請求數(shù)據(jù)像是運動員在賽跑,第一名獎勵是可以打產(chǎn)品狗一巴掌,但是只能有一個人去打,那就看誰跑得快了~
吃了個飯回來再看明白了,不知道對不對,補(bǔ)碼擴(kuò)展的話高位是0補(bǔ)零是1補(bǔ)1,所以上面的-8加5可以寫成11000 + 00101=11101
請自行查找 alter 用法。修改一下對應(yīng)字段的設(shè)置就好了。
真機(jī)測試搖一搖
如果我按鈕事件是在另一個組件這個怎么傳輸,給組件綁定ref打印出來的是這樣的
print(1, '\n', 2, sep='')
我是這樣解的,你可參考以下:
//解密獲取ComponentVerifyTicket
$encodingAesKey = ''; //申請時填寫的"消息加解密Key"
$token = ''; //申請時填寫的"消息校驗Token"
$appId = ''; //申請時填寫的"消息校驗Token"
$msg_signature = $request['msg_signature'];
$timestamp = $request['timestamp'];
$nonce = $request['nonce'];
$encryptMsg = file_get_contents('php://input');
libxml_disable_entity_loader(true);
$xml_obj = (array)simplexml_load_string($encryptMsg, 'SimpleXMLElement', LIBXML_NOCDATA);
// 重新拼接xml
$encrypt = $xml_obj['Encrypt'];
$encryptMsg = sprintf("<xml><ToUserName><![CDATA[toUser]]></ToUserName><Encrypt><![CDATA[%s]]></Encrypt></xml>", $encrypt);
// 解密
$pc = new WXBizMsgCrypt($token, $encodingAesKey, $appId);
$pc->WXBizMsgCrypt($token, $encodingAesKey, $appId);
$msg = '';
$errCode = $pc->decryptMsg($msg_signature, $timestamp, $nonce, $encryptMsg, $msg);
if ($errCode) {
return $errCode;
}
else {
libxml_disable_entity_loader(true);
$xml_obj = (array)simplexml_load_string($msg, 'SimpleXMLElement', LIBXML_NOCDATA);
// 返回ComponentVerifyTicket
return $xml_obj['ComponentVerifyTicket'];
}我自己琢磨出了一種辦法,不知道可行否。
我生成3個客戶端:
處理正常req,res請求的
發(fā)布消息的
訂閱消息的
我本來想用訂閱消息的redis客戶端來處理正常req,res請求但是報錯:
ReplyError: ERR only (P)SUBSCRIBE / (P)UNSUBSCRIBE / PING / QUIT
allowed in this context
后來才知道,原來如果客戶端用于訂閱消息就不能下其他命令進(jìn)行CRUD。
所以才要再建一個客戶端處理正常的req, res請求。
下面是代碼:
var redis = require('redis');
var express = require('express');
var app = express();
var clientSub = redis.createClient(6379, 'localhost');
var clientPub = redis.createClient(6379, 'localhost');
var clientRes = redis.createClient(6379,'localhost');
clientRes.on('ready', function(err){
console.log('hello, i handle req/res');
});
clientPub.on('ready', function (err) {
console.log('hello, i publish');
});
clientSub.on('ready', function (err) {
console.log('hello, i subscribe');
});
clientSub.subscribe('channel1');
clientSub.on('subscribe', function (channel, count) {
console.log(`got subscribe event: ${channel} and count is ${count}`);
setInterval(()=>{
clientPub.publish('channel1', `hi, i am channel one, message at ${new Date()}`);
}, 2000);
});
clientSub.on('connect', function () {
clientSub.on('message', function (channel, message) {
var response = `received message from ${channel}:${message}`;
clientRes.lpush('myResponse', response,redis.print);
});
});
app.get('/', function (req, res) {
clientRes.lrange('myResponse',0,-1, function(err, result){
console.log(result[result.length])
res.send(typeof result);
})
})
app.listen(1338, function () {
console.log('App listening on port 1338!');
});
https://jsfiddle.net/g7askt9w... 只能先寫個這個樣的 開銷很大如果數(shù)據(jù)很大
let datas =[{id:0},{id:2},
{id:1,parentId:0},
{id:6,parentId:2},
{id:7,parentId:6},
{id:3,parentId:1},
{id:4,parentId:0},
{id:5,parentId:3}]
let arr=[]
function treedata(data,a){
data.forEach((r,index)=>{
if(r.parentId==a.id){
arr.push(r)
/* datas.splice(index,1) */
treedata(datas,r)
}
})
}
datas.forEach((r,index)=>{
if(r.parentId || r.parentId===0){
}else{
arr.push(r)
/* datas.splice(index,1) */
treedata(datas,r)
}
})
console.log(arr) 好吧搞定了 自定義的tooltip行內(nèi)style會被覆蓋,寫在class里面就可以了
webpack和vue-cli沒關(guān)系。vue-cli只是安裝工具和npm一樣,只不多正對的是vue,如果要支持webpack3.0
首先是模板支持3.0,就目前而言vue init webpack 中的webpack只支持1.0,和2.0 地址:
https://github.com/vuejs-templates/webpack
當(dāng)然了,也有可能有其他私人的庫可以使用
北大青鳥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)格清新自然、條理清晰、主次分明、重點難點突出、引人入勝。
精通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)師。