成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

React-Native

bbbbbb / 3213人閱讀

摘要:系統(tǒng)存在啟動魚銷毀一個的一條有序的回調(diào)函數(shù)。一個,繼承子所在應(yīng)用進程的窗口管理器有一個主要用來管理窗口的一些狀態(tài),屬性,增加,刪除,更新,窗口順序,消息收集和處理等。通過接口與全局窗口管理器進行交互界面控制和消息響應(yīng)。

安裝

iOS啟動注意

在xcode項目代碼中AppDelegate.m會標(biāo)識入口文件。例如:jsCodeLocation = [NSURL URLWithString:@"http://localhost:8081/index.ios.bundle"]

閃屏界面在哪修改?

xcode項目中找到LaunchScreen.xib文件,就是啟動界面。手動添加組件或修改文本即可。

文本編輯器打開index.ios.js文件,是js代碼的入口文件,所有的代碼編寫從這開始,可以定義自己的模塊和引入第三方模塊。

原生知識點

andriod的activity跳轉(zhuǎn)

兩個activity之間的跳轉(zhuǎn)。
android中有一個比較重要的組件--activity,是用于顯示View的。
比如:利用react創(chuàng)建簡單的app,當(dāng)一開打開app的時候,其實就進入了一個主的activity,由其渲染主界面(activity可以簡單理解為瀏覽器的tab)。

andriod系統(tǒng)根據(jù)生命周期的不同階段喚起對應(yīng)的回調(diào)函數(shù)來執(zhí)行代碼。系統(tǒng)存在啟動魚銷毀一個activity的一條有序的回調(diào)函數(shù)。

Acitivity: Activity包含一個Window,改window在Acitivity的attach方法中調(diào)用PolicyManager.makeNewWindow創(chuàng)建。
View:最基本的UI組件,表示屏幕上的一個矩形區(qū)域。
DecorView:是Window中的View的RootView,設(shè)置窗口屬性。
Window:表示頂層窗口,管理界面的顯示和事件的相應(yīng)。每個Activity均會創(chuàng)建一個PhoneWinodw對象,是Activity和整個View系統(tǒng)交互的接口。
WIndowManager: 一個interface,繼承子ViewManager.所在應(yīng)用進程的窗口管理器;有一個implementtation WindowManagerImpl;主要用來管理窗口的一些狀態(tài),屬性,view增加,刪除,更新,窗口順序,消息收集和處理等。
ViewRoot:通過IWindowSession 接口與全局窗口管理器進行交互:界面控制和消息響應(yīng)。
ActivityThread:應(yīng)用程序的主線程,其中會創(chuàng)建關(guān)聯(lián)當(dāng)前Activity于Window;創(chuàng)建WindowManager實現(xiàn)雷實例,把當(dāng)前DecoView加入到WindowManager

flex布局

react-native中的flex布局應(yīng)用的6的屬性

flex
var Text = React.createClass({
    render() {
        return (
            
                
                
                
            
        );
    }
});


var styles = StyleSheet.create({
    style_0: {
        flex: 1,
    },
    style_1: {
        flex: 5,
        height: 40,
        borderWidth: 1,
        borderColor: "red"
    }
});

當(dāng)一個組件(元素),定義了flex屬性時,表示改元素是可伸縮的。
flex的屬性值是大于0的時候伸縮,其小余和等于0的時候不伸縮,例如:flex: 0, flex: -1.

代碼中:最外層的View是可伸縮的,因為沒有兄弟節(jié)點和它占空間,占滿全屏。里層是3個View,可以看到三個View的flex屬性加起來是5+5+10 = 20.所以第一個View和第二個View分別占1/4伸縮空間,最后一個View占據(jù)1/2空間。

flexDireaction

屬性值:row, column
flexDirecation在React-Native只有兩個屬性: row(橫向伸縮) ,column(縱向伸縮)

flexWrap

flexWrap屬性值:
wrap,nowrap

alignItems

alignItems屬性值:
flex-start,flex-end,center,stretch

alignSelf

alignSelf橫向?qū)ζ浞绞剑?br>flex-start,flex-end,center, stretch

justifyContent

justifyContent縱向?qū)ζ浞绞剑?br>flex-strat,flex-end,center,space-between,space-around

樣式

和普通的css不一樣的地方

RN樣式的屬性名,需要使用駝峰式

應(yīng)用于組件的style屬性上的樣式,可以不止一個,可以使用多個,以逗號分隔。如 style={styles.a, styles.b}

可以在樣式中使用變量.
例如:需要一個元素的寬度等于屏幕的寬度。

const styles = StyleSheet.create({
    container: {
        flex: 1,
        flexDireaction: "column",
        width: Dimensions.get("window").width
    }
});
定位
position
top
left
bottom
right
布局

RN是border-box模型

width
height
margin
padding
border
flex系列

marginVertical  // 上下外留白的簡寫,如果marginTop和marginBottom一樣。
marginHorizontal // 左右外留白的簡寫
paddingVertial
paddingHorizontal
背景
backgroundColor
backgroundVisibility
文字
color
fontFamily
fontSize
fontStyle
fontWeight
textAlign
textDecorationColor
textDecorationLine
textDecorationStyle
letterSpacing
lineHeight
陰影
shadowColor 陰影色iOS only
shadowOffset 陰影距離iOS only
shadowOpaicty 陰影透明度iOS only
shadowRadius 陰影半徑 iOS only
elevation 仰角 android only // 這是屬性影響著元素的z-index,就是絕對定位時覆蓋順序,也會在元素上產(chǎn)生一個陰影。
其它
opacity
overflow
resizeMode
rotation
scaleX
scaleY
transform
transformMatrix
translateX
translateY
writingDirection
文本輸入
constructor(props) {
    super(props);    
    this.state = { text: "" }
}

