js操作ios剪切板,ios 禁止讀取剪切板

本文目錄一覽:

iOS oc-剪切板

一、自帶剪切板操作的原生UI控件

在iOS的UI系統中,有3個控件自帶剪切板操作,分別是UITextField、UITextView與UIWebView。在這些控件的文字交互處進行長按手勢可以在屏幕視圖上喚出系統的剪切板控件,用戶可以進行複製、粘貼,剪切等操作

二、系統的剪切板管理類UIPasteboard

實際上,當用戶通過上面的空間進行複製、剪切等操作時,被選中的內容會被存放到系統的剪切板中,並且這個剪切板並不只能存放字符串數據,其還可以進行圖片數據與網址URL數據的存放。這個剪切板就是UIPasteboard類,開發者也可以直接通過它來操作數據進行應用內或應用間傳值。

UIPasteboard類有3個初始化方法,如下:

//獲取系統級別的剪切板

+ (UIPasteboard *)generalPasteboard;

//獲取一個自定義的剪切板 name參數為此剪切板的名稱 create參數用於設置當這個剪切板不存在時 是否進行創建

+ (nullable UIPasteboard *)pasteboardWithName:(NSString *)pasteboardName create:(BOOL)create;

//獲取一個應用內可用的剪切板

+ (UIPasteboard *)pasteboardWithUniqueName;

上面3個初始化方法,分別獲取或創建3個級別不同的剪切板,系統級別的剪切板在整個設備中共享,即是應用程序被刪掉,其向系統級的剪切板中寫入的數據依然在。自定義的剪切板通過一個特定的名稱字符串進行創建,它在應用程序內或者同一開發者開發的其他應用程序中可以進行數據共享。第3個方法創建的剪切板等價為使用第2個方法創建的剪切板,只是其名稱字符串為nil,它通常用於當前應用內部。

注意:使用第3個方法創建的剪切板默認是不進行數據持久化的,及當應用程序退出後,剪切板中內容將別抹去。若要實現持久化,需要設置persistent屬性為YES。

UIPasteboard中常用方法及屬性如下:

//剪切板的名稱

@property(readonly,nonatomic) NSString *name;

//根據名稱刪除一個剪切板

+ (void)removePasteboardWithName:(NSString *)pasteboardName;

//是否進行持久化

@property(getter=isPersistent,nonatomic) BOOL persistent;

//此剪切板的改變次數 系統級別的剪切板只有當設備重新啟動時 這個值才會清零

@property(readonly,nonatomic) NSInteger changeCount;

下面這些方法用於設置與獲取剪切板中的數據:

最新一組數據對象的存取:

/獲取剪切板中最新數據的類型

– (NSArray*)pasteboardTypes;

//獲取剪切板中最新數據對象是否包含某一類型的數據- (BOOL)containsPasteboardTypes:(NSArray*)pasteboardTypes;

//將剪切板中最新數據對象某一類型的數據取出

– (nullable NSData *)dataForPasteboardType:(NSString *)pasteboardType;

//將剪切板中最新數據對象某一類型的值取出

– (nullable id)valueForPasteboardType:(NSString *)pasteboardType;

//為剪切板中最新數據對應的某一數據類型設置值

– (void)setValue:(id)value forPasteboardType:(NSString *)pasteboardType;

//為剪切板中最新數據對應的某一數據類型設置數據

– (void)setData:(NSData *)data forPasteboardType:(NSString *)pasteboardType;

多組數據對象的存取:

 //數據組數@property(readonly,nonatomic) NSInteger numberOfItems;

//獲取一組數據對象包含的數據類型

– (nullable NSArray *)pasteboardTypesForItemSet:(nullable NSIndexSet*)itemSet;

//獲取一組數據對象中是否包含某些數據類型

– (BOOL)containsPasteboardTypes:(NSArray*)pasteboardTypes inItemSet:(nullable NSIndexSet *)itemSet;

//根據數據類型獲取一組數據對象

– (nullable NSIndexSet *)itemSetWithPasteboardTypes:(NSArray *)pasteboardTypes;

//根據數據類型獲取一組數據的值

– (nullable NSArray *)valuesForPasteboardType:(NSString *)pasteboardType inItemSet:(nullable NSIndexSet *)itemSet;

//根據數據類型獲取一組數據的NSData數據

– (nullable NSArray *)dataForPasteboardType:(NSString *)pasteboardType inItemSet:(nullable NSIndexSet *)itemSet;

//所有數據對象

@property(nonatomic,copy) NSArray *items;

//添加一組數據對象

– (void)addItems:(NSArray* *)items;

上面方法中很多需要傳入數據類型參數,這些參數是系統定義好的一些字符竄,如下:

//所有字符串類型數據的類型定義字符串數組

UIKIT_EXTERN NSArray*UIPasteboardTypeListString;

//所有URL類型數據的類型定義字符串數組

UIKIT_EXTERN NSArray*UIPasteboardTypeListURL;

