コードを見ると、LoginPageCS.csはLoginPage.xamlとほとんど同じように見えます。つまり、XAMLではなくC#でページコントロールを作成する方法になります。この相違点については、this questionを参照してください。
注類似
LoginPage.xaml:
<?xml version="1.0" encoding="UTF-8"?>
<ContentPage xmlns="http://xamarin.com/schemas/2014/forms" xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml" x:Class="LoginNavigation.LoginPage" Title="Login">
<ContentPage.ToolbarItems>
<ToolbarItem Text="Sign Up" Clicked="OnSignUpButtonClicked" />
</ContentPage.ToolbarItems>
<ContentPage.Content>
<StackLayout VerticalOptions="StartAndExpand">
<Label Text="Username" />
<Entry x:Name="usernameEntry" Placeholder="username" />
<Label Text="Password" />
<Entry x:Name="passwordEntry" IsPassword="true" />
<Button Text="Login" Clicked="OnLoginButtonClicked" />
<Label x:Name="messageLabel" />
</StackLayout>
</ContentPage.Content>
</ContentPage>
LoginPageCS.cs:
public LoginPageCS()
{
var toolbarItem = new ToolbarItem {
Text = "Sign Up"
};
toolbarItem.Clicked += OnSignUpButtonClicked;
ToolbarItems.Add (toolbarItem);
messageLabel = new Label();
usernameEntry = new Entry {
Placeholder = "username"
};
passwordEntry = new Entry {
IsPassword = true
};
var loginButton = new Button {
Text = "Login"
};
loginButton.Clicked += OnLoginButtonClicked;
Title = "Login";
Content = new StackLayout {
VerticalOptions = LayoutOptions.StartAndExpand,
Children = {
new Label { Text = "Username" },
usernameEntry,
new Label { Text = "Password" },
passwordEntry,
loginButton,
messageLabel
}
};
}
マージンはページがC#コードを介して作成されていることを伝えるための単なる視覚的な方法であり、 Xamlではありません。 – SushiHangover
XAMLはUIデザイナーに親切で、*コードジェネレータ*の入力です。あなたは通常、それが生成するコードを見ることはできませんし、そのコードはそれほどきれいではありません。代わりに、foo.xamlとfoo.xaml.csファイルとまったく同じことをするfooCS.csファイルも提供します。しかし、fooCSという別のクラスでは。そのクラスはプロジェクトで実際には使用されません。実証的な使い方以外にも、xamlの代わりにプログラマーにコードを書くよう促すかもしれません。 –