render() {
    return (
        
             this.setStatet({text: textCount})} />
            
                {this.state.text.split(" ").map((word) => word && "aaa").join()}
            
        
    );
}

react-native布局的一些坑

不存在zIndex,后面的元素覆蓋前面的元素。

內(nèi)層元素覆蓋外層元素。

borderRadius的設(shè)置,需要考慮到內(nèi)層元素的位置。

flex為0,系統(tǒng)不會自動計算寬高。

View內(nèi)部的元素不要超出父級的范圍,iOS問題不大,andriod上就什么超出的都看不到了。

lineHeight可以用,不過不要寫成小數(shù),否則andriod上會直接崩潰。

RN的樣式不存在繼承的情況,所以基本上的每個節(jié)點都要寫style。 (Text相關(guān)樣式除外,Text嵌套的話,其文字屬性也會應(yīng)用于子元素)

如果Text的父級元素設(shè)置了背景顏色,那么iOS下Text的背景顏色也是父級的背景顏色,那么自己寫Text重置下樣式,那么就遇到了再改。

RN的字號是沒有設(shè)置單位的,所以會隨著系統(tǒng)設(shè)置的字體大小而變化。

RN的樣式中的width/height的單位是DP

RN沒有寬高100%的設(shè)置,所以如果需要讓元素?fù)螡M屏幕 :

react語法

jsx語法

生命周期

componentWillMount:組件創(chuàng)建之前
getInitialState:初始化狀態(tài)
render:渲染視圖
componentDidMount:渲染視圖完成后
componentWillUnmount:組件被卸載之前

樣式解析

普通內(nèi)聯(lián)樣式:{{}},第一層{}是表達式,第二層{}是js對象;

 

調(diào)用樣式表:{樣式類.屬性}

樣式表和內(nèi)聯(lián)樣式共存:{[]}

多個樣式表:{[樣式類1, 樣式類2]}


設(shè)置屬性默認(rèn)值
Recat.createClass({
    getDefaultProps() {
        return {
            sign: "正在加載..."
        }
    }
});
事件綁定
class TestReact extends Component {
    construcotr(props) {
        super(props);
        this.state = {
            name: "a"
        }
    }
    changeState() {
        this.setState({
            name: "b"
        });
    }
    render() {
        return (
            
                當(dāng)前狀態(tài)是:{this.state.name}
            
        );
    }
}

TouchEnd事件綁定在最外層View上。
注意:事件觸發(fā)函數(shù)的上下文,默認(rèn)就是本組件。 changeState中的this,就是指代的就是TestReact的實例.

獲取元素

refs屬性

class TestReact extends Component {
    getPos() {
        this.res.position.measure((fx, fy, width, height, px, py) => {
            console.log("位置:", "x:", fx, "y:", fy);        
        });
    }
    render() {
        return (
            
                位置
            
        );
    }
}
全局對象

在RN中,引用全局對象可以使用window或者global,它們都指向一個對象 -- DedicatedWorkerGlobalScope,,其中有jscore提供的方法,也有RN注入的方法.

props

Props屬性
設(shè)置:在應(yīng)用組件上傳遞key=val
獲?。?b>this.props.key

class Test exntds Compontent {
    render() {
        return (
            
                HELLO {this.props.name}
            
        );
    }
}

export default class FirstApp extned Componet {
    render() {
        return {
            
                
                
                    
            
        }
    }
}
state

在constructor中初始化state,然后再需要修改時調(diào)用setState方法。

設(shè)置:this.setState({key: val})
獲?。?b>this.state.key

constructor(props) {
    super(props);
    this.state = {
        count: 0
    }
}
doUpdateCount() {
    this.setState({count: this.state.count + 1});
}

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/82682.html

相關(guān)文章

  • react-native:環(huán)境搭建

    摘要:是開源的,在和的基礎(chǔ)上構(gòu)建原生的和應(yīng)用的平臺。著力于提高多平臺的開發(fā)效率,。下面簡單介紹下的環(huán)境搭建。環(huán)境要求最新的系統(tǒng),要開發(fā)應(yīng)用就必須使用系統(tǒng)。運行在當(dāng)前目錄下會多出一個的目錄,里面是項目的文件。 Any application that than can be written in JavaScript will eventually be written in JavaScri...

    curried 評論0 收藏0
  • 從 1 到完美,用 js 和 react-native 寫一個 APP

    摘要:從到完美,用和寫一個在年開源了后,緊接著在年就又開源了,就此打開了用和前端技術(shù)寫原生之路。對應(yīng)來看,程序只有兩個部分,和,而部分則分為組件和。所以,在端的純庫無在中同樣適用,如等。應(yīng)用實例便是使用開發(fā)的一個日記。 從 1 到完美,用 js 和 react-native 寫一個 APP facebook 在 2013 年開源了 react 后,緊接著在 2015 年就又開源了 react...

    CollinPeng 評論0 收藏0
  • react-native電影簡介app,了解一下?(android端)

    摘要:寒假結(jié)束了,在寒假期間玩了一下,模仿豆瓣實現(xiàn)了一個查看當(dāng)前熱門電影和即將上映電影的簡單,項目比較簡單,十分適合剛剛?cè)腴T的同學(xué)查看。 寒假結(jié)束了,在寒假期間玩了一下react-native,模仿豆瓣實現(xiàn)了一個查看當(dāng)前熱門電影和即將上映電影的簡單app,項目比較簡單,十分適合剛剛?cè)腴T的同學(xué)查看。首先我們要了解react-native: react-native中文網(wǎng)、react-nativ...

    RayKr 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<