//所有圖片數據的類型定義字符串數據

UIKIT_EXTERN NSArray*UIPasteboardTypeListImage;

//所有顏色數據的類型定義字符串數組

UIKIT_EXTERN NSArray*UIPasteboardTypeListColor;

相比於上面兩組方法,下面這些方法更加面向對象,在開發中使用更加方便與快捷:

//獲取或設置剪切板中的字符串數據

@property(nullable,nonatomic,copy) NSString *string;

//獲取或設置剪切板中的字符串數組

@property(nullable,nonatomic,copy) NSArray*strings;

//獲取或設置剪切板中的URL數據

@property(nullable,nonatomic,copy) NSURL *URL;

//獲取或設置剪切板中的URL數組

@property(nullable,nonatomic,copy) NSArray*URLs;

//獲取或s何止剪切板中的圖片數據

@property(nullable,nonatomic,copy) UIImage *image;

//獲取或設置剪切板中的圖片數組

@property(nullable,nonatomic,copy) NSArray*images;

//獲取或設置剪切板中的顏色數據

@property(nullable,nonatomic,copy) UIColor *color;

//獲取或設置剪切板中的顏色數組

@property(nullable,nonatomic,copy) NSArray*colors;

對剪切板的某些操作會觸發如下通知:

//剪切板內容發生變化時發送的通知

UIKIT_EXTERN NSString *const UIPasteboardChangedNotification;

//剪切板數據類型鍵值增加時發送的通知

UIKIT_EXTERN NSString *const UIPasteboardChangedTypesAddedKey;

//剪切板數據類型鍵值移除時發送的通知

UIKIT_EXTERN NSString *const UIPasteboardChangedTypesRemovedKey;

//剪切板被刪除時發送的通知

UIKIT_EXTERN NSString *const UIPasteboardRemovedNotification;

三、複製圖片的簡單例子

創建一個CopyView

#import “CopyView.h”

@interface CopyView ()

@property (strong, nonatomic) UIImageView* img1;

@property (strong, nonatomic) UIImageView* img2;

@end 

@implementation CopyView

-(UIImageView *)img1{  

if (_img1 == nil) {   

 _img1 = [[UIImageView alloc] initWithFrame:CGRectMake(10.0f, 20.0f, 100.0f, 100.0f)]; 

   NSString* path = [[NSBundle mainBundle] pathForResource:@”NetworldImage” ofType:@”jpg”];

    _img1.image = [UIImage imageWithContentsOfFile:path]; 

 }  

return _img1;

-(UIImageView *)img2{  if (_img2 == nil) { 

   _img2 = [[UIImageView alloc] initWithFrame:CGRectMake(CGRectGetMaxX(self.img1.frame)+50.0f, 20.0f, 100.0f, 100.0f)];

    _img2.backgroundColor = [UIColor lightGrayColor]; 

 }  

return _img2;

}

 – (instancetype)initWithFrame:(CGRect)frame {

  self = [super initWithFrame:frame];

  if (self) { 

   self.backgroundColor = [UIColor whiteColor];

    [self addSubview:self.img1];

    [self addSubview:self.img2];

  }  

return self;

-(BOOL)canBecomeFirstResponder{

  return YES;

}

-(BOOL)canPerformAction:(SEL)action withSender:(id)sender{

  NSArray* methodNameArr = @[@”copy:”,@”cut:”,@”select:”,@”selectAll:”,@”paste:”];

  if ([methodNameArr containsObject:NSStringFromSelector(action)]) { 

   return YES; 

 }  

return [super canPerformAction:action withSender:sender];

-(void)copy:(id)sender{ 

 UIPasteboard* pasteboard = [UIPasteboard generalPasteboard];

  [pasteboard setImage:self.img1.image];

}

 -(void)paste:(id)sender{ 

 UIPasteboard* pasteboard = [UIPasteboard generalPasteboard];

  self.img2.image = [pasteboard image];

-(void)touchesBegan:(NSSet*)touches withEvent:(UIEvent *)event{

[self becomeFirstResponder];

UIMenuController* menuController = [UIMenuController sharedMenuController];

[menuController setTargetRect:self.img1.frame inView:self];

[menuController setMenuVisible:YES animated:YES];

}

@end

在controller中

#import “ViewController.h”

#import “CopyView.h”

@implementation ViewController

– (void)viewDidLoad {

[super viewDidLoad];

CopyView* cv = [[CopyView alloc] initWithFrame:self.view.bounds];

self.view = cv;

}

@end

如何用JS操作粘貼板

主要是用到了 window.clipboardData.setData(“Text”,copyText);

他主要有兩個參數:第一個是設置要複製的是一段文本,第二個參數是要複製具體的內容,這個內容可以從文本框中或使用innerHTML獲取。

簡單的實例代碼:

複製代碼 代碼如下:

script type=”text/javascript”

function copyData() {

var copyText = document.getElementById(“ctl00_cpRight_txtUrl”).value;

window.clipboardData.setData(“Text”,copyText);

}

/script

asp:TextBox ID=”txtUrl” runat=”server” Height=”30px” Width=”349px”/asp:TextBox

input id=”btnCopyUrl” type=”button” value=”複製URL到粘貼板” onclick=”copyData()” /

註:ctl00_cpRight_txtUrl這個ID其實是txtUrl生成頁面後自動生成的ID。

js 蘋果 safair 瀏覽器怎麼獲取剪切板內容

可以用 js 給頁面中的元素綁定 paste 事件的方法,當用戶鼠標在該元素上或者該元素處於 focus 狀態,綁定到 paste 事件的方法就運行了。

綁定的元素不一定是 input ,普通的 div 也是可以綁定的,如果是給 document 綁定了,就相當於全局了,任何時候的粘貼操作都會觸發。

js/jQuery怎麼自動複製到剪貼板

出於安全問題,無法使用原生的 JS 或 jQuery 來操作粘貼板。除非使用瀏覽器擴展(需設置權限),或者使用Flash。

某些瀏覽器允許在文本框內使用 document.execCommand(‘copy’) 與 document.execCommand(‘paste’) 來操作剪貼板。

(但現在基於較新版本的webkit內核以及主流的瀏覽器,該命令已經被False)

如何用js實現複製到剪貼板

放文字試過,方圖片沒試過。

不過可以給你參考一下js~,你自己試試,成功了可以告訴我。

script

function copyToClipboard()

{

var d = document.all(“source”).value;

window.clipboardData.setData(‘text’, d);

}

/script

BODY

button onclick=”copyToClipboard();”拷貝/button

input type=”text” size=20 id=”source” value=”測試數據”

br

button onclick=”alert(window.clipboardData.getData(‘text’));”顯示/button

button onclick=”window.clipboardData.clearData(‘text’);”清空/button

/BODY

原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hk/n/246927.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2024-12-12 13:17
下一篇 2024-12-12 13:17

相關推薦

  • JS Proxy(array)用法介紹

    JS Proxy(array)可以說是ES6中非常重要的一個特性,它可以代理一個數組,監聽數據變化並進行攔截、處理。在實際開發中,使用Proxy(array)可以方便地實現數據的監…

    編程 2025-04-29
  • Python棧操作用法介紹

    如果你是一位Python開發工程師,那麼你必須掌握Python中的棧操作。在Python中,棧是一個容器,提供後進先出(LIFO)的原則。這篇文章將通過多個方面詳細地闡述Pytho…

    編程 2025-04-29
  • Python操作數組

    本文將從多個方面詳細介紹如何使用Python操作5個數組成的列表。 一、數組的定義 數組是一種用於存儲相同類型數據的數據結構。Python中的數組是通過列表來實現的,列表中可以存放…

    編程 2025-04-29
  • Python操作MySQL

    本文將從以下幾個方面對Python操作MySQL進行詳細闡述: 一、連接MySQL數據庫 在使用Python操作MySQL之前,我們需要先連接MySQL數據庫。在Python中,我…

    編程 2025-04-29
  • Python磁盤操作全方位解析

    本篇文章將從多個方面對Python磁盤操作進行詳細闡述,包括文件讀寫、文件夾創建、刪除、文件搜索與遍歷、文件重命名、移動、複製、文件權限修改等常用操作。 一、文件讀寫操作 文件讀寫…

    編程 2025-04-29
  • Python代碼實現迴文數最少操作次數

    本文將介紹如何使用Python解決一道經典的迴文數問題:給定一個數n,按照一定規則對它進行若干次操作,使得n成為迴文數,求最少的操作次數。 一、問題分析 首先,我們需要了解迴文數的…

    編程 2025-04-29
  • 解析js base64並轉成unit

    本文將從多個方面詳細介紹js中如何解析base64編碼並轉成unit格式。 一、base64編碼解析 在JavaScript中解析base64編碼可以使用atob()函數,它會將b…

    編程 2025-04-29
  • Python元祖操作用法介紹

    本文將從多個方面對Python元祖的操作進行詳細闡述。包括:元祖定義及初始化、元祖遍歷、元祖切片、元祖合併及比較、元祖解包等內容。 一、元祖定義及初始化 元祖在Python中屬於序…

    編程 2025-04-29
  • Python列表的讀寫操作

    本文將針對Python列表的讀取與寫入操作進行詳細的闡述,包括列表的基本操作、列表的增刪改查、列表切片、列表排序、列表反轉、列表拼接、列表複製等操作。 一、列表的基本操作 列表是P…

    編程 2025-04-29
  • Node.js使用Body-Parser處理HTTP POST請求時,特殊字符無法返回的解決方法

    本文將解決Node.js使用Body-Parser處理HTTP POST請求時,特殊字符無法返回的問題。同時,給出一些相關示例代碼,以幫助讀者更好的理解並處理這個問題。 一、問題解…

    編程 2025-04-29

發表回復

登錄後才能評論